tldraw 4.1.0-canary.e2133d922c9e → 4.1.0-canary.e259b517a450
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 +37 -2
- package/dist-cjs/index.js +3 -1
- package/dist-cjs/index.js.map +2 -2
- package/dist-cjs/lib/canvas/TldrawCropHandles.js +1 -1
- package/dist-cjs/lib/canvas/TldrawScribble.js +1 -1
- package/dist-cjs/lib/canvas/TldrawSelectionForeground.js +1 -1
- package/dist-cjs/lib/defaultEmbedDefinitions.js +26 -7
- package/dist-cjs/lib/defaultEmbedDefinitions.js.map +2 -2
- package/dist-cjs/lib/defaultExternalContentHandlers.js +9 -32
- package/dist-cjs/lib/defaultExternalContentHandlers.js.map +2 -2
- package/dist-cjs/lib/shapes/arrow/ArrowShapeUtil.js +3 -0
- package/dist-cjs/lib/shapes/arrow/ArrowShapeUtil.js.map +2 -2
- package/dist-cjs/lib/shapes/bookmark/BookmarkShapeUtil.js +22 -84
- package/dist-cjs/lib/shapes/bookmark/BookmarkShapeUtil.js.map +2 -2
- package/dist-cjs/lib/shapes/bookmark/bookmarks.js +137 -0
- package/dist-cjs/lib/shapes/bookmark/bookmarks.js.map +7 -0
- package/dist-cjs/lib/shapes/frame/FrameShapeUtil.js +1 -1
- package/dist-cjs/lib/shapes/image/ImageShapeUtil.js +1 -1
- package/dist-cjs/lib/shapes/line/LineShapeUtil.js +3 -0
- package/dist-cjs/lib/shapes/line/LineShapeUtil.js.map +2 -2
- package/dist-cjs/lib/shapes/shared/HyperlinkButton.js +1 -1
- package/dist-cjs/lib/shapes/shared/PlainTextLabel.js +1 -1
- package/dist-cjs/lib/shapes/shared/RichTextLabel.js +1 -1
- package/dist-cjs/lib/shapes/shared/ShapeFill.js +1 -1
- package/dist-cjs/lib/shapes/text/PlainTextArea.js +1 -1
- package/dist-cjs/lib/shapes/text/RichTextArea.js +1 -1
- package/dist-cjs/lib/shapes/video/VideoShapeUtil.js +1 -1
- package/dist-cjs/lib/tools/SelectTool/childStates/Crop/children/Idle.js +1 -1
- package/dist-cjs/lib/tools/SelectTool/childStates/Crop/children/Idle.js.map +2 -2
- package/dist-cjs/lib/tools/SelectTool/childStates/DraggingHandle.js +9 -1
- package/dist-cjs/lib/tools/SelectTool/childStates/DraggingHandle.js.map +2 -2
- package/dist-cjs/lib/tools/SelectTool/childStates/Idle.js +1 -1
- package/dist-cjs/lib/tools/SelectTool/childStates/Idle.js.map +2 -2
- package/dist-cjs/lib/ui/TldrawUi.js +2 -2
- package/dist-cjs/lib/ui/components/DebugMenu/DefaultDebugMenuContent.js +1 -1
- package/dist-cjs/lib/ui/components/KeyboardShortcutsDialog/DefaultKeyboardShortcutsDialog.js +1 -1
- package/dist-cjs/lib/ui/components/Minimap/DefaultMinimap.js +1 -1
- package/dist-cjs/lib/ui/components/Minimap/MinimapManager.js +5 -0
- package/dist-cjs/lib/ui/components/Minimap/MinimapManager.js.map +2 -2
- package/dist-cjs/lib/ui/components/OfflineIndicator/OfflineIndicator.js +1 -1
- package/dist-cjs/lib/ui/components/SharePanel/PeopleMenu.js +6 -2
- package/dist-cjs/lib/ui/components/SharePanel/PeopleMenu.js.map +2 -2
- package/dist-cjs/lib/ui/components/SharePanel/UserPresenceColorPicker.js +1 -1
- package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanel.js +1 -1
- package/dist-cjs/lib/ui/components/StylePanel/DefaultStylePanelContent.js +1 -1
- package/dist-cjs/lib/ui/components/StylePanel/StylePanelButtonPicker.js +1 -1
- package/dist-cjs/lib/ui/components/StylePanel/StylePanelButtonPicker.js.map +1 -1
- package/dist-cjs/lib/ui/components/StylePanel/StylePanelDoubleDropdownPicker.js +1 -1
- package/dist-cjs/lib/ui/components/StylePanel/StylePanelDropdownPicker.js +1 -1
- package/dist-cjs/lib/ui/components/Toolbar/DefaultToolbar.js +1 -1
- package/dist-cjs/lib/ui/components/Toolbar/OverflowingToolbar.js +1 -1
- package/dist-cjs/lib/ui/components/Toolbar/ToggleToolLockedButton.js +1 -1
- package/dist-cjs/lib/ui/components/primitives/Button/TldrawUiButton.js +2 -2
- package/dist-cjs/lib/ui/components/primitives/TldrawUiContextualToolbar.js +1 -1
- package/dist-cjs/lib/ui/components/primitives/TldrawUiDialog.js +1 -1
- package/dist-cjs/lib/ui/components/primitives/TldrawUiDropdownMenu.js +1 -1
- package/dist-cjs/lib/ui/components/primitives/TldrawUiIcon.js +1 -1
- package/dist-cjs/lib/ui/components/primitives/TldrawUiInput.js +2 -2
- package/dist-cjs/lib/ui/components/primitives/TldrawUiPopover.js +2 -2
- package/dist-cjs/lib/ui/components/primitives/TldrawUiSlider.js +1 -1
- package/dist-cjs/lib/ui/components/primitives/TldrawUiToolbar.js +2 -2
- package/dist-cjs/lib/ui/components/primitives/TldrawUiTooltip.js +1 -1
- package/dist-cjs/lib/ui/components/primitives/layout.js +1 -1
- package/dist-cjs/lib/ui/components/primitives/menus/TldrawUiMenuGroup.js +1 -1
- package/dist-cjs/lib/ui/context/actions.js +24 -30
- package/dist-cjs/lib/ui/context/actions.js.map +2 -2
- package/dist-cjs/lib/ui/context/breakpoints.js +1 -1
- package/dist-cjs/lib/ui/context/events.js +1 -1
- package/dist-cjs/lib/ui/hooks/useClipboardEvents.js +1 -1
- package/dist-cjs/lib/ui/hooks/useKeyboardShortcuts.js +1 -1
- package/dist-cjs/lib/ui/hooks/useLocalStorageState.js +1 -1
- package/dist-cjs/lib/ui/hooks/useTools.js +1 -1
- package/dist-cjs/lib/ui/hooks/useTranslation/useTranslation.js +1 -1
- package/dist-cjs/lib/ui/version.js +3 -3
- package/dist-cjs/lib/ui/version.js.map +1 -1
- package/dist-cjs/lib/utils/text/richText.js +4 -4
- package/dist-esm/index.d.mts +37 -2
- package/dist-esm/index.mjs +3 -1
- package/dist-esm/index.mjs.map +2 -2
- package/dist-esm/lib/defaultEmbedDefinitions.mjs +26 -7
- package/dist-esm/lib/defaultEmbedDefinitions.mjs.map +2 -2
- package/dist-esm/lib/defaultExternalContentHandlers.mjs +9 -32
- package/dist-esm/lib/defaultExternalContentHandlers.mjs.map +2 -2
- package/dist-esm/lib/shapes/arrow/ArrowShapeUtil.mjs +3 -0
- package/dist-esm/lib/shapes/arrow/ArrowShapeUtil.mjs.map +2 -2
- package/dist-esm/lib/shapes/bookmark/BookmarkShapeUtil.mjs +23 -82
- package/dist-esm/lib/shapes/bookmark/BookmarkShapeUtil.mjs.map +2 -2
- package/dist-esm/lib/shapes/bookmark/bookmarks.mjs +123 -0
- package/dist-esm/lib/shapes/bookmark/bookmarks.mjs.map +7 -0
- package/dist-esm/lib/shapes/line/LineShapeUtil.mjs +3 -0
- package/dist-esm/lib/shapes/line/LineShapeUtil.mjs.map +2 -2
- package/dist-esm/lib/tools/SelectTool/childStates/Crop/children/Idle.mjs +1 -1
- package/dist-esm/lib/tools/SelectTool/childStates/Crop/children/Idle.mjs.map +2 -2
- package/dist-esm/lib/tools/SelectTool/childStates/DraggingHandle.mjs +11 -2
- package/dist-esm/lib/tools/SelectTool/childStates/DraggingHandle.mjs.map +2 -2
- package/dist-esm/lib/tools/SelectTool/childStates/Idle.mjs +1 -1
- package/dist-esm/lib/tools/SelectTool/childStates/Idle.mjs.map +2 -2
- package/dist-esm/lib/ui/components/Minimap/MinimapManager.mjs +5 -0
- package/dist-esm/lib/ui/components/Minimap/MinimapManager.mjs.map +2 -2
- package/dist-esm/lib/ui/components/SharePanel/PeopleMenu.mjs +6 -2
- package/dist-esm/lib/ui/components/SharePanel/PeopleMenu.mjs.map +2 -2
- package/dist-esm/lib/ui/components/StylePanel/StylePanelButtonPicker.mjs +1 -1
- package/dist-esm/lib/ui/components/StylePanel/StylePanelButtonPicker.mjs.map +1 -1
- package/dist-esm/lib/ui/context/actions.mjs +23 -29
- package/dist-esm/lib/ui/context/actions.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 +11 -11
- package/src/index.ts +1 -0
- package/src/lib/defaultEmbedDefinitions.ts +21 -1
- package/src/lib/defaultExternalContentHandlers.ts +11 -36
- package/src/lib/shapes/arrow/ArrowShapeUtil.tsx +3 -0
- package/src/lib/shapes/bookmark/BookmarkShapeUtil.tsx +22 -115
- package/src/lib/shapes/bookmark/bookmarks.ts +170 -0
- package/src/lib/shapes/line/LineShapeUtil.tsx +3 -0
- package/src/lib/shapes/text/TextShapeTool.test.ts +74 -0
- package/src/lib/tools/SelectTool/childStates/Crop/children/Idle.ts +1 -1
- package/src/lib/tools/SelectTool/childStates/DraggingHandle.tsx +13 -1
- package/src/lib/tools/SelectTool/childStates/Idle.ts +1 -1
- package/src/lib/ui/components/Minimap/MinimapManager.ts +6 -0
- package/src/lib/ui/components/SharePanel/PeopleMenu.tsx +6 -2
- package/src/lib/ui/components/StylePanel/StylePanelButtonPicker.tsx +1 -1
- package/src/lib/ui/context/actions.tsx +27 -31
- package/src/lib/ui/version.ts +3 -3
- package/src/lib/utils/embeds/embeds.test.ts +16 -0
- package/src/test/bookmark-shapes.test.ts +123 -1
- package/src/test/customSnapping.test.tsx +55 -11
- package/tldraw.css +7 -2
|
@@ -33,8 +33,8 @@ __export(TldrawUiInput_exports, {
|
|
|
33
33
|
module.exports = __toCommonJS(TldrawUiInput_exports);
|
|
34
34
|
var import_jsx_runtime = require("react/jsx-runtime");
|
|
35
35
|
var import_editor = require("@tldraw/editor");
|
|
36
|
-
var import_classnames = __toESM(require("classnames"));
|
|
37
|
-
var React = __toESM(require("react"));
|
|
36
|
+
var import_classnames = __toESM(require("classnames"), 1);
|
|
37
|
+
var React = __toESM(require("react"), 1);
|
|
38
38
|
var import_useTranslation = require("../../hooks/useTranslation/useTranslation");
|
|
39
39
|
var import_TldrawUiIcon = require("./TldrawUiIcon");
|
|
40
40
|
const TldrawUiInput = React.forwardRef(
|
|
@@ -35,9 +35,9 @@ __export(TldrawUiPopover_exports, {
|
|
|
35
35
|
module.exports = __toCommonJS(TldrawUiPopover_exports);
|
|
36
36
|
var import_jsx_runtime = require("react/jsx-runtime");
|
|
37
37
|
var import_editor = require("@tldraw/editor");
|
|
38
|
-
var import_classnames = __toESM(require("classnames"));
|
|
38
|
+
var import_classnames = __toESM(require("classnames"), 1);
|
|
39
39
|
var import_radix_ui = require("radix-ui");
|
|
40
|
-
var import_react = __toESM(require("react"));
|
|
40
|
+
var import_react = __toESM(require("react"), 1);
|
|
41
41
|
var import_useMenuIsOpen = require("../../hooks/useMenuIsOpen");
|
|
42
42
|
function TldrawUiPopover({ id, children, onOpenChange, open, className }) {
|
|
43
43
|
const [isOpen, handleOpenChange] = (0, import_useMenuIsOpen.useMenuIsOpen)(id, onOpenChange);
|
|
@@ -34,7 +34,7 @@ module.exports = __toCommonJS(TldrawUiSlider_exports);
|
|
|
34
34
|
var import_jsx_runtime = require("react/jsx-runtime");
|
|
35
35
|
var import_editor = require("@tldraw/editor");
|
|
36
36
|
var import_radix_ui = require("radix-ui");
|
|
37
|
-
var import_react = __toESM(require("react"));
|
|
37
|
+
var import_react = __toESM(require("react"), 1);
|
|
38
38
|
var import_useTranslation = require("../../hooks/useTranslation/useTranslation");
|
|
39
39
|
var import_TldrawUiTooltip = require("./TldrawUiTooltip");
|
|
40
40
|
const TldrawUiSlider = import_react.default.forwardRef(function Slider({
|
|
@@ -35,9 +35,9 @@ __export(TldrawUiToolbar_exports, {
|
|
|
35
35
|
});
|
|
36
36
|
module.exports = __toCommonJS(TldrawUiToolbar_exports);
|
|
37
37
|
var import_jsx_runtime = require("react/jsx-runtime");
|
|
38
|
-
var import_classnames = __toESM(require("classnames"));
|
|
38
|
+
var import_classnames = __toESM(require("classnames"), 1);
|
|
39
39
|
var import_radix_ui = require("radix-ui");
|
|
40
|
-
var import_react = __toESM(require("react"));
|
|
40
|
+
var import_react = __toESM(require("react"), 1);
|
|
41
41
|
var import_layout = require("./layout");
|
|
42
42
|
var import_TldrawUiTooltip = require("./TldrawUiTooltip");
|
|
43
43
|
const LayoutByOrientation = {
|
|
@@ -36,7 +36,7 @@ module.exports = __toCommonJS(TldrawUiTooltip_exports);
|
|
|
36
36
|
var import_jsx_runtime = require("react/jsx-runtime");
|
|
37
37
|
var import_editor = require("@tldraw/editor");
|
|
38
38
|
var import_radix_ui = require("radix-ui");
|
|
39
|
-
var import_react = __toESM(require("react"));
|
|
39
|
+
var import_react = __toESM(require("react"), 1);
|
|
40
40
|
var import_layout = require("./layout");
|
|
41
41
|
const DEFAULT_TOOLTIP_DELAY_MS = 700;
|
|
42
42
|
class TooltipManager {
|
|
@@ -36,7 +36,7 @@ __export(layout_exports, {
|
|
|
36
36
|
});
|
|
37
37
|
module.exports = __toCommonJS(layout_exports);
|
|
38
38
|
var import_jsx_runtime = require("react/jsx-runtime");
|
|
39
|
-
var import_classnames = __toESM(require("classnames"));
|
|
39
|
+
var import_classnames = __toESM(require("classnames"), 1);
|
|
40
40
|
var import_radix_ui = require("radix-ui");
|
|
41
41
|
var import_react = require("react");
|
|
42
42
|
const TldrawUiOrientationContext = (0, import_react.createContext)({
|
|
@@ -32,7 +32,7 @@ __export(TldrawUiMenuGroup_exports, {
|
|
|
32
32
|
});
|
|
33
33
|
module.exports = __toCommonJS(TldrawUiMenuGroup_exports);
|
|
34
34
|
var import_jsx_runtime = require("react/jsx-runtime");
|
|
35
|
-
var import_classnames = __toESM(require("classnames"));
|
|
35
|
+
var import_classnames = __toESM(require("classnames"), 1);
|
|
36
36
|
var import_actions = require("../../../context/actions");
|
|
37
37
|
var import_useTranslation = require("../../../hooks/useTranslation/useTranslation");
|
|
38
38
|
var import_layout = require("../layout");
|
|
@@ -37,7 +37,8 @@ __export(actions_exports, {
|
|
|
37
37
|
module.exports = __toCommonJS(actions_exports);
|
|
38
38
|
var import_jsx_runtime = require("react/jsx-runtime");
|
|
39
39
|
var import_editor = require("@tldraw/editor");
|
|
40
|
-
var React = __toESM(require("react"));
|
|
40
|
+
var React = __toESM(require("react"), 1);
|
|
41
|
+
var import_bookmarks = require("../../shapes/bookmark/bookmarks");
|
|
41
42
|
var import_frames = require("../../utils/frames/frames");
|
|
42
43
|
var import_A11y = require("../components/A11y");
|
|
43
44
|
var import_EditLinkDialog = require("../components/EditLinkDialog");
|
|
@@ -333,38 +334,31 @@ function ActionsProvider({ overrides, children }) {
|
|
|
333
334
|
{
|
|
334
335
|
id: "convert-to-bookmark",
|
|
335
336
|
label: "action.convert-to-bookmark",
|
|
336
|
-
onSelect(source) {
|
|
337
|
+
async onSelect(source) {
|
|
337
338
|
if (!canApplySelectionAction()) return;
|
|
338
339
|
if (mustGoBackToSelectToolFirst()) return;
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
type: "bookmark",
|
|
354
|
-
rotation: shape.rotation,
|
|
355
|
-
x: newPos.x,
|
|
356
|
-
y: newPos.y,
|
|
357
|
-
opacity: 1,
|
|
358
|
-
props: {
|
|
359
|
-
url: shape.props.url
|
|
340
|
+
trackEvent("convert-to-bookmark", { source });
|
|
341
|
+
const shapes = editor.getSelectedShapes();
|
|
342
|
+
const markId = editor.markHistoryStoppingPoint("convert shapes to bookmark");
|
|
343
|
+
const creationPromises = [];
|
|
344
|
+
for (const shape of shapes) {
|
|
345
|
+
if (!shape || !editor.isShapeOfType(shape, "embed") || !shape.props.url)
|
|
346
|
+
continue;
|
|
347
|
+
const center = editor.getShapePageBounds(shape)?.center;
|
|
348
|
+
if (!center) continue;
|
|
349
|
+
editor.deleteShapes([shape.id]);
|
|
350
|
+
creationPromises.push(
|
|
351
|
+
(0, import_bookmarks.createBookmarkFromUrl)(editor, { url: shape.props.url, center }).then((res) => {
|
|
352
|
+
if (!res.ok) {
|
|
353
|
+
throw new Error(res.error);
|
|
360
354
|
}
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
editor.
|
|
367
|
-
|
|
355
|
+
return res;
|
|
356
|
+
})
|
|
357
|
+
);
|
|
358
|
+
}
|
|
359
|
+
await Promise.all(creationPromises).catch((error) => {
|
|
360
|
+
editor.bailToMark(markId);
|
|
361
|
+
console.error(error);
|
|
368
362
|
});
|
|
369
363
|
}
|
|
370
364
|
},
|