mirror of
				https://github.com/excalidraw/excalidraw.git
				synced 2025-10-25 17:04:40 +02:00 
			
		
		
		
	Compare commits
	
		
			4 Commits
		
	
	
		
			zsviczian-
			...
			dependabot
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 658248d1da | ||
|   | 2e61926a6b | ||
|   | e921bfb1ae | ||
|   | e6f74350ac | 
| @@ -91,7 +91,7 @@ export class LaserPathManager { | |||||||
|   private collaboratorsState: Map<string, CollabolatorState> = new Map(); |   private collaboratorsState: Map<string, CollabolatorState> = new Map(); | ||||||
|  |  | ||||||
|   private rafId: number | undefined; |   private rafId: number | undefined; | ||||||
|   private isDrawing = false; |   private lastUpdate = 0; | ||||||
|   private container: SVGSVGElement | undefined; |   private container: SVGSVGElement | undefined; | ||||||
|  |  | ||||||
|   constructor(private app: App) { |   constructor(private app: App) { | ||||||
| @@ -100,7 +100,7 @@ export class LaserPathManager { | |||||||
|  |  | ||||||
|   destroy() { |   destroy() { | ||||||
|     this.stop(); |     this.stop(); | ||||||
|     this.isDrawing = false; |     this.lastUpdate = 0; | ||||||
|     this.ownState = instantiateCollabolatorState(); |     this.ownState = instantiateCollabolatorState(); | ||||||
|     this.collaboratorsState = new Map(); |     this.collaboratorsState = new Map(); | ||||||
|   } |   } | ||||||
| @@ -127,7 +127,7 @@ export class LaserPathManager { | |||||||
|   } |   } | ||||||
|  |  | ||||||
|   private updatePath(state: CollabolatorState) { |   private updatePath(state: CollabolatorState) { | ||||||
|     this.isDrawing = true; |     this.lastUpdate = performance.now(); | ||||||
|  |  | ||||||
|     if (!this.isRunning) { |     if (!this.isRunning) { | ||||||
|       this.start(); |       this.start(); | ||||||
| @@ -160,7 +160,7 @@ export class LaserPathManager { | |||||||
|  |  | ||||||
|     this.updateCollabolatorsState(); |     this.updateCollabolatorsState(); | ||||||
|  |  | ||||||
|     if (this.isDrawing) { |     if (performance.now() - this.lastUpdate < DECAY_TIME * 2) { | ||||||
|       this.update(); |       this.update(); | ||||||
|     } else { |     } else { | ||||||
|       this.isRunning = false; |       this.isRunning = false; | ||||||
| @@ -250,8 +250,6 @@ export class LaserPathManager { | |||||||
|       return; |       return; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     let somePathsExist = false; |  | ||||||
|  |  | ||||||
|     for (const [key, state] of this.collaboratorsState.entries()) { |     for (const [key, state] of this.collaboratorsState.entries()) { | ||||||
|       if (!this.app.state.collaborators.has(key)) { |       if (!this.app.state.collaborators.has(key)) { | ||||||
|         state.svg.remove(); |         state.svg.remove(); | ||||||
| @@ -271,10 +269,6 @@ export class LaserPathManager { | |||||||
|         paths += ` ${this.draw(state.currentPath)}`; |         paths += ` ${this.draw(state.currentPath)}`; | ||||||
|       } |       } | ||||||
|  |  | ||||||
|       if (paths.trim()) { |  | ||||||
|         somePathsExist = true; |  | ||||||
|       } |  | ||||||
|  |  | ||||||
|       state.svg.setAttribute("d", paths); |       state.svg.setAttribute("d", paths); | ||||||
|       state.svg.setAttribute("fill", getClientColor(key)); |       state.svg.setAttribute("fill", getClientColor(key)); | ||||||
|     } |     } | ||||||
| @@ -293,17 +287,7 @@ export class LaserPathManager { | |||||||
|       paths += ` ${this.draw(this.ownState.currentPath)}`; |       paths += ` ${this.draw(this.ownState.currentPath)}`; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     paths = paths.trim(); |  | ||||||
|  |  | ||||||
|     if (paths) { |  | ||||||
|       somePathsExist = true; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     this.ownState.svg.setAttribute("d", paths); |     this.ownState.svg.setAttribute("d", paths); | ||||||
|     this.ownState.svg.setAttribute("fill", "red"); |     this.ownState.svg.setAttribute("fill", "red"); | ||||||
|  |  | ||||||
|     if (!somePathsExist) { |  | ||||||
|       this.isDrawing = false; |  | ||||||
|     } |  | ||||||
|   } |   } | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,5 +1,5 @@ | |||||||
| import { updateBoundElements } from "./binding"; | import { updateBoundElements } from "./binding"; | ||||||
| import { Bounds, getCommonBounds } from "./bounds"; | import { getCommonBounds } from "./bounds"; | ||||||
| import { mutateElement } from "./mutateElement"; | import { mutateElement } from "./mutateElement"; | ||||||
| import { getPerfectElementSize } from "./sizeHelpers"; | import { getPerfectElementSize } from "./sizeHelpers"; | ||||||
| import { NonDeletedExcalidrawElement } from "./types"; | import { NonDeletedExcalidrawElement } from "./types"; | ||||||
| @@ -41,16 +41,14 @@ export const dragSelectedElements = ( | |||||||
|     elementsInFrames.forEach((element) => elementsToUpdate.add(element)); |     elementsInFrames.forEach((element) => elementsToUpdate.add(element)); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   const commonBounds = getCommonBounds(Array.from(elementsToUpdate)); |   elementsToUpdate.forEach((element) => { | ||||||
|   const adjustedOffset = calculateOffset( |     updateElementCoords( | ||||||
|     commonBounds, |       pointerDownState, | ||||||
|  |       element, | ||||||
|       offset, |       offset, | ||||||
|       snapOffset, |       snapOffset, | ||||||
|       gridSize, |       gridSize, | ||||||
|     ); |     ); | ||||||
|  |  | ||||||
|   elementsToUpdate.forEach((element) => { |  | ||||||
|     updateElementCoords(pointerDownState, element, adjustedOffset); |  | ||||||
|     // update coords of bound text only if we're dragging the container directly |     // update coords of bound text only if we're dragging the container directly | ||||||
|     // (we don't drag the group that it's part of) |     // (we don't drag the group that it's part of) | ||||||
|     if ( |     if ( | ||||||
| @@ -68,7 +66,13 @@ export const dragSelectedElements = ( | |||||||
|         // updating its coords again |         // updating its coords again | ||||||
|         (!textElement.frameId || !frames.includes(textElement.frameId)) |         (!textElement.frameId || !frames.includes(textElement.frameId)) | ||||||
|       ) { |       ) { | ||||||
|         updateElementCoords(pointerDownState, textElement, adjustedOffset); |         updateElementCoords( | ||||||
|  |           pointerDownState, | ||||||
|  |           textElement, | ||||||
|  |           offset, | ||||||
|  |           snapOffset, | ||||||
|  |           gridSize, | ||||||
|  |         ); | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|     updateBoundElements(element, { |     updateBoundElements(element, { | ||||||
| @@ -77,20 +81,23 @@ export const dragSelectedElements = ( | |||||||
|   }); |   }); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| const calculateOffset = ( | const updateElementCoords = ( | ||||||
|   commonBounds: Bounds, |   pointerDownState: PointerDownState, | ||||||
|  |   element: NonDeletedExcalidrawElement, | ||||||
|   dragOffset: { x: number; y: number }, |   dragOffset: { x: number; y: number }, | ||||||
|   snapOffset: { x: number; y: number }, |   snapOffset: { x: number; y: number }, | ||||||
|   gridSize: AppState["gridSize"], |   gridSize: AppState["gridSize"], | ||||||
| ): { x: number; y: number } => { | ) => { | ||||||
|   const [x, y] = commonBounds; |   const originalElement = | ||||||
|   let nextX = x + dragOffset.x + snapOffset.x; |     pointerDownState.originalElements.get(element.id) ?? element; | ||||||
|   let nextY = y + dragOffset.y + snapOffset.y; |  | ||||||
|  |   let nextX = originalElement.x + dragOffset.x + snapOffset.x; | ||||||
|  |   let nextY = originalElement.y + dragOffset.y + snapOffset.y; | ||||||
|  |  | ||||||
|   if (snapOffset.x === 0 || snapOffset.y === 0) { |   if (snapOffset.x === 0 || snapOffset.y === 0) { | ||||||
|     const [nextGridX, nextGridY] = getGridPoint( |     const [nextGridX, nextGridY] = getGridPoint( | ||||||
|       x + dragOffset.x, |       originalElement.x + dragOffset.x, | ||||||
|       y + dragOffset.y, |       originalElement.y + dragOffset.y, | ||||||
|       gridSize, |       gridSize, | ||||||
|     ); |     ); | ||||||
|  |  | ||||||
| @@ -102,22 +109,6 @@ const calculateOffset = ( | |||||||
|       nextY = nextGridY; |       nextY = nextGridY; | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|   return { |  | ||||||
|     x: nextX - x, |  | ||||||
|     y: nextY - y, |  | ||||||
|   }; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| const updateElementCoords = ( |  | ||||||
|   pointerDownState: PointerDownState, |  | ||||||
|   element: NonDeletedExcalidrawElement, |  | ||||||
|   dragOffset: { x: number; y: number }, |  | ||||||
| ) => { |  | ||||||
|   const originalElement = |  | ||||||
|     pointerDownState.originalElements.get(element.id) ?? element; |  | ||||||
|  |  | ||||||
|   const nextX = originalElement.x + dragOffset.x; |  | ||||||
|   const nextY = originalElement.y + dragOffset.y; |  | ||||||
|  |  | ||||||
|   mutateElement(element, { |   mutateElement(element, { | ||||||
|     x: nextX, |     x: nextX, | ||||||
|   | |||||||
							
								
								
									
										17
									
								
								yarn.lock
									
									
									
									
									
								
							
							
						
						
									
										17
									
								
								yarn.lock
									
									
									
									
									
								
							| @@ -5994,19 +5994,10 @@ portfinder@^1.0.28: | |||||||
|     debug "^3.2.7" |     debug "^3.2.7" | ||||||
|     mkdirp "^0.5.6" |     mkdirp "^0.5.6" | ||||||
|  |  | ||||||
| postcss@^8.4.23: | postcss@^8.4.23, postcss@^8.4.24: | ||||||
|   version "8.4.24" |   version "8.4.31" | ||||||
|   resolved "https://registry.yarnpkg.com/postcss/-/postcss-8.4.24.tgz#f714dba9b2284be3cc07dbd2fc57ee4dc972d2df" |   resolved "https://registry.yarnpkg.com/postcss/-/postcss-8.4.31.tgz#92b451050a9f914da6755af352bdc0192508656d" | ||||||
|   integrity sha512-M0RzbcI0sO/XJNucsGjvWU9ERWxb/ytp1w6dKtxTKgixdtQDq4rmx/g8W1hnaheq9jgwL/oyEdH5Bc4WwJKMqg== |   integrity sha512-PS08Iboia9mts/2ygV3eLpY5ghnUcfLV/EXTOW1E2qYxJKGGBUtNjN76FYHnMs36RmARn41bC0AZmn+rR0OVpQ== | ||||||
|   dependencies: |  | ||||||
|     nanoid "^3.3.6" |  | ||||||
|     picocolors "^1.0.0" |  | ||||||
|     source-map-js "^1.0.2" |  | ||||||
|  |  | ||||||
| postcss@^8.4.24: |  | ||||||
|   version "8.4.25" |  | ||||||
|   resolved "https://registry.yarnpkg.com/postcss/-/postcss-8.4.25.tgz#4a133f5e379eda7f61e906c3b1aaa9b81292726f" |  | ||||||
|   integrity sha512-7taJ/8t2av0Z+sQEvNzCkpDynl0tX3uJMCODi6nT3PfASC7dYCWV9aQ+uiCf+KBD4SEFcu+GvJdGdwzQ6OSjCw== |  | ||||||
|   dependencies: |   dependencies: | ||||||
|     nanoid "^3.3.6" |     nanoid "^3.3.6" | ||||||
|     picocolors "^1.0.0" |     picocolors "^1.0.0" | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user