diff --git a/src/actions/actionFinalize.tsx b/src/actions/actionFinalize.tsx index fae31eb2..c9615f8a 100644 --- a/src/actions/actionFinalize.tsx +++ b/src/actions/actionFinalize.tsx @@ -2,6 +2,7 @@ import { Action } from "./types"; import { KEYS } from "../keys"; import { clearSelection } from "../scene"; import { isInvisiblySmallElement } from "../element"; +import { resetCursor } from "../utils"; export const actionFinalize: Action = { name: "finalize", @@ -20,11 +21,17 @@ export const actionFinalize: Action = { } appState.multiElement.shape = null; } + if (!appState.elementLocked || !appState.multiElement) { + resetCursor(); + } return { elements: newElements, appState: { ...appState, - elementType: "selection", + elementType: + appState.elementLocked && appState.multiElement + ? appState.elementType + : "selection", draggingElement: null, multiElement: null, }, diff --git a/src/index.tsx b/src/index.tsx index a3f78756..19133e38 100644 --- a/src/index.tsx +++ b/src/index.tsx @@ -48,6 +48,7 @@ import { capitalizeString, distance, distance2d, + resetCursor, } from "./utils"; import { KEYS, isArrowKey } from "./keys"; @@ -102,10 +103,6 @@ import { copyToAppClipboard, getClipboardContent } from "./clipboard"; let { elements } = createScene(); const { history } = createHistory(); -function resetCursor() { - document.documentElement.style.cursor = ""; -} - function setCursorForShape(shape: string) { if (shape === "selection") { resetCursor(); @@ -1014,6 +1011,12 @@ export class App extends React.Component { } if (isTextElement(element)) { + // if we're currently still editing text, clicking outside + // should only finalize it, not create another (irrespective + // of state.elementLocked) + if (this.state.editingElement?.type === "text") { + return; + } let textX = e.clientX; let textY = e.clientY; if (!e.altKey) { @@ -1033,7 +1036,6 @@ export class App extends React.Component { this.setState({ draggingElement: null, editingElement: null, - elementType: "selection", }); }; @@ -1058,6 +1060,9 @@ export class App extends React.Component { }, ]; } + if (this.state.elementLocked) { + setCursorForShape(this.state.elementType); + } history.resumeRecording(); resetSelection(); }, @@ -1065,10 +1070,17 @@ export class App extends React.Component { resetSelection(); }, }); - this.setState({ - elementType: "selection", - editingElement: element, - }); + resetCursor(); + if (!this.state.elementLocked) { + this.setState({ + editingElement: element, + elementType: "selection", + }); + } else { + this.setState({ + editingElement: element, + }); + } return; } else if ( this.state.elementType === "arrow" || @@ -1563,10 +1575,17 @@ export class App extends React.Component { this.setState({ multiElement: this.state.draggingElement }); } else if (draggingOccurred && !multiElement) { this.state.draggingElement!.isSelected = true; - this.setState({ - draggingElement: null, - elementType: "selection", - }); + if (!elementLocked) { + resetCursor(); + this.setState({ + draggingElement: null, + elementType: "selection", + }); + } else { + this.setState({ + draggingElement: null, + }); + } } return; } @@ -1660,6 +1679,8 @@ export class App extends React.Component { window.addEventListener("mouseup", onMouseUp); }} onDoubleClick={e => { + resetCursor(); + const { x, y } = viewportCoordsToSceneCoords(e, this.state); const elementAtPosition = getElementAtPosition(elements, x, y); @@ -1724,7 +1745,6 @@ export class App extends React.Component { this.setState({ draggingElement: null, editingElement: null, - elementType: "selection", }); }; diff --git a/src/utils.ts b/src/utils.ts index 1470f364..842be25f 100644 --- a/src/utils.ts +++ b/src/utils.ts @@ -126,3 +126,7 @@ export function distance2d(x1: number, y1: number, x2: number, y2: number) { const yd = y2 - y1; return Math.sqrt(xd * xd + yd * yd); } + +export function resetCursor() { + document.documentElement.style.cursor = ""; +}