tldraw 3.16.0-canary.8c74738e06fb → 3.16.0-canary.9a2b07b264aa
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.
- package/dist-cjs/index.d.ts +100 -5
- package/dist-cjs/index.js +13 -1
- package/dist-cjs/index.js.map +2 -2
- package/dist-cjs/lib/canvas/TldrawScribble.js +1 -1
- package/dist-cjs/lib/canvas/TldrawScribble.js.map +2 -2
- package/dist-cjs/lib/shapes/arrow/ArrowShapeUtil.js +3 -3
- package/dist-cjs/lib/shapes/arrow/ArrowShapeUtil.js.map +2 -2
- package/dist-cjs/lib/shapes/arrow/arrowTargetState.js +1 -1
- package/dist-cjs/lib/shapes/arrow/arrowTargetState.js.map +2 -2
- package/dist-cjs/lib/shapes/arrow/elbow/ElbowArrowDebug.js +3 -3
- package/dist-cjs/lib/shapes/arrow/elbow/ElbowArrowDebug.js.map +1 -1
- package/dist-cjs/lib/shapes/draw/DrawShapeUtil.js +3 -3
- package/dist-cjs/lib/shapes/draw/DrawShapeUtil.js.map +2 -2
- package/dist-cjs/lib/shapes/embed/EmbedShapeUtil.js +1 -1
- package/dist-cjs/lib/shapes/embed/EmbedShapeUtil.js.map +1 -1
- package/dist-cjs/lib/shapes/frame/FrameShapeUtil.js +12 -12
- package/dist-cjs/lib/shapes/frame/FrameShapeUtil.js.map +2 -2
- package/dist-cjs/lib/shapes/frame/components/FrameHeading.js +1 -1
- package/dist-cjs/lib/shapes/frame/components/FrameHeading.js.map +2 -2
- package/dist-cjs/lib/shapes/geo/GeoShapeUtil.js +2 -2
- package/dist-cjs/lib/shapes/geo/GeoShapeUtil.js.map +2 -2
- package/dist-cjs/lib/shapes/geo/components/GeoShapeBody.js +2 -1
- package/dist-cjs/lib/shapes/geo/components/GeoShapeBody.js.map +2 -2
- package/dist-cjs/lib/shapes/highlight/HighlightShapeUtil.js +5 -1
- package/dist-cjs/lib/shapes/highlight/HighlightShapeUtil.js.map +2 -2
- package/dist-cjs/lib/shapes/image/ImageShapeUtil.js +3 -3
- package/dist-cjs/lib/shapes/image/ImageShapeUtil.js.map +1 -1
- package/dist-cjs/lib/shapes/line/LineShapeUtil.js +5 -1
- package/dist-cjs/lib/shapes/line/LineShapeUtil.js.map +2 -2
- package/dist-cjs/lib/shapes/note/NoteShapeUtil.js +4 -4
- package/dist-cjs/lib/shapes/note/NoteShapeUtil.js.map +2 -2
- package/dist-cjs/lib/shapes/shared/ShapeFill.js +4 -4
- package/dist-cjs/lib/shapes/shared/ShapeFill.js.map +2 -2
- package/dist-cjs/lib/shapes/shared/usePrefersReducedMotion.js +10 -1
- package/dist-cjs/lib/shapes/shared/usePrefersReducedMotion.js.map +2 -2
- package/dist-cjs/lib/shapes/text/TextShapeUtil.js +2 -2
- package/dist-cjs/lib/shapes/text/TextShapeUtil.js.map +2 -2
- package/dist-cjs/lib/shapes/video/VideoShapeUtil.js +3 -3
- package/dist-cjs/lib/shapes/video/VideoShapeUtil.js.map +1 -1
- package/dist-cjs/lib/tools/EraserTool/childStates/Erasing.js +25 -1
- package/dist-cjs/lib/tools/EraserTool/childStates/Erasing.js.map +2 -2
- package/dist-cjs/lib/tools/EraserTool/childStates/Pointing.js +12 -0
- package/dist-cjs/lib/tools/EraserTool/childStates/Pointing.js.map +2 -2
- package/dist-cjs/lib/ui/TldrawUi.js +14 -0
- package/dist-cjs/lib/ui/TldrawUi.js.map +3 -3
- package/dist-cjs/lib/ui/components/AccessibilityMenu.js +35 -0
- package/dist-cjs/lib/ui/components/AccessibilityMenu.js.map +7 -0
- package/dist-cjs/lib/ui/components/ActionsMenu/DefaultActionsMenu.js +12 -3
- package/dist-cjs/lib/ui/components/ActionsMenu/DefaultActionsMenu.js.map +2 -2
- package/dist-cjs/lib/ui/components/DefaultMenuPanel.js +3 -2
- package/dist-cjs/lib/ui/components/DefaultMenuPanel.js.map +2 -2
- package/dist-cjs/lib/ui/components/MainMenu/DefaultMainMenuContent.js +3 -3
- package/dist-cjs/lib/ui/components/MainMenu/DefaultMainMenuContent.js.map +2 -2
- package/dist-cjs/lib/ui/components/Minimap/MinimapManager.js +4 -4
- package/dist-cjs/lib/ui/components/Minimap/MinimapManager.js.map +2 -2
- package/dist-cjs/lib/ui/components/MobileStylePanel.js +5 -3
- package/dist-cjs/lib/ui/components/MobileStylePanel.js.map +2 -2
- package/dist-cjs/lib/ui/components/NavigationPanel/DefaultNavigationPanel.js +1 -1
- package/dist-cjs/lib/ui/components/NavigationPanel/DefaultNavigationPanel.js.map +2 -2
- package/dist-cjs/lib/ui/components/PageMenu/DefaultPageMenu.js +2 -1
- package/dist-cjs/lib/ui/components/PageMenu/DefaultPageMenu.js.map +2 -2
- package/dist-cjs/lib/ui/components/SharePanel/PeopleMenuItem.js +3 -2
- package/dist-cjs/lib/ui/components/SharePanel/PeopleMenuItem.js.map +2 -2
- package/dist-cjs/lib/ui/components/SharePanel/UserPresenceColorPicker.js +2 -2
- package/dist-cjs/lib/ui/components/SharePanel/UserPresenceColorPicker.js.map +2 -2
- package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanel.js +2 -0
- package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanel.js.map +2 -2
- package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanelContent.js +171 -140
- package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanelContent.js.map +2 -2
- package/dist-cjs/lib/ui/components/StylePanel/DoubleDropdownPicker.js +3 -3
- package/dist-cjs/lib/ui/components/StylePanel/DoubleDropdownPicker.js.map +2 -2
- package/dist-cjs/lib/ui/components/StylePanel/DropdownPicker.js +26 -25
- package/dist-cjs/lib/ui/components/StylePanel/DropdownPicker.js.map +3 -3
- package/dist-cjs/lib/ui/components/Toolbar/DefaultImageToolbarContent.js +1 -1
- package/dist-cjs/lib/ui/components/Toolbar/DefaultImageToolbarContent.js.map +2 -2
- package/dist-cjs/lib/ui/components/Toolbar/DefaultToolbar.js +66 -21
- package/dist-cjs/lib/ui/components/Toolbar/DefaultToolbar.js.map +3 -3
- package/dist-cjs/lib/ui/components/Toolbar/OverflowingToolbar.js +189 -80
- package/dist-cjs/lib/ui/components/Toolbar/OverflowingToolbar.js.map +3 -3
- package/dist-cjs/lib/ui/components/Toolbar/ToggleToolLockedButton.js +5 -4
- package/dist-cjs/lib/ui/components/Toolbar/ToggleToolLockedButton.js.map +2 -2
- package/dist-cjs/lib/ui/components/menu-items.js +6 -0
- package/dist-cjs/lib/ui/components/menu-items.js.map +2 -2
- package/dist-cjs/lib/ui/components/primitives/TldrawUiButtonPicker.js +5 -16
- package/dist-cjs/lib/ui/components/primitives/TldrawUiButtonPicker.js.map +3 -3
- package/dist-cjs/lib/ui/components/primitives/TldrawUiContextualToolbar.js +1 -1
- package/dist-cjs/lib/ui/components/primitives/TldrawUiContextualToolbar.js.map +2 -2
- package/dist-cjs/lib/ui/components/primitives/TldrawUiPopover.js +3 -2
- package/dist-cjs/lib/ui/components/primitives/TldrawUiPopover.js.map +3 -3
- package/dist-cjs/lib/ui/components/primitives/TldrawUiToolbar.js +30 -7
- package/dist-cjs/lib/ui/components/primitives/TldrawUiToolbar.js.map +2 -2
- package/dist-cjs/lib/ui/components/primitives/TldrawUiTooltip.js +268 -0
- package/dist-cjs/lib/ui/components/primitives/TldrawUiTooltip.js.map +7 -0
- package/dist-cjs/lib/ui/components/primitives/layout.js +76 -0
- package/dist-cjs/lib/ui/components/primitives/layout.js.map +7 -0
- package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuContext.js.map +2 -2
- package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuGroup.js +25 -12
- package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuGroup.js.map +2 -2
- package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuItem.js +11 -26
- package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuItem.js.map +2 -2
- package/dist-cjs/lib/ui/context/TldrawUiContextProvider.js +3 -2
- package/dist-cjs/lib/ui/context/TldrawUiContextProvider.js.map +2 -2
- package/dist-cjs/lib/ui/context/actions.js +15 -0
- package/dist-cjs/lib/ui/context/actions.js.map +2 -2
- package/dist-cjs/lib/ui/context/events.js.map +2 -2
- package/dist-cjs/lib/ui/hooks/useTools.js +21 -3
- package/dist-cjs/lib/ui/hooks/useTools.js.map +2 -2
- package/dist-cjs/lib/ui/hooks/useTranslation/TLUiTranslationKey.js.map +1 -1
- package/dist-cjs/lib/ui/hooks/useTranslation/defaultTranslation.js +3 -0
- package/dist-cjs/lib/ui/hooks/useTranslation/defaultTranslation.js.map +2 -2
- package/dist-cjs/lib/ui/version.js +3 -3
- package/dist-cjs/lib/ui/version.js.map +1 -1
- package/dist-esm/index.d.mts +100 -5
- package/dist-esm/index.mjs +23 -1
- package/dist-esm/index.mjs.map +2 -2
- package/dist-esm/lib/canvas/TldrawScribble.mjs +1 -1
- package/dist-esm/lib/canvas/TldrawScribble.mjs.map +2 -2
- package/dist-esm/lib/shapes/arrow/ArrowShapeUtil.mjs +4 -3
- package/dist-esm/lib/shapes/arrow/ArrowShapeUtil.mjs.map +2 -2
- package/dist-esm/lib/shapes/arrow/arrowTargetState.mjs +1 -1
- package/dist-esm/lib/shapes/arrow/arrowTargetState.mjs.map +2 -2
- package/dist-esm/lib/shapes/arrow/elbow/ElbowArrowDebug.mjs +3 -3
- package/dist-esm/lib/shapes/arrow/elbow/ElbowArrowDebug.mjs.map +1 -1
- package/dist-esm/lib/shapes/draw/DrawShapeUtil.mjs +4 -3
- package/dist-esm/lib/shapes/draw/DrawShapeUtil.mjs.map +2 -2
- package/dist-esm/lib/shapes/embed/EmbedShapeUtil.mjs +1 -1
- package/dist-esm/lib/shapes/embed/EmbedShapeUtil.mjs.map +1 -1
- package/dist-esm/lib/shapes/frame/FrameShapeUtil.mjs +13 -12
- package/dist-esm/lib/shapes/frame/FrameShapeUtil.mjs.map +2 -2
- package/dist-esm/lib/shapes/frame/components/FrameHeading.mjs +1 -1
- package/dist-esm/lib/shapes/frame/components/FrameHeading.mjs.map +2 -2
- package/dist-esm/lib/shapes/geo/GeoShapeUtil.mjs +3 -2
- package/dist-esm/lib/shapes/geo/GeoShapeUtil.mjs.map +2 -2
- package/dist-esm/lib/shapes/geo/components/GeoShapeBody.mjs +2 -1
- package/dist-esm/lib/shapes/geo/components/GeoShapeBody.mjs.map +2 -2
- package/dist-esm/lib/shapes/highlight/HighlightShapeUtil.mjs +6 -1
- package/dist-esm/lib/shapes/highlight/HighlightShapeUtil.mjs.map +2 -2
- package/dist-esm/lib/shapes/image/ImageShapeUtil.mjs +3 -3
- package/dist-esm/lib/shapes/image/ImageShapeUtil.mjs.map +1 -1
- package/dist-esm/lib/shapes/line/LineShapeUtil.mjs +6 -1
- package/dist-esm/lib/shapes/line/LineShapeUtil.mjs.map +2 -2
- package/dist-esm/lib/shapes/note/NoteShapeUtil.mjs +5 -4
- package/dist-esm/lib/shapes/note/NoteShapeUtil.mjs.map +2 -2
- package/dist-esm/lib/shapes/shared/ShapeFill.mjs +5 -4
- package/dist-esm/lib/shapes/shared/ShapeFill.mjs.map +2 -2
- package/dist-esm/lib/shapes/shared/usePrefersReducedMotion.mjs +10 -1
- package/dist-esm/lib/shapes/shared/usePrefersReducedMotion.mjs.map +2 -2
- package/dist-esm/lib/shapes/text/TextShapeUtil.mjs +3 -2
- package/dist-esm/lib/shapes/text/TextShapeUtil.mjs.map +2 -2
- package/dist-esm/lib/shapes/video/VideoShapeUtil.mjs +3 -3
- package/dist-esm/lib/shapes/video/VideoShapeUtil.mjs.map +1 -1
- package/dist-esm/lib/tools/EraserTool/childStates/Erasing.mjs +26 -1
- package/dist-esm/lib/tools/EraserTool/childStates/Erasing.mjs.map +2 -2
- package/dist-esm/lib/tools/EraserTool/childStates/Pointing.mjs +13 -0
- package/dist-esm/lib/tools/EraserTool/childStates/Pointing.mjs.map +2 -2
- package/dist-esm/lib/ui/TldrawUi.mjs +16 -2
- package/dist-esm/lib/ui/TldrawUi.mjs.map +3 -3
- package/dist-esm/lib/ui/components/AccessibilityMenu.mjs +19 -0
- package/dist-esm/lib/ui/components/AccessibilityMenu.mjs.map +7 -0
- package/dist-esm/lib/ui/components/ActionsMenu/DefaultActionsMenu.mjs +12 -3
- package/dist-esm/lib/ui/components/ActionsMenu/DefaultActionsMenu.mjs.map +2 -2
- package/dist-esm/lib/ui/components/DefaultMenuPanel.mjs +3 -2
- package/dist-esm/lib/ui/components/DefaultMenuPanel.mjs.map +2 -2
- package/dist-esm/lib/ui/components/MainMenu/DefaultMainMenuContent.mjs +3 -5
- package/dist-esm/lib/ui/components/MainMenu/DefaultMainMenuContent.mjs.map +2 -2
- package/dist-esm/lib/ui/components/Minimap/MinimapManager.mjs +4 -4
- package/dist-esm/lib/ui/components/Minimap/MinimapManager.mjs.map +2 -2
- package/dist-esm/lib/ui/components/MobileStylePanel.mjs +6 -3
- package/dist-esm/lib/ui/components/MobileStylePanel.mjs.map +2 -2
- package/dist-esm/lib/ui/components/NavigationPanel/DefaultNavigationPanel.mjs +1 -1
- package/dist-esm/lib/ui/components/NavigationPanel/DefaultNavigationPanel.mjs.map +2 -2
- package/dist-esm/lib/ui/components/PageMenu/DefaultPageMenu.mjs +2 -1
- package/dist-esm/lib/ui/components/PageMenu/DefaultPageMenu.mjs.map +2 -2
- package/dist-esm/lib/ui/components/SharePanel/PeopleMenuItem.mjs +3 -2
- package/dist-esm/lib/ui/components/SharePanel/PeopleMenuItem.mjs.map +2 -2
- package/dist-esm/lib/ui/components/SharePanel/UserPresenceColorPicker.mjs +2 -2
- package/dist-esm/lib/ui/components/SharePanel/UserPresenceColorPicker.mjs.map +2 -2
- package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanel.mjs +3 -1
- package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanel.mjs.map +2 -2
- package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanelContent.mjs +171 -140
- package/dist-esm/lib/ui/components/StylePanel/DefaultStylePanelContent.mjs.map +2 -2
- package/dist-esm/lib/ui/components/StylePanel/DoubleDropdownPicker.mjs +3 -3
- package/dist-esm/lib/ui/components/StylePanel/DoubleDropdownPicker.mjs.map +2 -2
- package/dist-esm/lib/ui/components/StylePanel/DropdownPicker.mjs +26 -25
- package/dist-esm/lib/ui/components/StylePanel/DropdownPicker.mjs.map +2 -2
- package/dist-esm/lib/ui/components/Toolbar/DefaultImageToolbarContent.mjs +1 -1
- package/dist-esm/lib/ui/components/Toolbar/DefaultImageToolbarContent.mjs.map +2 -2
- package/dist-esm/lib/ui/components/Toolbar/DefaultToolbar.mjs +56 -21
- package/dist-esm/lib/ui/components/Toolbar/DefaultToolbar.mjs.map +2 -2
- package/dist-esm/lib/ui/components/Toolbar/OverflowingToolbar.mjs +192 -81
- package/dist-esm/lib/ui/components/Toolbar/OverflowingToolbar.mjs.map +3 -3
- package/dist-esm/lib/ui/components/Toolbar/ToggleToolLockedButton.mjs +5 -4
- package/dist-esm/lib/ui/components/Toolbar/ToggleToolLockedButton.mjs.map +2 -2
- package/dist-esm/lib/ui/components/menu-items.mjs +6 -0
- package/dist-esm/lib/ui/components/menu-items.mjs.map +2 -2
- package/dist-esm/lib/ui/components/primitives/TldrawUiButtonPicker.mjs +6 -6
- package/dist-esm/lib/ui/components/primitives/TldrawUiButtonPicker.mjs.map +2 -2
- package/dist-esm/lib/ui/components/primitives/TldrawUiContextualToolbar.mjs +1 -1
- package/dist-esm/lib/ui/components/primitives/TldrawUiContextualToolbar.mjs.map +2 -2
- package/dist-esm/lib/ui/components/primitives/TldrawUiPopover.mjs +3 -2
- package/dist-esm/lib/ui/components/primitives/TldrawUiPopover.mjs.map +2 -2
- package/dist-esm/lib/ui/components/primitives/TldrawUiToolbar.mjs +30 -7
- package/dist-esm/lib/ui/components/primitives/TldrawUiToolbar.mjs.map +2 -2
- package/dist-esm/lib/ui/components/primitives/TldrawUiTooltip.mjs +245 -0
- package/dist-esm/lib/ui/components/primitives/TldrawUiTooltip.mjs.map +7 -0
- package/dist-esm/lib/ui/components/primitives/layout.mjs +46 -0
- package/dist-esm/lib/ui/components/primitives/layout.mjs.map +7 -0
- package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuContext.mjs.map +2 -2
- package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuGroup.mjs +25 -12
- package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuGroup.mjs.map +2 -2
- package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuItem.mjs +11 -26
- package/dist-esm/lib/ui/components/primitives/menus/TldrawUiMenuItem.mjs.map +2 -2
- package/dist-esm/lib/ui/context/TldrawUiContextProvider.mjs +3 -2
- package/dist-esm/lib/ui/context/TldrawUiContextProvider.mjs.map +2 -2
- package/dist-esm/lib/ui/context/actions.mjs +15 -0
- package/dist-esm/lib/ui/context/actions.mjs.map +2 -2
- package/dist-esm/lib/ui/context/events.mjs.map +2 -2
- package/dist-esm/lib/ui/hooks/useTools.mjs +22 -3
- package/dist-esm/lib/ui/hooks/useTools.mjs.map +2 -2
- package/dist-esm/lib/ui/hooks/useTranslation/defaultTranslation.mjs +3 -0
- package/dist-esm/lib/ui/hooks/useTranslation/defaultTranslation.mjs.map +2 -2
- package/dist-esm/lib/ui/version.mjs +3 -3
- package/dist-esm/lib/ui/version.mjs.map +1 -1
- package/package.json +3 -3
- package/src/index.ts +18 -0
- package/src/lib/canvas/TldrawScribble.tsx +1 -1
- package/src/lib/shapes/arrow/ArrowShapeUtil.tsx +4 -3
- package/src/lib/shapes/arrow/arrowTargetState.ts +2 -1
- package/src/lib/shapes/arrow/elbow/ElbowArrowDebug.tsx +3 -3
- package/src/lib/shapes/draw/DrawShapeUtil.tsx +4 -3
- package/src/lib/shapes/embed/EmbedShapeUtil.tsx +1 -1
- package/src/lib/shapes/frame/FrameShapeUtil.tsx +21 -14
- package/src/lib/shapes/frame/components/FrameHeading.tsx +1 -1
- package/src/lib/shapes/geo/GeoShapeUtil.tsx +3 -2
- package/src/lib/shapes/geo/components/GeoShapeBody.tsx +2 -2
- package/src/lib/shapes/highlight/HighlightShapeUtil.tsx +7 -1
- package/src/lib/shapes/image/ImageShapeUtil.tsx +3 -3
- package/src/lib/shapes/line/LineShapeUtil.tsx +6 -1
- package/src/lib/shapes/note/NoteShapeUtil.tsx +9 -4
- package/src/lib/shapes/shared/ShapeFill.tsx +5 -4
- package/src/lib/shapes/shared/usePrefersReducedMotion.tsx +11 -1
- package/src/lib/shapes/text/TextShapeUtil.tsx +3 -2
- package/src/lib/shapes/video/VideoShapeUtil.tsx +3 -3
- package/src/lib/tools/EraserTool/childStates/Erasing.ts +34 -1
- package/src/lib/tools/EraserTool/childStates/Pointing.ts +20 -0
- package/src/lib/ui/TldrawUi.tsx +17 -2
- package/src/lib/ui/components/AccessibilityMenu.tsx +20 -0
- package/src/lib/ui/components/ActionsMenu/DefaultActionsMenu.tsx +15 -3
- package/src/lib/ui/components/DefaultMenuPanel.tsx +4 -3
- package/src/lib/ui/components/MainMenu/DefaultMainMenuContent.tsx +4 -4
- package/src/lib/ui/components/Minimap/MinimapManager.ts +4 -4
- package/src/lib/ui/components/MobileStylePanel.tsx +9 -6
- package/src/lib/ui/components/NavigationPanel/DefaultNavigationPanel.tsx +1 -1
- package/src/lib/ui/components/PageMenu/DefaultPageMenu.tsx +3 -2
- package/src/lib/ui/components/SharePanel/PeopleMenuItem.tsx +4 -3
- package/src/lib/ui/components/SharePanel/UserPresenceColorPicker.tsx +3 -3
- package/src/lib/ui/components/StylePanel/DefaultStylePanel.tsx +3 -1
- package/src/lib/ui/components/StylePanel/DefaultStylePanelContent.tsx +146 -107
- package/src/lib/ui/components/StylePanel/DoubleDropdownPicker.tsx +3 -3
- package/src/lib/ui/components/StylePanel/DropdownPicker.tsx +7 -6
- package/src/lib/ui/components/Toolbar/DefaultImageToolbarContent.tsx +1 -1
- package/src/lib/ui/components/Toolbar/DefaultToolbar.tsx +55 -23
- package/src/lib/ui/components/Toolbar/OverflowingToolbar.tsx +212 -61
- package/src/lib/ui/components/Toolbar/ToggleToolLockedButton.tsx +14 -11
- package/src/lib/ui/components/menu-items.tsx +8 -0
- package/src/lib/ui/components/primitives/TldrawUiButtonPicker.tsx +40 -37
- package/src/lib/ui/components/primitives/TldrawUiContextualToolbar.tsx +1 -1
- package/src/lib/ui/components/primitives/TldrawUiPopover.tsx +4 -2
- package/src/lib/ui/components/primitives/TldrawUiToolbar.tsx +51 -12
- package/src/lib/ui/components/primitives/TldrawUiTooltip.tsx +327 -0
- package/src/lib/ui/components/primitives/layout.tsx +107 -0
- package/src/lib/ui/components/primitives/menus/TldrawUiMenuContext.tsx +0 -1
- package/src/lib/ui/components/primitives/menus/TldrawUiMenuGroup.tsx +29 -16
- package/src/lib/ui/components/primitives/menus/TldrawUiMenuItem.tsx +15 -25
- package/src/lib/ui/context/TldrawUiContextProvider.tsx +23 -20
- package/src/lib/ui/context/actions.tsx +15 -0
- package/src/lib/ui/context/events.tsx +1 -0
- package/src/lib/ui/hooks/useTools.tsx +25 -3
- package/src/lib/ui/hooks/useTranslation/TLUiTranslationKey.ts +3 -0
- package/src/lib/ui/hooks/useTranslation/defaultTranslation.ts +3 -0
- package/src/lib/ui/version.ts +3 -3
- package/src/lib/ui.css +406 -292
- package/src/test/EraserTool.test.ts +176 -6
- package/src/test/arrows-megabus.test.tsx +12 -6
- package/src/test/inner-outer-margin.test.ts +315 -0
- package/tldraw.css +699 -580
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { TLGeoShape } from '@tldraw/editor'
|
|
1
|
+
import { getColorValue, TLGeoShape } from '@tldraw/editor'
|
|
2
2
|
import { ShapeFill } from '../../shared/ShapeFill'
|
|
3
3
|
import { STROKE_SIZES } from '../../shared/default-shape-constants'
|
|
4
4
|
import { useDefaultColorTheme } from '../../shared/useDefaultColorTheme'
|
|
@@ -33,7 +33,7 @@ export function GeoShapeBody({
|
|
|
33
33
|
strokeWidth,
|
|
34
34
|
forceSolid,
|
|
35
35
|
randomSeed: shape.id,
|
|
36
|
-
props: { fill: 'none', stroke: theme
|
|
36
|
+
props: { fill: 'none', stroke: getColorValue(theme, color, 'solid') },
|
|
37
37
|
})}
|
|
38
38
|
</>
|
|
39
39
|
)
|
|
@@ -10,6 +10,7 @@ import {
|
|
|
10
10
|
TLHighlightShapeProps,
|
|
11
11
|
TLResizeInfo,
|
|
12
12
|
VecLike,
|
|
13
|
+
getColorValue,
|
|
13
14
|
highlightShapeMigrations,
|
|
14
15
|
highlightShapeProps,
|
|
15
16
|
last,
|
|
@@ -289,7 +290,12 @@ function HighlightRenderer({
|
|
|
289
290
|
: getShapeDot(shape.props.segments[0].points[0])
|
|
290
291
|
|
|
291
292
|
const colorSpace = useColorSpace()
|
|
292
|
-
|
|
293
|
+
|
|
294
|
+
const color = getColorValue(
|
|
295
|
+
theme,
|
|
296
|
+
shape.props.color,
|
|
297
|
+
colorSpace === 'p3' ? 'highlightP3' : 'highlightSrgb'
|
|
298
|
+
)
|
|
293
299
|
|
|
294
300
|
return (
|
|
295
301
|
<path
|
|
@@ -314,9 +314,9 @@ const ImageShape = memo(function ImageShape({ shape }: { shape: TLImageShape })
|
|
|
314
314
|
overflow: 'hidden',
|
|
315
315
|
width: shape.props.w,
|
|
316
316
|
height: shape.props.h,
|
|
317
|
-
color: 'var(--color-text-3)',
|
|
318
|
-
backgroundColor: 'var(--color-low)',
|
|
319
|
-
border: '1px solid var(--color-low-border)',
|
|
317
|
+
color: 'var(--tl-color-text-3)',
|
|
318
|
+
backgroundColor: 'var(--tl-color-low)',
|
|
319
|
+
border: '1px solid var(--tl-color-low-border)',
|
|
320
320
|
}}
|
|
321
321
|
>
|
|
322
322
|
<div
|
|
@@ -12,6 +12,7 @@ import {
|
|
|
12
12
|
WeakCache,
|
|
13
13
|
ZERO_INDEX_KEY,
|
|
14
14
|
assert,
|
|
15
|
+
getColorValue,
|
|
15
16
|
getIndexAbove,
|
|
16
17
|
getIndexBetween,
|
|
17
18
|
getIndices,
|
|
@@ -346,6 +347,10 @@ function LineShapeSvg({
|
|
|
346
347
|
strokeWidth,
|
|
347
348
|
forceSolid,
|
|
348
349
|
randomSeed: shape.id,
|
|
349
|
-
props: {
|
|
350
|
+
props: {
|
|
351
|
+
transform: `scale(${scale})`,
|
|
352
|
+
stroke: getColorValue(theme, color, 'solid'),
|
|
353
|
+
fill: 'none',
|
|
354
|
+
},
|
|
350
355
|
})
|
|
351
356
|
}
|
|
@@ -17,6 +17,7 @@ import {
|
|
|
17
17
|
Vec,
|
|
18
18
|
WeakCache,
|
|
19
19
|
exhaustiveSwitchError,
|
|
20
|
+
getColorValue,
|
|
20
21
|
getDefaultColorTheme,
|
|
21
22
|
getFontsFromRichText,
|
|
22
23
|
isEqual,
|
|
@@ -288,7 +289,7 @@ export class NoteShapeUtil extends ShapeUtil<TLNoteShape> {
|
|
|
288
289
|
style={{
|
|
289
290
|
width: nw,
|
|
290
291
|
height: nh,
|
|
291
|
-
backgroundColor: theme
|
|
292
|
+
backgroundColor: getColorValue(theme, color, 'noteFill'),
|
|
292
293
|
borderBottom: hideShadows
|
|
293
294
|
? isDarkMode
|
|
294
295
|
? `${2 * scale}px solid rgb(20, 20, 20)`
|
|
@@ -308,7 +309,11 @@ export class NoteShapeUtil extends ShapeUtil<TLNoteShape> {
|
|
|
308
309
|
verticalAlign={verticalAlign}
|
|
309
310
|
richText={richText}
|
|
310
311
|
isSelected={isSelected}
|
|
311
|
-
labelColor={
|
|
312
|
+
labelColor={
|
|
313
|
+
labelColor === 'black'
|
|
314
|
+
? getColorValue(theme, color, 'noteText')
|
|
315
|
+
: getColorValue(theme, labelColor, 'fill')
|
|
316
|
+
}
|
|
312
317
|
wrap
|
|
313
318
|
padding={LABEL_PADDING * scale}
|
|
314
319
|
hasCustomTabBehavior
|
|
@@ -343,7 +348,7 @@ export class NoteShapeUtil extends ShapeUtil<TLNoteShape> {
|
|
|
343
348
|
align={shape.props.align}
|
|
344
349
|
verticalAlign={shape.props.verticalAlign}
|
|
345
350
|
richText={shape.props.richText}
|
|
346
|
-
labelColor={theme
|
|
351
|
+
labelColor={getColorValue(theme, shape.props.color, 'noteText')}
|
|
347
352
|
bounds={bounds}
|
|
348
353
|
padding={LABEL_PADDING}
|
|
349
354
|
showTextOutline={false}
|
|
@@ -357,7 +362,7 @@ export class NoteShapeUtil extends ShapeUtil<TLNoteShape> {
|
|
|
357
362
|
rx={1}
|
|
358
363
|
width={NOTE_SIZE}
|
|
359
364
|
height={bounds.h}
|
|
360
|
-
fill={theme
|
|
365
|
+
fill={getColorValue(theme, shape.props.color, 'noteFill')}
|
|
361
366
|
/>
|
|
362
367
|
{textLabel}
|
|
363
368
|
</>
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import {
|
|
2
|
+
getColorValue,
|
|
2
3
|
TLDefaultColorStyle,
|
|
3
4
|
TLDefaultColorTheme,
|
|
4
5
|
TLDefaultFillStyle,
|
|
@@ -29,13 +30,13 @@ export const ShapeFill = React.memo(function ShapeFill({
|
|
|
29
30
|
return null
|
|
30
31
|
}
|
|
31
32
|
case 'solid': {
|
|
32
|
-
return <path fill={theme
|
|
33
|
+
return <path fill={getColorValue(theme, color, 'semi')} d={d} />
|
|
33
34
|
}
|
|
34
35
|
case 'semi': {
|
|
35
36
|
return <path fill={theme.solid} d={d} />
|
|
36
37
|
}
|
|
37
38
|
case 'fill': {
|
|
38
|
-
return <path fill={theme
|
|
39
|
+
return <path fill={getColorValue(theme, color, 'fill')} d={d} />
|
|
39
40
|
}
|
|
40
41
|
case 'pattern': {
|
|
41
42
|
return <PatternFill theme={theme} color={color} fill={fill} d={d} scale={scale} />
|
|
@@ -53,13 +54,13 @@ export function PatternFill({ d, color, theme }: ShapeFillProps) {
|
|
|
53
54
|
|
|
54
55
|
return (
|
|
55
56
|
<>
|
|
56
|
-
<path fill={theme
|
|
57
|
+
<path fill={getColorValue(theme, color, 'pattern')} d={d} />
|
|
57
58
|
<path
|
|
58
59
|
fill={
|
|
59
60
|
svgExport
|
|
60
61
|
? `url(#${getHashPatternZoomName(1, theme.id)})`
|
|
61
62
|
: teenyTiny
|
|
62
|
-
? theme
|
|
63
|
+
? getColorValue(theme, color, 'semi')
|
|
63
64
|
: `url(#${getHashPatternZoomName(zoomLevel, theme.id)})`
|
|
64
65
|
}
|
|
65
66
|
d={d}
|
|
@@ -1,10 +1,20 @@
|
|
|
1
|
+
import { useMaybeEditor, useValue } from '@tldraw/editor'
|
|
1
2
|
import { useEffect, useState } from 'react'
|
|
2
3
|
|
|
3
4
|
/** @public */
|
|
4
5
|
export function usePrefersReducedMotion() {
|
|
6
|
+
const editor = useMaybeEditor()
|
|
7
|
+
const animationSpeed = useValue('animationSpeed', () => editor?.user.getAnimationSpeed(), [
|
|
8
|
+
editor,
|
|
9
|
+
])
|
|
5
10
|
const [prefersReducedMotion, setPrefersReducedMotion] = useState(false)
|
|
6
11
|
|
|
7
12
|
useEffect(() => {
|
|
13
|
+
if (animationSpeed !== undefined) {
|
|
14
|
+
setPrefersReducedMotion(animationSpeed === 0 ? true : false)
|
|
15
|
+
return
|
|
16
|
+
}
|
|
17
|
+
|
|
8
18
|
if (typeof window === 'undefined' || !('matchMedia' in window)) return
|
|
9
19
|
const mql = window.matchMedia('(prefers-reduced-motion: reduce)')
|
|
10
20
|
const handler = () => {
|
|
@@ -13,7 +23,7 @@ export function usePrefersReducedMotion() {
|
|
|
13
23
|
handler()
|
|
14
24
|
mql.addEventListener('change', handler)
|
|
15
25
|
return () => mql.removeEventListener('change', handler)
|
|
16
|
-
}, [])
|
|
26
|
+
}, [animationSpeed])
|
|
17
27
|
|
|
18
28
|
return prefersReducedMotion
|
|
19
29
|
}
|
|
@@ -11,6 +11,7 @@ import {
|
|
|
11
11
|
TLTextShape,
|
|
12
12
|
Vec,
|
|
13
13
|
createComputedCache,
|
|
14
|
+
getColorValue,
|
|
14
15
|
getDefaultColorTheme,
|
|
15
16
|
getFontsFromRichText,
|
|
16
17
|
isEqual,
|
|
@@ -135,7 +136,7 @@ export class TextShapeUtil extends ShapeUtil<TLTextShape> {
|
|
|
135
136
|
align={textAlign}
|
|
136
137
|
verticalAlign="middle"
|
|
137
138
|
richText={richText}
|
|
138
|
-
labelColor={theme
|
|
139
|
+
labelColor={getColorValue(theme, color, 'solid')}
|
|
139
140
|
isSelected={isSelected}
|
|
140
141
|
textWidth={width}
|
|
141
142
|
textHeight={height}
|
|
@@ -171,7 +172,7 @@ export class TextShapeUtil extends ShapeUtil<TLTextShape> {
|
|
|
171
172
|
align={shape.props.textAlign}
|
|
172
173
|
verticalAlign="middle"
|
|
173
174
|
richText={shape.props.richText}
|
|
174
|
-
labelColor={theme
|
|
175
|
+
labelColor={getColorValue(theme, shape.props.color, 'solid')}
|
|
175
176
|
bounds={exportBounds}
|
|
176
177
|
padding={0}
|
|
177
178
|
/>
|
|
@@ -142,9 +142,9 @@ const VideoShape = memo(function VideoShape({ shape }: { shape: TLVideoShape })
|
|
|
142
142
|
<HTMLContainer
|
|
143
143
|
id={shape.id}
|
|
144
144
|
style={{
|
|
145
|
-
color: 'var(--color-text-3)',
|
|
146
|
-
backgroundColor: asset ? 'transparent' : 'var(--color-low)',
|
|
147
|
-
border: asset ? 'none' : '1px solid var(--color-low-border)',
|
|
145
|
+
color: 'var(--tl-color-text-3)',
|
|
146
|
+
backgroundColor: asset ? 'transparent' : 'var(--tl-color-low)',
|
|
147
|
+
border: asset ? 'none' : '1px solid var(--tl-color-low-border)',
|
|
148
148
|
}}
|
|
149
149
|
>
|
|
150
150
|
<div className="tl-counter-scaled">
|
|
@@ -4,6 +4,7 @@ import {
|
|
|
4
4
|
TLGroupShape,
|
|
5
5
|
TLPointerEventInfo,
|
|
6
6
|
TLShapeId,
|
|
7
|
+
isAccelKey,
|
|
7
8
|
pointInPolygon,
|
|
8
9
|
} from '@tldraw/editor'
|
|
9
10
|
|
|
@@ -15,7 +16,15 @@ export class Erasing extends StateNode {
|
|
|
15
16
|
private markId = ''
|
|
16
17
|
private excludedShapeIds = new Set<TLShapeId>()
|
|
17
18
|
|
|
19
|
+
_isHoldingAccelKey = false
|
|
20
|
+
_firstErasingShapeId: TLShapeId | null = null
|
|
21
|
+
_erasingShapeIds: TLShapeId[] = []
|
|
22
|
+
|
|
18
23
|
override onEnter(info: TLPointerEventInfo) {
|
|
24
|
+
this._isHoldingAccelKey = isAccelKey(this.editor.inputs)
|
|
25
|
+
this._firstErasingShapeId = this.editor.getErasingShapeIds()[0] // the first one should be the first one we hit... is it?
|
|
26
|
+
this._erasingShapeIds = this.editor.getErasingShapeIds()
|
|
27
|
+
|
|
19
28
|
this.markId = this.editor.markHistoryStoppingPoint('erase scribble begin')
|
|
20
29
|
this.info = info
|
|
21
30
|
|
|
@@ -76,6 +85,16 @@ export class Erasing extends StateNode {
|
|
|
76
85
|
this.complete()
|
|
77
86
|
}
|
|
78
87
|
|
|
88
|
+
override onKeyUp() {
|
|
89
|
+
this._isHoldingAccelKey = isAccelKey(this.editor.inputs)
|
|
90
|
+
this.update()
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
override onKeyDown() {
|
|
94
|
+
this._isHoldingAccelKey = isAccelKey(this.editor.inputs)
|
|
95
|
+
this.update()
|
|
96
|
+
}
|
|
97
|
+
|
|
79
98
|
update() {
|
|
80
99
|
const { editor, excludedShapeIds } = this
|
|
81
100
|
const erasingShapeIds = editor.getErasingShapeIds()
|
|
@@ -87,6 +106,7 @@ export class Erasing extends StateNode {
|
|
|
87
106
|
|
|
88
107
|
this.pushPointToScribble()
|
|
89
108
|
|
|
109
|
+
// Otherwise, erasing shapes are all the shapes that were hit before plus any new shapes that are hit
|
|
90
110
|
const erasing = new Set<TLShapeId>(erasingShapeIds)
|
|
91
111
|
const minDist = this.editor.options.hitTestMargin / zoomLevel
|
|
92
112
|
|
|
@@ -121,18 +141,31 @@ export class Erasing extends StateNode {
|
|
|
121
141
|
if (geometry.hitTestLineSegment(A, B, minDist)) {
|
|
122
142
|
erasing.add(editor.getOutermostSelectableShape(shape).id)
|
|
123
143
|
}
|
|
144
|
+
|
|
145
|
+
this._erasingShapeIds = [...erasing]
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
// If the user is holding the meta / ctrl key, we should only erase the first shape we hit
|
|
149
|
+
if (this._isHoldingAccelKey && this._firstErasingShapeId) {
|
|
150
|
+
const erasingShapeId = this._firstErasingShapeId
|
|
151
|
+
if (erasingShapeId && this.editor.getShape(erasingShapeId)) {
|
|
152
|
+
editor.setErasingShapes([erasingShapeId])
|
|
153
|
+
}
|
|
154
|
+
return
|
|
124
155
|
}
|
|
125
156
|
|
|
126
157
|
// Remove the hit shapes, except if they're in the list of excluded shapes
|
|
127
158
|
// (these excluded shapes will be any frames or groups the pointer was inside of
|
|
128
159
|
// when the user started erasing)
|
|
129
|
-
this.editor.setErasingShapes(
|
|
160
|
+
this.editor.setErasingShapes(this._erasingShapeIds.filter((id) => !excludedShapeIds.has(id)))
|
|
130
161
|
}
|
|
131
162
|
|
|
132
163
|
complete() {
|
|
133
164
|
const { editor } = this
|
|
134
165
|
editor.deleteShapes(editor.getCurrentPageState().erasingShapeIds)
|
|
135
166
|
this.parent.transition('idle')
|
|
167
|
+
this._erasingShapeIds = []
|
|
168
|
+
this._firstErasingShapeId = null
|
|
136
169
|
}
|
|
137
170
|
|
|
138
171
|
cancel() {
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import {
|
|
2
|
+
isAccelKey,
|
|
2
3
|
StateNode,
|
|
3
4
|
TLFrameShape,
|
|
4
5
|
TLGroupShape,
|
|
@@ -9,7 +10,11 @@ import {
|
|
|
9
10
|
export class Pointing extends StateNode {
|
|
10
11
|
static override id = 'pointing'
|
|
11
12
|
|
|
13
|
+
_isHoldingAccelKey = false
|
|
14
|
+
|
|
12
15
|
override onEnter() {
|
|
16
|
+
this._isHoldingAccelKey = isAccelKey(this.editor.inputs)
|
|
17
|
+
|
|
13
18
|
const zoomLevel = this.editor.getZoomLevel()
|
|
14
19
|
const currentPageShapesSorted = this.editor.getCurrentPageRenderingShapesSorted()
|
|
15
20
|
const {
|
|
@@ -45,12 +50,25 @@ export class Pointing extends StateNode {
|
|
|
45
50
|
}
|
|
46
51
|
|
|
47
52
|
erasing.add(hitShape.id)
|
|
53
|
+
|
|
54
|
+
// If the user is holding the meta / ctrl key, stop after the first shape
|
|
55
|
+
if (this._isHoldingAccelKey) {
|
|
56
|
+
break
|
|
57
|
+
}
|
|
48
58
|
}
|
|
49
59
|
}
|
|
50
60
|
|
|
51
61
|
this.editor.setErasingShapes([...erasing])
|
|
52
62
|
}
|
|
53
63
|
|
|
64
|
+
override onKeyUp() {
|
|
65
|
+
this._isHoldingAccelKey = isAccelKey(this.editor.inputs)
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
override onKeyDown() {
|
|
69
|
+
this._isHoldingAccelKey = isAccelKey(this.editor.inputs)
|
|
70
|
+
}
|
|
71
|
+
|
|
54
72
|
override onLongPress(info: TLPointerEventInfo) {
|
|
55
73
|
this.startErasing(info)
|
|
56
74
|
}
|
|
@@ -62,6 +80,8 @@ export class Pointing extends StateNode {
|
|
|
62
80
|
}
|
|
63
81
|
|
|
64
82
|
override onPointerMove(info: TLPointerEventInfo) {
|
|
83
|
+
if (this._isHoldingAccelKey) return
|
|
84
|
+
|
|
65
85
|
if (this.editor.inputs.isDragging) {
|
|
66
86
|
this.startErasing(info)
|
|
67
87
|
}
|
package/src/lib/ui/TldrawUi.tsx
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import { tlenv, useEditor, useReactor, useValue } from '@tldraw/editor'
|
|
2
2
|
import classNames from 'classnames'
|
|
3
|
-
import React, { ReactNode, useRef, useState } from 'react'
|
|
3
|
+
import React, { ReactNode, useMemo, useRef, useState } from 'react'
|
|
4
4
|
import { TLUiAssetUrlOverrides } from './assetUrls'
|
|
5
5
|
import { SkipToMainContent } from './components/A11y'
|
|
6
6
|
import { FollowingIndicator } from './components/FollowingIndicator'
|
|
7
7
|
import { TldrawUiButton } from './components/primitives/Button/TldrawUiButton'
|
|
8
8
|
import { TldrawUiButtonIcon } from './components/primitives/Button/TldrawUiButtonIcon'
|
|
9
|
-
import { PORTRAIT_BREAKPOINT } from './constants'
|
|
9
|
+
import { PORTRAIT_BREAKPOINT, PORTRAIT_BREAKPOINTS } from './constants'
|
|
10
10
|
import {
|
|
11
11
|
TLUiContextProviderProps,
|
|
12
12
|
TldrawUiContextProvider,
|
|
@@ -160,6 +160,19 @@ const TldrawUiContent = React.memo(function TldrawUI() {
|
|
|
160
160
|
|
|
161
161
|
const { 'toggle-focus-mode': toggleFocus } = useActions()
|
|
162
162
|
|
|
163
|
+
const { breakpointsAbove, breakpointsBelow } = useMemo(() => {
|
|
164
|
+
const breakpointsAbove = []
|
|
165
|
+
const breakpointsBelow = []
|
|
166
|
+
for (let bp = 0; bp < PORTRAIT_BREAKPOINTS.length; bp++) {
|
|
167
|
+
if (bp <= breakpoint) {
|
|
168
|
+
breakpointsAbove.push(bp)
|
|
169
|
+
} else {
|
|
170
|
+
breakpointsBelow.push(bp)
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
return { breakpointsAbove, breakpointsBelow }
|
|
174
|
+
}, [breakpoint])
|
|
175
|
+
|
|
163
176
|
return (
|
|
164
177
|
<div
|
|
165
178
|
className={classNames('tlui-layout', {
|
|
@@ -169,6 +182,8 @@ const TldrawUiContent = React.memo(function TldrawUI() {
|
|
|
169
182
|
// But when the virtual keyboard is closing we want to wait a bit before showing it again.
|
|
170
183
|
data-iseditinganything={hideToolbarWhileEditing}
|
|
171
184
|
data-breakpoint={breakpoint}
|
|
185
|
+
data-breakpoints-above={breakpointsAbove.join(' ')}
|
|
186
|
+
data-breakpoints-below={breakpointsBelow.join(' ')}
|
|
172
187
|
>
|
|
173
188
|
<SkipToMainContent />
|
|
174
189
|
{isFocusMode ? (
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import {
|
|
2
|
+
ToggleKeyboardShortcutsItem,
|
|
3
|
+
ToggleReduceMotionItem,
|
|
4
|
+
ToggleUiLabelsItem,
|
|
5
|
+
} from './menu-items'
|
|
6
|
+
import { TldrawUiMenuGroup } from './primitives/menus/TldrawUiMenuGroup'
|
|
7
|
+
import { TldrawUiMenuSubmenu } from './primitives/menus/TldrawUiMenuSubmenu'
|
|
8
|
+
|
|
9
|
+
/** @public @react */
|
|
10
|
+
export function AccessibilityMenu() {
|
|
11
|
+
return (
|
|
12
|
+
<TldrawUiMenuSubmenu id="help menu accessibility" label="menu.accessibility">
|
|
13
|
+
<TldrawUiMenuGroup id="accessibility">
|
|
14
|
+
<ToggleReduceMotionItem />
|
|
15
|
+
<ToggleKeyboardShortcutsItem />
|
|
16
|
+
<ToggleUiLabelsItem />
|
|
17
|
+
</TldrawUiMenuGroup>
|
|
18
|
+
</TldrawUiMenuSubmenu>
|
|
19
|
+
)
|
|
20
|
+
}
|
|
@@ -11,6 +11,7 @@ import {
|
|
|
11
11
|
TldrawUiPopoverTrigger,
|
|
12
12
|
} from '../primitives/TldrawUiPopover'
|
|
13
13
|
import { TldrawUiToolbar, TldrawUiToolbarButton } from '../primitives/TldrawUiToolbar'
|
|
14
|
+
import { useTldrawUiOrientation } from '../primitives/layout'
|
|
14
15
|
import { TldrawUiMenuContextProvider } from '../primitives/menus/TldrawUiMenuContext'
|
|
15
16
|
import { DefaultActionsMenuContent } from './DefaultActionsMenuContent'
|
|
16
17
|
|
|
@@ -26,6 +27,7 @@ export const DefaultActionsMenu = memo(function DefaultActionsMenu({
|
|
|
26
27
|
const msg = useTranslation()
|
|
27
28
|
const breakpoint = useBreakpoint()
|
|
28
29
|
const isReadonlyMode = useReadonly()
|
|
30
|
+
const { orientation } = useTldrawUiOrientation()
|
|
29
31
|
|
|
30
32
|
const ref = useRef<HTMLDivElement>(null)
|
|
31
33
|
usePassThroughWheelEvents(ref)
|
|
@@ -52,18 +54,28 @@ export const DefaultActionsMenu = memo(function DefaultActionsMenu({
|
|
|
52
54
|
data-testid="actions-menu.button"
|
|
53
55
|
title={msg('actions-menu.title')}
|
|
54
56
|
>
|
|
55
|
-
<TldrawUiButtonIcon
|
|
57
|
+
<TldrawUiButtonIcon
|
|
58
|
+
icon={orientation === 'horizontal' ? 'dots-vertical' : 'dots-horizontal'}
|
|
59
|
+
small
|
|
60
|
+
/>
|
|
56
61
|
</TldrawUiToolbarButton>
|
|
57
62
|
</TldrawUiPopoverTrigger>
|
|
58
63
|
<TldrawUiPopoverContent
|
|
59
|
-
side={
|
|
64
|
+
side={
|
|
65
|
+
orientation === 'horizontal'
|
|
66
|
+
? breakpoint >= PORTRAIT_BREAKPOINT.TABLET
|
|
67
|
+
? 'bottom'
|
|
68
|
+
: 'top'
|
|
69
|
+
: 'right'
|
|
70
|
+
}
|
|
60
71
|
sideOffset={6}
|
|
61
72
|
>
|
|
62
73
|
<TldrawUiToolbar
|
|
63
74
|
ref={ref}
|
|
64
75
|
label={msg('actions-menu.title')}
|
|
65
|
-
className="tlui-actions-menu
|
|
76
|
+
className="tlui-actions-menu"
|
|
66
77
|
data-testid="actions-menu.content"
|
|
78
|
+
orientation="grid"
|
|
67
79
|
>
|
|
68
80
|
<TldrawUiMenuContextProvider type="icons" sourceId="actions-menu">
|
|
69
81
|
{content}
|
|
@@ -5,6 +5,7 @@ import { useBreakpoint } from '../context/breakpoints'
|
|
|
5
5
|
import { useTldrawUiComponents } from '../context/components'
|
|
6
6
|
import { useTranslation } from '../hooks/useTranslation/useTranslation'
|
|
7
7
|
import { TldrawUiToolbar } from './primitives/TldrawUiToolbar'
|
|
8
|
+
import { TldrawUiRow } from './primitives/layout'
|
|
8
9
|
|
|
9
10
|
/** @public @react */
|
|
10
11
|
export const DefaultMenuPanel = memo(function MenuPanel() {
|
|
@@ -32,16 +33,16 @@ export const DefaultMenuPanel = memo(function MenuPanel() {
|
|
|
32
33
|
|
|
33
34
|
return (
|
|
34
35
|
<nav ref={ref} className="tlui-menu-zone">
|
|
35
|
-
<
|
|
36
|
+
<TldrawUiRow>
|
|
36
37
|
{MainMenu && <MainMenu />}
|
|
37
38
|
{PageMenu && !isSinglePageMode && <PageMenu />}
|
|
38
39
|
{showQuickActions ? (
|
|
39
|
-
<TldrawUiToolbar
|
|
40
|
+
<TldrawUiToolbar orientation="horizontal" label={msg('actions-menu.title')}>
|
|
40
41
|
{QuickActions && <QuickActions />}
|
|
41
42
|
{ActionsMenu && <ActionsMenu />}
|
|
42
43
|
</TldrawUiToolbar>
|
|
43
44
|
) : null}
|
|
44
|
-
</
|
|
45
|
+
</TldrawUiRow>
|
|
45
46
|
</nav>
|
|
46
47
|
)
|
|
47
48
|
})
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { useCanRedo, useCanUndo } from '../../hooks/menu-hooks'
|
|
2
|
+
import { AccessibilityMenu } from '../AccessibilityMenu'
|
|
2
3
|
import { ColorSchemeMenu } from '../ColorSchemeMenu'
|
|
3
4
|
import { KeyboardShortcutsMenuItem } from '../HelpMenu/DefaultHelpMenuContent'
|
|
4
5
|
import { LanguageMenu } from '../LanguageMenu'
|
|
@@ -19,10 +20,8 @@ import {
|
|
|
19
20
|
ToggleEdgeScrollingItem,
|
|
20
21
|
ToggleFocusModeItem,
|
|
21
22
|
ToggleGridItem,
|
|
22
|
-
ToggleKeyboardShortcutsItem,
|
|
23
23
|
ToggleLockMenuItem,
|
|
24
24
|
TogglePasteAtCursorItem,
|
|
25
|
-
ToggleReduceMotionItem,
|
|
26
25
|
ToggleSnapModeItem,
|
|
27
26
|
ToggleToolLockItem,
|
|
28
27
|
ToggleTransparentBgMenuItem,
|
|
@@ -161,8 +160,6 @@ export function PreferencesGroup() {
|
|
|
161
160
|
<ToggleWrapModeItem />
|
|
162
161
|
<ToggleFocusModeItem />
|
|
163
162
|
<ToggleEdgeScrollingItem />
|
|
164
|
-
<ToggleReduceMotionItem />
|
|
165
|
-
<ToggleKeyboardShortcutsItem />
|
|
166
163
|
<ToggleDynamicSizeModeItem />
|
|
167
164
|
<TogglePasteAtCursorItem />
|
|
168
165
|
<ToggleDebugModeItem />
|
|
@@ -170,6 +167,9 @@ export function PreferencesGroup() {
|
|
|
170
167
|
<TldrawUiMenuGroup id="color-scheme">
|
|
171
168
|
<ColorSchemeMenu />
|
|
172
169
|
</TldrawUiMenuGroup>
|
|
170
|
+
<TldrawUiMenuGroup id="accessibility-menu">
|
|
171
|
+
<AccessibilityMenu />
|
|
172
|
+
</TldrawUiMenuGroup>
|
|
173
173
|
</TldrawUiMenuSubmenu>
|
|
174
174
|
<LanguageMenu />
|
|
175
175
|
<KeyboardShortcutsMenuItem />
|
|
@@ -46,10 +46,10 @@ export class MinimapManager {
|
|
|
46
46
|
const style = getComputedStyle(this.editor.getContainer())
|
|
47
47
|
|
|
48
48
|
return {
|
|
49
|
-
shapeFill: getRgba(style.getPropertyValue('--color-text-3').trim()),
|
|
50
|
-
selectFill: getRgba(style.getPropertyValue('--color-selected').trim()),
|
|
51
|
-
viewportFill: getRgba(style.getPropertyValue('--color-muted-1').trim()),
|
|
52
|
-
background: getRgba(style.getPropertyValue('--color-low').trim()),
|
|
49
|
+
shapeFill: getRgba(style.getPropertyValue('--tl-color-text-3').trim()),
|
|
50
|
+
selectFill: getRgba(style.getPropertyValue('--tl-color-selected').trim()),
|
|
51
|
+
viewportFill: getRgba(style.getPropertyValue('--tl-color-muted-1').trim()),
|
|
52
|
+
background: getRgba(style.getPropertyValue('--tl-color-low').trim()),
|
|
53
53
|
}
|
|
54
54
|
}
|
|
55
55
|
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import {
|
|
2
2
|
DefaultColorStyle,
|
|
3
3
|
TLDefaultColorStyle,
|
|
4
|
+
getColorValue,
|
|
4
5
|
getDefaultColorTheme,
|
|
5
6
|
useEditor,
|
|
6
7
|
useValue,
|
|
@@ -16,18 +17,20 @@ import {
|
|
|
16
17
|
TldrawUiPopoverContent,
|
|
17
18
|
TldrawUiPopoverTrigger,
|
|
18
19
|
} from './primitives/TldrawUiPopover'
|
|
20
|
+
import { useTldrawUiOrientation } from './primitives/layout'
|
|
19
21
|
|
|
20
22
|
/** @public @react */
|
|
21
23
|
export function MobileStylePanel() {
|
|
22
24
|
const editor = useEditor()
|
|
23
25
|
const msg = useTranslation()
|
|
24
|
-
|
|
26
|
+
const { orientation } = useTldrawUiOrientation()
|
|
25
27
|
const relevantStyles = useRelevantStyles()
|
|
26
28
|
const color = relevantStyles?.get(DefaultColorStyle)
|
|
27
29
|
const theme = getDefaultColorTheme({ isDarkMode: editor.user.getIsDarkMode() })
|
|
28
|
-
const currentColor =
|
|
29
|
-
color?.type === 'shared'
|
|
30
|
-
|
|
30
|
+
const currentColor =
|
|
31
|
+
color?.type === 'shared'
|
|
32
|
+
? getColorValue(theme, color.value as TLDefaultColorStyle, 'solid')
|
|
33
|
+
: getColorValue(theme, 'black', 'solid')
|
|
31
34
|
|
|
32
35
|
const disableStylePanel = useValue(
|
|
33
36
|
'disable style panel',
|
|
@@ -54,7 +57,7 @@ export function MobileStylePanel() {
|
|
|
54
57
|
type="tool"
|
|
55
58
|
data-testid="mobile-styles.button"
|
|
56
59
|
style={{
|
|
57
|
-
color: disableStylePanel ? 'var(--color-muted-1)' : currentColor,
|
|
60
|
+
color: disableStylePanel ? 'var(--tl-color-muted-1)' : currentColor,
|
|
58
61
|
}}
|
|
59
62
|
title={msg('style-panel.title')}
|
|
60
63
|
disabled={disableStylePanel}
|
|
@@ -64,7 +67,7 @@ export function MobileStylePanel() {
|
|
|
64
67
|
/>
|
|
65
68
|
</TldrawUiButton>
|
|
66
69
|
</TldrawUiPopoverTrigger>
|
|
67
|
-
<TldrawUiPopoverContent side=
|
|
70
|
+
<TldrawUiPopoverContent side={orientation === 'horizontal' ? 'top' : 'right'} align="end">
|
|
68
71
|
{StylePanel && <StylePanel isMobile />}
|
|
69
72
|
</TldrawUiPopoverContent>
|
|
70
73
|
</TldrawUiPopover>
|
|
@@ -33,7 +33,7 @@ export const DefaultNavigationPanel = memo(function DefaultNavigationPanel() {
|
|
|
33
33
|
|
|
34
34
|
return (
|
|
35
35
|
<div ref={ref} className="tlui-navigation-panel">
|
|
36
|
-
<TldrawUiToolbar
|
|
36
|
+
<TldrawUiToolbar orientation="horizontal" label={msg('navigation-zone.title')}>
|
|
37
37
|
{ZoomMenu && breakpoint < PORTRAIT_BREAKPOINT.TABLET ? (
|
|
38
38
|
<ZoomMenu />
|
|
39
39
|
) : (
|
|
@@ -24,6 +24,7 @@ import {
|
|
|
24
24
|
TldrawUiPopoverContent,
|
|
25
25
|
TldrawUiPopoverTrigger,
|
|
26
26
|
} from '../primitives/TldrawUiPopover'
|
|
27
|
+
import { TldrawUiRow } from '../primitives/layout'
|
|
27
28
|
import { PageItemInput } from './PageItemInput'
|
|
28
29
|
import { PageItemSubmenu } from './PageItemSubmenu'
|
|
29
30
|
import { onMovePage } from './edit-pages-shared'
|
|
@@ -329,7 +330,7 @@ export const DefaultPageMenu = memo(function DefaultPageMenu() {
|
|
|
329
330
|
<div className="tlui-page-menu__header">
|
|
330
331
|
<div className="tlui-page-menu__header__title">{msg('page-menu.title')}</div>
|
|
331
332
|
{!isReadonlyMode && (
|
|
332
|
-
<
|
|
333
|
+
<TldrawUiRow>
|
|
333
334
|
<TldrawUiButton
|
|
334
335
|
type="icon"
|
|
335
336
|
data-testid="page-menu.edit"
|
|
@@ -351,7 +352,7 @@ export const DefaultPageMenu = memo(function DefaultPageMenu() {
|
|
|
351
352
|
>
|
|
352
353
|
<TldrawUiButtonIcon icon="plus" />
|
|
353
354
|
</TldrawUiButton>
|
|
354
|
-
</
|
|
355
|
+
</TldrawUiRow>
|
|
355
356
|
)}
|
|
356
357
|
</div>
|
|
357
358
|
<div
|
|
@@ -5,6 +5,7 @@ import { useTranslation } from '../../hooks/useTranslation/useTranslation'
|
|
|
5
5
|
import { TldrawUiButton } from '../primitives/Button/TldrawUiButton'
|
|
6
6
|
import { TldrawUiButtonIcon } from '../primitives/Button/TldrawUiButtonIcon'
|
|
7
7
|
import { TldrawUiIcon } from '../primitives/TldrawUiIcon'
|
|
8
|
+
import { TldrawUiRow } from '../primitives/layout'
|
|
8
9
|
|
|
9
10
|
export const PeopleMenuItem = track(function PeopleMenuItem({ userId }: { userId: string }) {
|
|
10
11
|
const editor = useEditor()
|
|
@@ -29,8 +30,8 @@ export const PeopleMenuItem = track(function PeopleMenuItem({ userId }: { userId
|
|
|
29
30
|
if (!presence) return null
|
|
30
31
|
|
|
31
32
|
return (
|
|
32
|
-
<
|
|
33
|
-
className="tlui-people-menu__item
|
|
33
|
+
<TldrawUiRow
|
|
34
|
+
className="tlui-people-menu__item"
|
|
34
35
|
data-follow={youAreFollowingThem || theyAreFollowingYou}
|
|
35
36
|
>
|
|
36
37
|
<TldrawUiButton
|
|
@@ -61,6 +62,6 @@ export const PeopleMenuItem = track(function PeopleMenuItem({ userId }: { userId
|
|
|
61
62
|
icon={theyAreFollowingYou ? 'leading' : youAreFollowingThem ? 'following' : 'follow'}
|
|
62
63
|
/>
|
|
63
64
|
</TldrawUiButton>
|
|
64
|
-
</
|
|
65
|
+
</TldrawUiRow>
|
|
65
66
|
)
|
|
66
67
|
})
|