From 5d295415db00b68a5c86aac7d93bb4bf2d3b8f55 Mon Sep 17 00:00:00 2001 From: Lipis Date: Thu, 5 Nov 2020 19:06:18 +0200 Subject: [PATCH] Keep errors, elements and comments consistent (#2340) Co-authored-by: David Luzar --- .lintstagedrc.js | 2 +- src/actions/actionProperties.tsx | 2 +- src/clipboard.ts | 14 +++---- src/components/App.tsx | 64 +++++++++++++++--------------- src/components/Portal.tsx | 3 +- src/data/blob.ts | 3 +- src/data/firebase.ts | 4 +- src/data/library.ts | 12 +++--- src/data/restore.ts | 12 +++--- src/element/linearElementEditor.ts | 16 ++++---- src/element/newElement.ts | 2 +- src/element/textWysiwyg.tsx | 8 ++-- src/renderer/renderElement.ts | 10 ++--- src/renderer/renderScene.ts | 2 +- src/scene/Scene.ts | 2 +- src/serviceWorker.tsx | 18 ++++----- src/tests/binding.test.tsx | 2 +- src/tests/export.test.tsx | 2 +- src/tests/regressionTests.test.tsx | 8 ++-- src/types.ts | 2 +- src/utils.ts | 2 +- src/zindex.ts | 4 +- 22 files changed, 96 insertions(+), 98 deletions(-) diff --git a/.lintstagedrc.js b/.lintstagedrc.js index 9de68ddf..612d4c39 100644 --- a/.lintstagedrc.js +++ b/.lintstagedrc.js @@ -1,7 +1,7 @@ const { CLIEngine } = require("eslint"); // see https://github.com/okonet/lint-staged#how-can-i-ignore-files-from-eslintignore- -// for explanation +// for explanation const cli = new CLIEngine({}); module.exports = { diff --git a/src/actions/actionProperties.tsx b/src/actions/actionProperties.tsx index c2834101..fcce6d14 100644 --- a/src/actions/actionProperties.tsx +++ b/src/actions/actionProperties.tsx @@ -540,7 +540,7 @@ export const actionChangeSharpness = register({ appState, ); const shouldUpdateForNonLinearElements = targetElements.length - ? targetElements.every((e) => !isLinearElement(e)) + ? targetElements.every((el) => !isLinearElement(el)) : !isLinearElementType(appState.elementType); const shouldUpdateForLinearElements = targetElements.length ? targetElements.every(isLinearElement) diff --git a/src/clipboard.ts b/src/clipboard.ts index 625b9f1f..7f4d7a2e 100644 --- a/src/clipboard.ts +++ b/src/clipboard.ts @@ -57,9 +57,9 @@ export const copyToClipboard = async ( try { PREFER_APP_CLIPBOARD = false; await copyTextToSystemClipboard(json); - } catch (err) { + } catch (error) { PREFER_APP_CLIPBOARD = true; - console.error(err); + console.error(error); } }; @@ -128,7 +128,7 @@ export const parseClipboard = async ( } // if system clipboard contains spreadsheet, use it even though it's - // technically possible it's staler than in-app clipboard + // technically possible it's staler than in-app clipboard const spreadsheetResult = parsePotentialSpreadsheet(systemClipboard); if (spreadsheetResult) { return spreadsheetResult; @@ -150,8 +150,8 @@ export const parseClipboard = async ( return appClipboardData; } catch { // system clipboard doesn't contain excalidraw elements → return plaintext - // unless we set a flag to prefer in-app clipboard because browser didn't - // support storing to system clipboard on copy + // unless we set a flag to prefer in-app clipboard because browser didn't + // support storing to system clipboard on copy return PREFER_APP_CLIPBOARD && appClipboardData.elements ? appClipboardData : { text: systemClipboard }; @@ -170,7 +170,7 @@ export const copyTextToSystemClipboard = async (text: string | null) => { if (probablySupportsClipboardWriteText) { try { // NOTE: doesn't work on FF on non-HTTPS domains, or when document - // not focused + // not focused await navigator.clipboard.writeText(text || ""); copied = true; } catch (error) { @@ -179,7 +179,7 @@ export const copyTextToSystemClipboard = async (text: string | null) => { } // Note that execCommand doesn't allow copying empty strings, so if we're - // clearing clipboard using this API, we must copy at least an empty char + // clearing clipboard using this API, we must copy at least an empty char if (!copied && !copyTextViaExecCommand(text || " ")) { throw new Error("couldn't copy"); } diff --git a/src/components/App.tsx b/src/components/App.tsx index 05325ff0..0b2c3180 100644 --- a/src/components/App.tsx +++ b/src/components/App.tsx @@ -523,7 +523,7 @@ class App extends React.Component { collabForceLoadFlag, ); // if loading same room as the one previously unloaded within 15sec - // force reload without prompting + // force reload without prompting if (previousRoom === roomID && Date.now() - timestamp < 15000) { return true; } @@ -561,8 +561,8 @@ class App extends React.Component { history.clear(); }; - /** Completely resets scene & history. - * Do not use for clear scene user action. */ + // Completely resets scene & history. + // Do not use for clear scene user action. private resetScene = withBatchedUpdates(() => { this.scene.replaceAllElements([]); this.setState({ @@ -654,7 +654,7 @@ class App extends React.Component { if (isCollaborationScene) { // when joining a room we don't want user's local scene data to be merged - // into the remote scene + // into the remote scene this.resetScene(); this.initializeSocketClient({ showLoadingState: true }); @@ -847,7 +847,7 @@ class App extends React.Component { !isSavedToFirebase(this.portal, syncableElements) ) { // this won't run in time if user decides to leave the site, but - // the purpose is to run in immediately after user decides to stay + // the purpose is to run in immediately after user decides to stay this.saveCollabRoomToFirebase(syncableElements); event.preventDefault(); @@ -943,7 +943,7 @@ class App extends React.Component { const { atLeastOneVisibleElement, scrollBars } = renderScene( elements.filter((element) => { // don't render text element that's being currently edited (it's - // rendered on remote only) + // rendered on remote only) return ( !this.state.editingElement || this.state.editingElement.type !== "text" || @@ -1108,7 +1108,7 @@ class App extends React.Component { const elementUnderCursor = document.elementFromPoint(cursorX, cursorY); if ( // if no ClipboardEvent supplied, assume we're pasting via contextMenu - // thus these checks don't make sense + // thus these checks don't make sense event && (!(elementUnderCursor instanceof HTMLCanvasElement) || isWritableElement(target)) @@ -1380,7 +1380,7 @@ class App extends React.Component { const roomKey = roomMatch[2]; // fallback in case you're not alone in the room but still don't receive - // initial SCENE_UPDATE message + // initial SCENE_UPDATE message this.socketInitializationTimer = setTimeout( this.initializeSocket, INITIAL_SCENE_UPDATE_TIMEOUT, @@ -1432,7 +1432,7 @@ class App extends React.Component { decryptedData.payload.socketID; // NOTE purposefully mutating collaborators map in case of - // pointer updates so as not to trigger LayerUI rerender + // pointer updates so as not to trigger LayerUI rerender this.setState((state) => { if (!state.collaborators.has(socketId)) { state.collaborators.set(socketId, {}); @@ -1467,9 +1467,9 @@ class App extends React.Component { if (elements) { this.handleRemoteSceneUpdate(elements, { initFromSnapshot: true }); } - } catch (e) { + } catch (error) { // log the error and move on. other peers will sync us the scene. - console.error(e); + console.error(error); } } }; @@ -1814,7 +1814,7 @@ class App extends React.Component { }); // do an initial update to re-initialize element position since we were - // modifying element's x/y for sake of editor (case: syncing to remote) + // modifying element's x/y for sake of editor (case: syncing to remote) updateElement(element.text); } @@ -1920,7 +1920,7 @@ class App extends React.Component { if (existingTextElement) { // if text element is no longer centered to a container, reset - // verticalAlign to default because it's currently internal-only + // verticalAlign to default because it's currently internal-only if (!parentCenterPosition || element.textAlign !== "center") { mutateElement(element, { verticalAlign: DEFAULT_VERTICAL_ALIGN }); } @@ -1931,7 +1931,7 @@ class App extends React.Component { ]); // case: creating new text not centered to parent elemenent → offset Y - // so that the text is centered to cursor position + // so that the text is centered to cursor position if (!parentCenterPosition) { mutateElement(element, { y: element.y - element.baseline / 2, @@ -1952,7 +1952,7 @@ class App extends React.Component { event: React.MouseEvent, ) => { // case: double-clicking with arrow/line tool selected would both create - // text and enter multiElement mode + // text and enter multiElement mode if (this.state.multiElement) { return; } @@ -2129,7 +2129,7 @@ class App extends React.Component { if (lastPoint === lastCommittedPoint) { // if we haven't yet created a temp point and we're beyond commit-zone - // threshold, add a point + // threshold, add a point if ( distance2d( scenePointerX - rx, @@ -2144,11 +2144,11 @@ class App extends React.Component { } else { document.documentElement.style.cursor = CURSOR_TYPE.POINTER; // in this branch, we're inside the commit zone, and no uncommitted - // point exists. Thus do nothing (don't add/remove points). + // point exists. Thus do nothing (don't add/remove points). } } else { // cursor moved inside commit zone, and there's uncommitted point, - // thus remove it + // thus remove it if ( points.length > 2 && lastCommittedPoint && @@ -2293,8 +2293,8 @@ class App extends React.Component { // fixes pointermove causing selection of UI texts #32 event.preventDefault(); // Preventing the event above disables default behavior - // of defocusing potentially focused element, which is what we - // want when clicking inside the canvas. + // of defocusing potentially focused element, which is what we + // want when clicking inside the canvas. if (document.activeElement instanceof HTMLElement) { document.activeElement.blur(); } @@ -2739,8 +2739,8 @@ class App extends React.Component { } // Add hit element to selection. At this point if we're not holding - // SHIFT the previously selected element(s) were deselected above - // (make sure you use setState updater to use latest state) + // SHIFT the previously selected element(s) were deselected above + // (make sure you use setState updater to use latest state) if ( !someHitElementIsSelected && !pointerDownState.hit.hasHitCommonBoundingBoxOfSelectedElements @@ -2798,8 +2798,8 @@ class App extends React.Component { pointerDownState: PointerDownState, ): void => { // if we're currently still editing text, clicking outside - // should only finalize it, not create another (irrespective - // of state.elementLocked) + // should only finalize it, not create another (irrespective + // of state.elementLocked) if (this.state.editingElement?.type === "text") { return; } @@ -2860,7 +2860,7 @@ class App extends React.Component { }, })); // clicking outside commit zone → update reference for last committed - // point + // point mutateElement(multiElement, { lastCommittedPoint: multiElement.points[multiElement.points.length - 1], }); @@ -2986,9 +2986,9 @@ class App extends React.Component { ); // for arrows/lines, don't start dragging until a given threshold - // to ensure we don't create a 2-point arrow by mistake when - // user clicks mouse in a way that it moves a tiny bit (thus - // triggering pointermove) + // to ensure we don't create a 2-point arrow by mistake when + // user clicks mouse in a way that it moves a tiny bit (thus + // triggering pointermove) if ( !pointerDownState.drag.hasOccurred && (this.state.elementType === "arrow" || @@ -3127,7 +3127,7 @@ class App extends React.Component { if ( this.state.selectedElementIds[element.id] || // case: the state.selectedElementIds might not have been - // updated yet by the time this mousemove event is fired + // updated yet by the time this mousemove event is fired (element.id === hitElement?.id && pointerDownState.hit.wasAddedToSelection) ) { @@ -3331,7 +3331,7 @@ class App extends React.Component { selectionElement: null, cursorButton: "up", // text elements are reset on finalize, and resetting on pointerup - // may cause issues with double taps + // may cause issues with double taps editingElement: multiElement || isTextElement(this.state.editingElement) ? this.state.editingElement @@ -3481,8 +3481,8 @@ class App extends React.Component { if (this.state.selectedElementIds[hitElement.id]) { if (isSelectedViaGroup(this.state, hitElement)) { // We want to unselect all groups hitElement is part of - // as well as all elements that are part of the groups - // hitElement is part of + // as well as all elements that are part of the groups + // hitElement is part of const idsOfSelectedElementsThatAreInGroups = hitElement.groupIds .flatMap((groupId) => getElementsInGroup(this.scene.getElements(), groupId), diff --git a/src/components/Portal.tsx b/src/components/Portal.tsx index dbb3188a..d135bc2a 100644 --- a/src/components/Portal.tsx +++ b/src/components/Portal.tsx @@ -167,8 +167,7 @@ class Portal { const newElements = sceneElements .reduce((elements, element) => { // if the remote element references one that's currently - // edited on local, skip it (it'll be added in the next - // step) + // edited on local, skip it (it'll be added in the next step) if ( element.id === this.app.state.editingElement?.id || element.id === this.app.state.resizingElement?.id || diff --git a/src/data/blob.ts b/src/data/blob.ts index a7a02395..4b2b9bf5 100644 --- a/src/data/blob.ts +++ b/src/data/blob.ts @@ -108,7 +108,8 @@ export const loadFromBlob = async ( }, localAppState, ); - } catch { + } catch (error) { + console.error(error.message); throw new Error(t("alerts.couldNotLoadInvalidFile")); } }; diff --git a/src/data/firebase.ts b/src/data/firebase.ts index 1ff9b987..db816558 100644 --- a/src/data/firebase.ts +++ b/src/data/firebase.ts @@ -86,7 +86,7 @@ export const isSavedToFirebase = ( return firebaseSceneVersionCache.get(portal.socket) === sceneVersion; } // if no room exists, consider the room saved so that we don't unnecessarily - // prevent unload (there's nothing we could do at that point anyway) + // prevent unload (there's nothing we could do at that point anyway) return true; }; @@ -97,7 +97,7 @@ export async function saveToFirebase( const { roomID, roomKey, socket } = portal; if ( // if no room exists, consider the room saved because there's nothing we can - // do at this point + // do at this point !roomID || !roomKey || !socket || diff --git a/src/data/library.ts b/src/data/library.ts index dab121a5..506f738e 100644 --- a/src/data/library.ts +++ b/src/data/library.ts @@ -31,7 +31,7 @@ export class Library { } // detect z-index difference by checking the excalidraw elements - // are in order + // are in order return libraryItem.every((libItemExcalidrawItem, idx) => { return ( libItemExcalidrawItem.id === targetLibraryItem[idx].id && @@ -69,8 +69,8 @@ export class Library { Library.libraryCache = JSON.parse(JSON.stringify(items)); resolve(items); - } catch (e) { - console.error(e); + } catch (error) { + console.error(error); resolve([]); } }); @@ -81,12 +81,12 @@ export class Library { try { const serializedItems = JSON.stringify(items); // cache optimistically so that consumers have access to the latest - // immediately + // immediately Library.libraryCache = JSON.parse(serializedItems); localStorage.setItem(STORAGE_KEYS.LOCAL_STORAGE_LIBRARY, serializedItems); - } catch (e) { + } catch (error) { Library.libraryCache = prevLibraryItems; - console.error(e); + console.error(error); } }; } diff --git a/src/data/restore.ts b/src/data/restore.ts index e428df86..5096151d 100644 --- a/src/data/restore.ts +++ b/src/data/restore.ts @@ -32,7 +32,7 @@ const restoreElementWithProperties = ( const base: Pick = { type: element.type, // all elements must have version > 0 so getSceneVersion() will pick up - // newly added elements + // newly added elements version: element.version || 1, versionNonce: element.versionNonce ?? 0, isDeleted: element.isDeleted ?? false, @@ -112,9 +112,9 @@ const restoreElement = ( case "diamond": return restoreElementWithProperties(element, {}); - // don't use default case so as to catch a missing an element type case - // (we also don't want to throw, but instead return void so we - // filter out these unsupported elements from the restored array) + // Don't use default case so as to catch a missing an element type case. + // We also don't want to throw, but instead return void so we filter + // out these unsupported elements from the restored array. } }; @@ -123,7 +123,7 @@ export const restoreElements = ( ): ExcalidrawElement[] => { return (elements || []).reduce((elements, element) => { // filtering out selection, which is legacy, no longer kept in elements, - // and causing issues if retained + // and causing issues if retained if (element.type !== "selection" && !isInvisiblySmallElement(element)) { const migratedElement = restoreElement(element); if (migratedElement) { @@ -161,7 +161,7 @@ const restoreAppState = ( ...nextAppState, offsetLeft: appState.offsetLeft || 0, offsetTop: appState.offsetTop || 0, - /* Migrates from previous version where appState.zoom was a number */ + // Migrates from previous version where appState.zoom was a number zoom: typeof appState.zoom === "number" ? { diff --git a/src/element/linearElementEditor.ts b/src/element/linearElementEditor.ts index 079953c4..b44f80c0 100644 --- a/src/element/linearElementEditor.ts +++ b/src/element/linearElementEditor.ts @@ -227,7 +227,7 @@ export class LinearElementEditor { ); // if we clicked on a point, set the element as hitElement otherwise - // it would get deselected if the point is outside the hitbox area + // it would get deselected if the point is outside the hitbox area if (clickedPointIndex > -1) { ret.hitElement = element; } else { @@ -379,8 +379,8 @@ export class LinearElementEditor { const pointHandles = this.getPointsGlobalCoordinates(element); let idx = pointHandles.length; // loop from right to left because points on the right are rendered over - // points on the left, thus should take precedence when clicking, if they - // overlap + // points on the left, thus should take precedence when clicking, if they + // overlap while (--idx > -1) { const point = pointHandles[idx]; if ( @@ -458,10 +458,10 @@ export class LinearElementEditor { const { points } = element; // in case we're moving start point, instead of modifying its position - // which would break the invariant of it being at [0,0], we move - // all the other points in the opposite direction by delta to - // offset it. We do the same with actual element.x/y position, so - // this hacks are completely transparent to the user. + // which would break the invariant of it being at [0,0], we move + // all the other points in the opposite direction by delta to + // offset it. We do the same with actual element.x/y position, so + // this hacks are completely transparent to the user. let offsetX = 0; let offsetY = 0; @@ -475,7 +475,7 @@ export class LinearElementEditor { nextPoints.splice(pointIndex, 1); if (pointIndex === 0) { // if deleting first point, make the next to be [0,0] and recalculate - // positions of the rest with respect to it + // positions of the rest with respect to it offsetX = nextPoints[0][0]; offsetY = nextPoints[0][1]; nextPoints = nextPoints.map((point, idx) => { diff --git a/src/element/newElement.ts b/src/element/newElement.ts index 25c7f101..b025e403 100644 --- a/src/element/newElement.ts +++ b/src/element/newElement.ts @@ -225,7 +225,7 @@ export const newLinearElement = ( }; // Simplified deep clone for the purpose of cloning ExcalidrawElement only -// (doesn't clone Date, RegExp, Map, Set, Typed arrays etc.) +// (doesn't clone Date, RegExp, Map, Set, Typed arrays etc.) // // Adapted from https://github.com/lukeed/klona export const deepCopyElement = (val: any, depth: number = 0) => { diff --git a/src/element/textWysiwyg.tsx b/src/element/textWysiwyg.tsx index 7befbd61..957bafce 100644 --- a/src/element/textWysiwyg.tsx +++ b/src/element/textWysiwyg.tsx @@ -25,7 +25,7 @@ const getTransform = ( const { zoom, offsetTop, offsetLeft } = appState; const degree = (180 * angle) / Math.PI; // offsets must be multiplied by 2 to account for the division by 2 of - // the whole expression afterwards + // the whole expression afterwards return `translate(${((width - offsetLeft * 2) * (zoom.value - 1)) / 2}px, ${ ((height - offsetTop * 2) * (zoom.value - 1)) / 2 }px) scale(${zoom.value}) rotate(${degree}deg)`; @@ -166,7 +166,7 @@ export const textWysiwyg = ({ const rebindBlur = () => { window.removeEventListener("pointerup", rebindBlur); // deferred to guard against focus traps on various UIs that steal focus - // upon pointerUp + // upon pointerUp setTimeout(() => { editable.onblur = handleSubmit; // case: clicking on the same property → no change → no update → no focus @@ -184,7 +184,7 @@ export const textWysiwyg = ({ editable.onblur = null; window.addEventListener("pointerup", rebindBlur); // handle edge-case where pointerup doesn't fire e.g. due to user - // alt-tabbing away + // alt-tabbing away window.addEventListener("blur", handleSubmit); } }; @@ -199,7 +199,7 @@ export const textWysiwyg = ({ editable.onblur = handleSubmit; // reposition wysiwyg in case of window resize. Happens on mobile when - // device keyboard is opened. + // device keyboard is opened. window.addEventListener("resize", updateWysiwygStyle); window.addEventListener("pointerdown", onPointerDown); window.addEventListener("wheel", stopEvent, { diff --git a/src/renderer/renderElement.ts b/src/renderer/renderElement.ts index d59e337c..032e2269 100644 --- a/src/renderer/renderElement.ts +++ b/src/renderer/renderElement.ts @@ -126,7 +126,7 @@ const drawElementOnCanvas = ( const shouldTemporarilyAttach = rtl && !context.canvas.isConnected; if (shouldTemporarilyAttach) { // to correctly render RTL text mixed with LTR, we have to append it - // to the DOM + // to the DOM document.body.appendChild(context.canvas); } context.canvas.setAttribute("dir", rtl ? "rtl" : "ltr"); @@ -194,17 +194,17 @@ export const generateRoughOptions = (element: ExcalidrawElement): Options => { ? DASHARRAY_DOTTED : undefined, // for non-solid strokes, disable multiStroke because it tends to make - // dashes/dots overlay each other + // dashes/dots overlay each other disableMultiStroke: element.strokeStyle !== "solid", // for non-solid strokes, increase the width a bit to make it visually - // similar to solid strokes, because we're also disabling multiStroke + // similar to solid strokes, because we're also disabling multiStroke strokeWidth: element.strokeStyle !== "solid" ? element.strokeWidth + 0.5 : element.strokeWidth, // when increasing strokeWidth, we must explicitly set fillWeight and - // hachureGap because if not specified, roughjs uses strokeWidth to - // calculate them (and we don't want the fills to be modified) + // hachureGap because if not specified, roughjs uses strokeWidth to + // calculate them (and we don't want the fills to be modified) fillWeight: element.strokeWidth / 2, hachureGap: element.strokeWidth * 4, roughness: element.roughness, diff --git a/src/renderer/renderScene.ts b/src/renderer/renderScene.ts index 30a1cfb7..ef61f693 100644 --- a/src/renderer/renderScene.ts +++ b/src/renderer/renderScene.ts @@ -187,7 +187,7 @@ export const renderScene = ( renderSelection = true, // Whether to employ render optimizations to improve performance. // Should not be turned on for export operations and similar, because it - // doesn't guarantee pixel-perfect output. + // doesn't guarantee pixel-perfect output. renderOptimizations = false, renderGrid = true, }: { diff --git a/src/scene/Scene.ts b/src/scene/Scene.ts index 5c353481..5d981c3f 100644 --- a/src/scene/Scene.ts +++ b/src/scene/Scene.ts @@ -129,7 +129,7 @@ class Scene { } }); // done not for memory leaks, but to guard against possible late fires - // (I guess?) + // (I guess?) this.callbacks.clear(); } } diff --git a/src/serviceWorker.tsx b/src/serviceWorker.tsx index 62ffdda0..1ef7271a 100644 --- a/src/serviceWorker.tsx +++ b/src/serviceWorker.tsx @@ -75,10 +75,9 @@ const registerValidSW = (swUrl: string, config?: Config) => { // but the previous service worker will still serve the older // content until all client tabs are closed. - // console.log( - // "New content is available and will be used when all " + - // "tabs for this page are closed.", - // ); + console.info( + "New content is available and will be used when all tabs for this page are closed.", + ); // Execute callback if (config && config.onUpdate) { @@ -89,7 +88,7 @@ const registerValidSW = (swUrl: string, config?: Config) => { // It's the perfect time to display a // "Content is cached for offline use." message. - // console.log("Content is cached for offline use."); + console.info("Content is cached for offline use."); // Execute callback if (config && config.onSuccess) { @@ -128,10 +127,11 @@ const checkValidServiceWorker = (swUrl: string, config?: Config) => { registerValidSW(swUrl, config); } }) - .catch(() => { - // console.log( - // "No internet connection found. App is running in offline mode.", - // ); + .catch((error) => { + console.info( + "No internet connection found. App is running in offline mode.", + error.message, + ); }); }; diff --git a/src/tests/binding.test.tsx b/src/tests/binding.test.tsx index 4ca802f4..5f833594 100644 --- a/src/tests/binding.test.tsx +++ b/src/tests/binding.test.tsx @@ -68,7 +68,7 @@ describe("element binding", () => { expect(API.getSelectedElement().type).toBe("arrow"); // NOTE this mouse down/up + await needs to be done in order to repro - // the issue, due to https://github.com/excalidraw/excalidraw/blob/46bff3daceb602accf60c40a84610797260fca94/src/components/App.tsx#L740 + // the issue, due to https://github.com/excalidraw/excalidraw/blob/46bff3daceb602accf60c40a84610797260fca94/src/components/App.tsx#L740 mouse.reset(); expect(h.state.editingLinearElement).not.toBe(null); mouse.down(0, 0); diff --git a/src/tests/export.test.tsx b/src/tests/export.test.tsx index 157e5968..3db1c209 100644 --- a/src/tests/export.test.tsx +++ b/src/tests/export.test.tsx @@ -19,7 +19,7 @@ const testElements = [ text: "😀", }), // can't get jsdom text measurement to work so this is a temp hack - // to ensure the element isn't stripped as invisible + // to ensure the element isn't stripped as invisible width: 16, height: 16, }, diff --git a/src/tests/regressionTests.test.tsx b/src/tests/regressionTests.test.tsx index 2dde72d3..1c9726ed 100644 --- a/src/tests/regressionTests.test.tsx +++ b/src/tests/regressionTests.test.tsx @@ -1569,7 +1569,7 @@ it( expect(API.getSelectedElements().length).toBe(3); // clicking on first rectangle that is part of the group should select - // that group (exclusively) + // that group (exclusively) mouse.clickOn(rect1); expect(API.getSelectedElements().length).toBe(2); expect(Object.keys(h.state.selectedGroupIds).length).toBe(1); @@ -1594,8 +1594,7 @@ it( mouse.up(100, 100); // Select first rectangle while keeping third one selected. - // Third rectangle is selected because it was the last element - // to be created. + // Third rectangle is selected because it was the last element to be created. mouse.reset(); Keyboard.withModifierKeys({ shift: true }, () => { mouse.click(); @@ -1616,8 +1615,7 @@ it( }); expect(API.getSelectedElements().length).toBe(3); - // pointer down o first rectangle that is - // part of the group + // Pointer down o first rectangle that is part of the group mouse.reset(); Keyboard.withModifierKeys({ shift: true }, () => { mouse.down(); diff --git a/src/types.ts b/src/types.ts index 23f06666..a59bde7f 100644 --- a/src/types.ts +++ b/src/types.ts @@ -41,7 +41,7 @@ export type AppState = { startBoundElement: NonDeleted | null; suggestedBindings: SuggestedBinding[]; // element being edited, but not necessarily added to elements array yet - // (e.g. text element when typing into the input) + // (e.g. text element when typing into the input) editingElement: NonDeletedExcalidrawElement | null; editingLinearElement: LinearElementEditor | null; elementType: typeof SHAPES[number]["value"]; diff --git a/src/utils.ts b/src/utils.ts index 1018d785..90396859 100644 --- a/src/utils.ts +++ b/src/utils.ts @@ -94,7 +94,7 @@ export const measureText = (text: string, font: FontString) => { line.innerText = text .split("\n") // replace empty lines with single space because leading/trailing empty - // lines would be stripped from computation + // lines would be stripped from computation .map((x) => x || " ") .join("\n"); const width = line.offsetWidth; diff --git a/src/zindex.ts b/src/zindex.ts index 2676f123..9a946ac5 100644 --- a/src/zindex.ts +++ b/src/zindex.ts @@ -62,7 +62,7 @@ const getTargetIndex = ( return false; } // if we're editing group, find closest sibling irrespective of whether - // there's a different-group element between them (for legacy reasons) + // there's a different-group element between them (for legacy reasons) if (appState.editingGroupId) { return element.groupIds.includes(appState.editingGroupId); } @@ -106,7 +106,7 @@ const getTargetIndex = ( if (elementsInSiblingGroup.length) { // assumes getElementsInGroup() returned elements are sorted - // by zIndex (ascending) + // by zIndex (ascending) return direction === "left" ? elements.indexOf(elementsInSiblingGroup[0]) : elements.indexOf(