@tldraw/editor
Version:
tldraw infinite canvas SDK (editor).
159 lines (158 loc) • 5.94 kB
JavaScript
;
var __defProp = Object.defineProperty;
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
var __getOwnPropNames = Object.getOwnPropertyNames;
var __hasOwnProp = Object.prototype.hasOwnProperty;
var __export = (target, all) => {
for (var name in all)
__defProp(target, name, { get: all[name], enumerable: true });
};
var __copyProps = (to, from, except, desc) => {
if (from && typeof from === "object" || typeof from === "function") {
for (let key of __getOwnPropNames(from))
if (!__hasOwnProp.call(to, key) && key !== except)
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
}
return to;
};
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
var useCanvasEvents_exports = {};
__export(useCanvasEvents_exports, {
useCanvasEvents: () => useCanvasEvents
});
module.exports = __toCommonJS(useCanvasEvents_exports);
var import_state_react = require("@tldraw/state-react");
var import_react = require("react");
var import_constants = require("../constants");
var import_dom = require("../utils/dom");
var import_getPointerInfo = require("../utils/getPointerInfo");
var import_useEditor = require("./useEditor");
function useCanvasEvents() {
const editor = (0, import_useEditor.useEditor)();
const currentTool = (0, import_state_react.useValue)("current tool", () => editor.getCurrentTool(), [editor]);
const events = (0, import_react.useMemo)(
function canvasEvents() {
let lastX, lastY;
function onPointerDown(e) {
if (e.isKilled) return;
if (e.button === import_constants.RIGHT_MOUSE_BUTTON) {
editor.dispatch({
type: "pointer",
target: "canvas",
name: "right_click",
...(0, import_getPointerInfo.getPointerInfo)(e)
});
return;
}
if (e.button !== 0 && e.button !== 1 && e.button !== 5) return;
(0, import_dom.setPointerCapture)(e.currentTarget, e);
editor.dispatch({
type: "pointer",
target: "canvas",
name: "pointer_down",
...(0, import_getPointerInfo.getPointerInfo)(e)
});
}
function onPointerMove(e) {
if (e.isKilled) return;
if (e.clientX === lastX && e.clientY === lastY) return;
lastX = e.clientX;
lastY = e.clientY;
const events2 = currentTool.useCoalescedEvents && e.nativeEvent.getCoalescedEvents ? e.nativeEvent.getCoalescedEvents() : [e];
for (const singleEvent of events2) {
editor.dispatch({
type: "pointer",
target: "canvas",
name: "pointer_move",
...(0, import_getPointerInfo.getPointerInfo)(singleEvent)
});
}
}
function onPointerUp(e) {
if (e.isKilled) return;
if (e.button !== 0 && e.button !== 1 && e.button !== 2 && e.button !== 5) return;
lastX = e.clientX;
lastY = e.clientY;
(0, import_dom.releasePointerCapture)(e.currentTarget, e);
editor.dispatch({
type: "pointer",
target: "canvas",
name: "pointer_up",
...(0, import_getPointerInfo.getPointerInfo)(e)
});
}
function onPointerEnter(e) {
if (e.isKilled) return;
if (editor.getInstanceState().isPenMode && e.pointerType !== "pen") return;
const canHover = e.pointerType === "mouse" || e.pointerType === "pen";
editor.updateInstanceState({ isHoveringCanvas: canHover ? true : null });
}
function onPointerLeave(e) {
if (e.isKilled) return;
if (editor.getInstanceState().isPenMode && e.pointerType !== "pen") return;
const canHover = e.pointerType === "mouse" || e.pointerType === "pen";
editor.updateInstanceState({ isHoveringCanvas: canHover ? false : null });
}
function onTouchStart(e) {
;
e.isKilled = true;
(0, import_dom.preventDefault)(e);
}
function onTouchEnd(e) {
;
e.isKilled = true;
if (!(e.target instanceof HTMLElement)) return;
if (e.target.tagName !== "A" && e.target.tagName !== "TEXTAREA" && !e.target.isContentEditable && // When in EditingShape state, we are actually clicking on a 'DIV'
// not A/TEXTAREA/contenteditable element yet. So, to preserve cursor position
// for edit mode on mobile we need to not preventDefault.
// TODO: Find out if we still need this preventDefault in general though.
!(editor.getEditingShape() && e.target.className.includes("tl-text-content"))) {
(0, import_dom.preventDefault)(e);
}
}
function onDragOver(e) {
(0, import_dom.preventDefault)(e);
}
async function onDrop(e) {
(0, import_dom.preventDefault)(e);
(0, import_dom.stopEventPropagation)(e);
if (e.dataTransfer?.files?.length) {
const files = Array.from(e.dataTransfer.files);
await editor.putExternalContent({
type: "files",
files,
point: editor.screenToPage({ x: e.clientX, y: e.clientY })
});
return;
}
const url = e.dataTransfer.getData("url");
if (url) {
await editor.putExternalContent({
type: "url",
url,
point: editor.screenToPage({ x: e.clientX, y: e.clientY })
});
return;
}
}
function onClick(e) {
(0, import_dom.stopEventPropagation)(e);
}
return {
onPointerDown,
onPointerMove,
onPointerUp,
onPointerEnter,
onPointerLeave,
onDragOver,
onDrop,
onTouchStart,
onTouchEnd,
onClick
};
},
[editor, currentTool]
);
return events;
}
//# sourceMappingURL=useCanvasEvents.js.map