mirror of
				https://github.com/excalidraw/excalidraw.git
				synced 2025-10-25 00:44:38 +02:00 
			
		
		
		
	Compare commits
	
		
			6 Commits
		
	
	
		
			mtolmacs/f
			...
			v0.17.4
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 640caba739 | ||
|   | 2879c9d852 | ||
|   | 81046ccd6b | ||
|   | 207a0bcc6e | ||
|   | f53edb7437 | ||
|   | 8d0a8ce65b | 
| @@ -39,7 +39,7 @@ Since Vite removes env variables by default, you can update the vite config to e | ||||
|  | ||||
| ``` | ||||
|  define: { | ||||
|     "process.env.IS_PREACT": process.env.IS_PREACT, | ||||
|     "process.env.IS_PREACT": JSON.stringify("true"), | ||||
|   }, | ||||
| ``` | ||||
|  | ||||
|   | ||||
| @@ -93,7 +93,7 @@ Since Vite removes env variables by default, you can update the vite config to e | ||||
|  | ||||
| ``` | ||||
|  define: { | ||||
|     "process.env.IS_PREACT": process.env.IS_PREACT, | ||||
|     "process.env.IS_PREACT": JSON.stringify("true"), | ||||
|   }, | ||||
| ``` | ||||
| :::  | ||||
|   | ||||
| @@ -946,7 +946,11 @@ class App extends React.Component<AppProps, AppState> { | ||||
|                       title="Excalidraw Embedded Content" | ||||
|                       allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture" | ||||
|                       allowFullScreen={true} | ||||
|                       sandbox="allow-same-origin allow-scripts allow-forms allow-popups allow-popups-to-escape-sandbox allow-presentation allow-downloads" | ||||
|                       sandbox={`${ | ||||
|                         embedLink?.sandbox?.allowSameOrigin | ||||
|                           ? "allow-same-origin" | ||||
|                           : "" | ||||
|                       } allow-scripts allow-forms allow-popups allow-popups-to-escape-sandbox allow-presentation allow-downloads`} | ||||
|                     /> | ||||
|                   )} | ||||
|                 </div> | ||||
|   | ||||
| @@ -14,6 +14,7 @@ exports[`Test Transform > Test arrow bindings > should bind arrows to existing s | ||||
|       "type": "arrow", | ||||
|     }, | ||||
|   ], | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -49,6 +50,7 @@ exports[`Test Transform > Test arrow bindings > should bind arrows to existing s | ||||
|       "type": "arrow", | ||||
|     }, | ||||
|   ], | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -79,6 +81,7 @@ exports[`Test Transform > Test arrow bindings > should bind arrows to existing s | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "endArrowhead": "arrow", | ||||
|   "endBinding": { | ||||
|     "elementId": "ellipse-1", | ||||
| @@ -132,6 +135,7 @@ exports[`Test Transform > Test arrow bindings > should bind arrows to existing s | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "endArrowhead": "arrow", | ||||
|   "endBinding": { | ||||
|     "elementId": "ellipse-1", | ||||
| @@ -190,6 +194,7 @@ exports[`Test Transform > Test arrow bindings > should bind arrows to existing s | ||||
|       "type": "arrow", | ||||
|     }, | ||||
|   ], | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -227,6 +232,7 @@ exports[`Test Transform > Test arrow bindings > should bind arrows to existing t | ||||
|     }, | ||||
|   ], | ||||
|   "containerId": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "fontFamily": 1, | ||||
|   "fontSize": 20, | ||||
| @@ -271,6 +277,7 @@ exports[`Test Transform > Test arrow bindings > should bind arrows to existing t | ||||
|     }, | ||||
|   ], | ||||
|   "containerId": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "fontFamily": 1, | ||||
|   "fontSize": 20, | ||||
| @@ -313,6 +320,7 @@ exports[`Test Transform > Test arrow bindings > should bind arrows to existing t | ||||
|       "type": "text", | ||||
|     }, | ||||
|   ], | ||||
|   "customData": undefined, | ||||
|   "endArrowhead": "arrow", | ||||
|   "endBinding": { | ||||
|     "elementId": "text-2", | ||||
| @@ -368,6 +376,7 @@ exports[`Test Transform > Test arrow bindings > should bind arrows to existing t | ||||
|   "baseline": 0, | ||||
|   "boundElements": null, | ||||
|   "containerId": "id48", | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "fontFamily": 1, | ||||
|   "fontSize": 20, | ||||
| @@ -410,6 +419,7 @@ exports[`Test Transform > Test arrow bindings > should bind arrows to shapes whe | ||||
|       "type": "text", | ||||
|     }, | ||||
|   ], | ||||
|   "customData": undefined, | ||||
|   "endArrowhead": "arrow", | ||||
|   "endBinding": { | ||||
|     "elementId": "id40", | ||||
| @@ -465,6 +475,7 @@ exports[`Test Transform > Test arrow bindings > should bind arrows to shapes whe | ||||
|   "baseline": 0, | ||||
|   "boundElements": null, | ||||
|   "containerId": "id37", | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "fontFamily": 1, | ||||
|   "fontSize": 20, | ||||
| @@ -507,6 +518,7 @@ exports[`Test Transform > Test arrow bindings > should bind arrows to shapes whe | ||||
|       "type": "arrow", | ||||
|     }, | ||||
|   ], | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -542,6 +554,7 @@ exports[`Test Transform > Test arrow bindings > should bind arrows to shapes whe | ||||
|       "type": "arrow", | ||||
|     }, | ||||
|   ], | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -577,6 +590,7 @@ exports[`Test Transform > Test arrow bindings > should bind arrows to text when | ||||
|       "type": "text", | ||||
|     }, | ||||
|   ], | ||||
|   "customData": undefined, | ||||
|   "endArrowhead": "arrow", | ||||
|   "endBinding": { | ||||
|     "elementId": "id44", | ||||
| @@ -632,6 +646,7 @@ exports[`Test Transform > Test arrow bindings > should bind arrows to text when | ||||
|   "baseline": 0, | ||||
|   "boundElements": null, | ||||
|   "containerId": "id41", | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "fontFamily": 1, | ||||
|   "fontSize": 20, | ||||
| @@ -676,6 +691,7 @@ exports[`Test Transform > Test arrow bindings > should bind arrows to text when | ||||
|     }, | ||||
|   ], | ||||
|   "containerId": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "fontFamily": 1, | ||||
|   "fontSize": 20, | ||||
| @@ -720,6 +736,7 @@ exports[`Test Transform > Test arrow bindings > should bind arrows to text when | ||||
|     }, | ||||
|   ], | ||||
|   "containerId": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "fontFamily": 1, | ||||
|   "fontSize": 20, | ||||
| @@ -757,6 +774,7 @@ exports[`Test Transform > should not allow duplicate ids 1`] = ` | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -787,6 +805,7 @@ exports[`Test Transform > should transform linear elements 1`] = ` | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "endArrowhead": "arrow", | ||||
|   "endBinding": null, | ||||
|   "fillStyle": "solid", | ||||
| @@ -832,6 +851,7 @@ exports[`Test Transform > should transform linear elements 2`] = ` | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "endArrowhead": "triangle", | ||||
|   "endBinding": null, | ||||
|   "fillStyle": "solid", | ||||
| @@ -877,6 +897,7 @@ exports[`Test Transform > should transform linear elements 3`] = ` | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "endArrowhead": null, | ||||
|   "endBinding": null, | ||||
|   "fillStyle": "solid", | ||||
| @@ -922,6 +943,7 @@ exports[`Test Transform > should transform linear elements 4`] = ` | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "endArrowhead": null, | ||||
|   "endBinding": null, | ||||
|   "fillStyle": "solid", | ||||
| @@ -967,6 +989,7 @@ exports[`Test Transform > should transform regular shapes 1`] = ` | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -997,6 +1020,7 @@ exports[`Test Transform > should transform regular shapes 2`] = ` | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -1027,6 +1051,7 @@ exports[`Test Transform > should transform regular shapes 3`] = ` | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -1057,6 +1082,7 @@ exports[`Test Transform > should transform regular shapes 4`] = ` | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "#c0eb75", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -1087,6 +1113,7 @@ exports[`Test Transform > should transform regular shapes 5`] = ` | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "#ffc9c9", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -1117,6 +1144,7 @@ exports[`Test Transform > should transform regular shapes 6`] = ` | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "#a5d8ff", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "cross-hatch", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -1149,6 +1177,7 @@ exports[`Test Transform > should transform text element 1`] = ` | ||||
|   "baseline": 0, | ||||
|   "boundElements": null, | ||||
|   "containerId": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "fontFamily": 1, | ||||
|   "fontSize": 20, | ||||
| @@ -1188,6 +1217,7 @@ exports[`Test Transform > should transform text element 2`] = ` | ||||
|   "baseline": 0, | ||||
|   "boundElements": null, | ||||
|   "containerId": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "fontFamily": 1, | ||||
|   "fontSize": 20, | ||||
| @@ -1230,6 +1260,7 @@ exports[`Test Transform > should transform to labelled arrows when label provide | ||||
|       "type": "text", | ||||
|     }, | ||||
|   ], | ||||
|   "customData": undefined, | ||||
|   "endArrowhead": "arrow", | ||||
|   "endBinding": null, | ||||
|   "fillStyle": "solid", | ||||
| @@ -1280,6 +1311,7 @@ exports[`Test Transform > should transform to labelled arrows when label provide | ||||
|       "type": "text", | ||||
|     }, | ||||
|   ], | ||||
|   "customData": undefined, | ||||
|   "endArrowhead": "arrow", | ||||
|   "endBinding": null, | ||||
|   "fillStyle": "solid", | ||||
| @@ -1330,6 +1362,7 @@ exports[`Test Transform > should transform to labelled arrows when label provide | ||||
|       "type": "text", | ||||
|     }, | ||||
|   ], | ||||
|   "customData": undefined, | ||||
|   "endArrowhead": "arrow", | ||||
|   "endBinding": null, | ||||
|   "fillStyle": "solid", | ||||
| @@ -1380,6 +1413,7 @@ exports[`Test Transform > should transform to labelled arrows when label provide | ||||
|       "type": "text", | ||||
|     }, | ||||
|   ], | ||||
|   "customData": undefined, | ||||
|   "endArrowhead": "arrow", | ||||
|   "endBinding": null, | ||||
|   "fillStyle": "solid", | ||||
| @@ -1427,6 +1461,7 @@ exports[`Test Transform > should transform to labelled arrows when label provide | ||||
|   "baseline": 0, | ||||
|   "boundElements": null, | ||||
|   "containerId": "id25", | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "fontFamily": 1, | ||||
|   "fontSize": 20, | ||||
| @@ -1466,6 +1501,7 @@ exports[`Test Transform > should transform to labelled arrows when label provide | ||||
|   "baseline": 0, | ||||
|   "boundElements": null, | ||||
|   "containerId": "id26", | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "fontFamily": 1, | ||||
|   "fontSize": 20, | ||||
| @@ -1505,6 +1541,7 @@ exports[`Test Transform > should transform to labelled arrows when label provide | ||||
|   "baseline": 0, | ||||
|   "boundElements": null, | ||||
|   "containerId": "id27", | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "fontFamily": 1, | ||||
|   "fontSize": 20, | ||||
| @@ -1545,6 +1582,7 @@ exports[`Test Transform > should transform to labelled arrows when label provide | ||||
|   "baseline": 0, | ||||
|   "boundElements": null, | ||||
|   "containerId": "id28", | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "fontFamily": 1, | ||||
|   "fontSize": 20, | ||||
| @@ -1588,6 +1626,7 @@ exports[`Test Transform > should transform to text containers when label provide | ||||
|       "type": "text", | ||||
|     }, | ||||
|   ], | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -1623,6 +1662,7 @@ exports[`Test Transform > should transform to text containers when label provide | ||||
|       "type": "text", | ||||
|     }, | ||||
|   ], | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -1658,6 +1698,7 @@ exports[`Test Transform > should transform to text containers when label provide | ||||
|       "type": "text", | ||||
|     }, | ||||
|   ], | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -1693,6 +1734,7 @@ exports[`Test Transform > should transform to text containers when label provide | ||||
|       "type": "text", | ||||
|     }, | ||||
|   ], | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -1728,6 +1770,7 @@ exports[`Test Transform > should transform to text containers when label provide | ||||
|       "type": "text", | ||||
|     }, | ||||
|   ], | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -1763,6 +1806,7 @@ exports[`Test Transform > should transform to text containers when label provide | ||||
|       "type": "text", | ||||
|     }, | ||||
|   ], | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -1795,6 +1839,7 @@ exports[`Test Transform > should transform to text containers when label provide | ||||
|   "baseline": 0, | ||||
|   "boundElements": null, | ||||
|   "containerId": "id13", | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "fontFamily": 1, | ||||
|   "fontSize": 20, | ||||
| @@ -1834,6 +1879,7 @@ exports[`Test Transform > should transform to text containers when label provide | ||||
|   "baseline": 0, | ||||
|   "boundElements": null, | ||||
|   "containerId": "id14", | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "fontFamily": 1, | ||||
|   "fontSize": 20, | ||||
| @@ -1874,6 +1920,7 @@ exports[`Test Transform > should transform to text containers when label provide | ||||
|   "baseline": 0, | ||||
|   "boundElements": null, | ||||
|   "containerId": "id15", | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "fontFamily": 1, | ||||
|   "fontSize": 20, | ||||
| @@ -1916,6 +1963,7 @@ exports[`Test Transform > should transform to text containers when label provide | ||||
|   "baseline": 0, | ||||
|   "boundElements": null, | ||||
|   "containerId": "id16", | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "fontFamily": 1, | ||||
|   "fontSize": 20, | ||||
| @@ -1956,6 +2004,7 @@ exports[`Test Transform > should transform to text containers when label provide | ||||
|   "baseline": 0, | ||||
|   "boundElements": null, | ||||
|   "containerId": "id17", | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "fontFamily": 1, | ||||
|   "fontSize": 20, | ||||
| @@ -1997,6 +2046,7 @@ exports[`Test Transform > should transform to text containers when label provide | ||||
|   "baseline": 0, | ||||
|   "boundElements": null, | ||||
|   "containerId": "id18", | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "fontFamily": 1, | ||||
|   "fontSize": 20, | ||||
|   | ||||
| @@ -822,4 +822,22 @@ describe("Test Transform", () => { | ||||
|       "Duplicate id found for rect-1", | ||||
|     ); | ||||
|   }); | ||||
|  | ||||
|   it("should contains customData if provided", () => { | ||||
|     const rawData = [ | ||||
|       { | ||||
|         type: "rectangle", | ||||
|         x: 100, | ||||
|         y: 100, | ||||
|         customData: { createdBy: "user01" }, | ||||
|       }, | ||||
|     ]; | ||||
|     const convertedElements = convertToExcalidrawElements( | ||||
|       rawData as ExcalidrawElementSkeleton[], | ||||
|       opts, | ||||
|     ); | ||||
|     expect(convertedElements[0].customData).toStrictEqual({ | ||||
|       createdBy: "user01", | ||||
|     }); | ||||
|   }); | ||||
| }); | ||||
|   | ||||
| @@ -13,6 +13,7 @@ import { Point } from "../types"; | ||||
| import { generateRoughOptions } from "../scene/Shape"; | ||||
| import { | ||||
|   isArrowElement, | ||||
|   isBoundToContainer, | ||||
|   isFreeDrawElement, | ||||
|   isLinearElement, | ||||
|   isTextElement, | ||||
| @@ -22,6 +23,7 @@ import { getBoundTextElement, getContainerElement } from "./textElement"; | ||||
| import { LinearElementEditor } from "./linearElementEditor"; | ||||
| import { Mutable } from "../utility-types"; | ||||
| import { ShapeCache } from "../scene/ShapeCache"; | ||||
| import Scene from "../scene/Scene"; | ||||
|  | ||||
| export type RectangleBox = { | ||||
|   x: number; | ||||
| @@ -53,16 +55,29 @@ export class ElementBounds { | ||||
|   static getBounds(element: ExcalidrawElement) { | ||||
|     const cachedBounds = ElementBounds.boundsCache.get(element); | ||||
|  | ||||
|     if (cachedBounds?.version && cachedBounds.version === element.version) { | ||||
|     if ( | ||||
|       cachedBounds?.version && | ||||
|       cachedBounds.version === element.version && | ||||
|       // we don't invalidate cache when we update containers and not labels, | ||||
|       // which is causing problems down the line. Fix TBA. | ||||
|       !isBoundToContainer(element) | ||||
|     ) { | ||||
|       return cachedBounds.bounds; | ||||
|     } | ||||
|  | ||||
|     const bounds = ElementBounds.calculateBounds(element); | ||||
|  | ||||
|     ElementBounds.boundsCache.set(element, { | ||||
|       version: element.version, | ||||
|       bounds, | ||||
|     }); | ||||
|     // hack to ensure that downstream checks could retrieve element Scene | ||||
|     // so as to have correctly calculated bounds | ||||
|     // FIXME remove when we get rid of all the id:Scene / element:Scene mapping | ||||
|     const shouldCache = Scene.getScene(element); | ||||
|  | ||||
|     if (shouldCache) { | ||||
|       ElementBounds.boundsCache.set(element, { | ||||
|         version: element.version, | ||||
|         bounds, | ||||
|       }); | ||||
|     } | ||||
|  | ||||
|     return bounds; | ||||
|   } | ||||
|   | ||||
| @@ -18,6 +18,7 @@ type EmbeddedLink = | ||||
|   | ({ | ||||
|       aspectRatio: { w: number; h: number }; | ||||
|       warning?: string; | ||||
|       sandbox?: { allowSameOrigin?: boolean }; | ||||
|     } & ( | ||||
|       | { type: "video" | "generic"; link: string } | ||||
|       | { type: "document"; srcdoc: (theme: Theme) => string } | ||||
| @@ -30,20 +31,20 @@ const RE_YOUTUBE = | ||||
|   /^(?:http(?:s)?:\/\/)?(?:www\.)?youtu(?:be\.com|\.be)\/(embed\/|watch\?v=|shorts\/|playlist\?list=|embed\/videoseries\?list=)?([a-zA-Z0-9_-]+)(?:\?t=|&t=|\?start=|&start=)?([a-zA-Z0-9_-]+)?[^\s]*$/; | ||||
|  | ||||
| const RE_VIMEO = | ||||
|   /^(?:http(?:s)?:\/\/)?(?:(?:w){3}.)?(?:player\.)?vimeo\.com\/(?:video\/)?([^?\s]+)(?:\?.*)?$/; | ||||
|   /^(?:http(?:s)?:\/\/)?(?:(?:w){3}\.)?(?:player\.)?vimeo\.com\/(?:video\/)?([^?\s]+)(?:\?.*)?$/; | ||||
| const RE_FIGMA = /^https:\/\/(?:www\.)?figma\.com/; | ||||
|  | ||||
| const RE_GH_GIST = /^https:\/\/gist\.github\.com/; | ||||
| const RE_GH_GIST_EMBED = | ||||
|   /^<script[\s\S]*?\ssrc=["'](https:\/\/gist.github.com\/.*?)\.js["']/i; | ||||
|   /https?:\/\/gist\.github\.com\/([\w_-]+)\/([\w_-]+)\.js["']/i; | ||||
|  | ||||
| // not anchored to start to allow <blockquote> twitter embeds | ||||
| const RE_TWITTER = /(?:http(?:s)?:\/\/)?(?:(?:w){3}.)?twitter.com/; | ||||
| const RE_TWITTER = /(?:https?:\/\/)?(?:(?:w){3}\.)?(?:twitter|x)\.com/; | ||||
| const RE_TWITTER_EMBED = | ||||
|   /^<blockquote[\s\S]*?\shref=["'](https:\/\/twitter.com\/[^"']*)/i; | ||||
|   /^<blockquote[\s\S]*?\shref=["'](https?:\/\/(?:twitter|x)\.com\/[^"']*)/i; | ||||
|  | ||||
| const RE_VALTOWN = | ||||
|   /^https:\/\/(?:www\.)?val.town\/(v|embed)\/[a-zA-Z_$][0-9a-zA-Z_$]+\.[a-zA-Z_$][0-9a-zA-Z_$]+/; | ||||
|   /^https:\/\/(?:www\.)?val\.town\/(v|embed)\/[a-zA-Z_$][0-9a-zA-Z_$]+\.[a-zA-Z_$][0-9a-zA-Z_$]+/; | ||||
|  | ||||
| const RE_GENERIC_EMBED = | ||||
|   /^<(?:iframe|blockquote)[\s\S]*?\s(?:src|href)=["']([^"']*)["'][\s\S]*?>$/i; | ||||
| @@ -143,46 +144,27 @@ export const getEmbedLink = (link: string | null | undefined): EmbeddedLink => { | ||||
|   } | ||||
|  | ||||
|   if (RE_TWITTER.test(link)) { | ||||
|     let ret: EmbeddedLink; | ||||
|     // assume embed code | ||||
|     if (/<blockquote/.test(link)) { | ||||
|       const srcDoc = createSrcDoc(link); | ||||
|       ret = { | ||||
|         type: "document", | ||||
|         srcdoc: () => srcDoc, | ||||
|         aspectRatio: { w: 480, h: 480 }, | ||||
|       }; | ||||
|       // assume regular tweet url | ||||
|     } else { | ||||
|       ret = { | ||||
|         type: "document", | ||||
|         srcdoc: (theme: string) => | ||||
|           createSrcDoc( | ||||
|             `<blockquote class="twitter-tweet" data-dnt="true" data-theme="${theme}"><a href="${link}"></a></blockquote> <script async src="https://platform.twitter.com/widgets.js" charset="utf-8"></script>`, | ||||
|           ), | ||||
|         aspectRatio: { w: 480, h: 480 }, | ||||
|       }; | ||||
|     } | ||||
|     // the embed srcdoc still supports twitter.com domain only | ||||
|     link = link.replace(/\bx.com\b/, "twitter.com"); | ||||
|  | ||||
|     const ret: EmbeddedLink = { | ||||
|       type: "document", | ||||
|       srcdoc: (theme: string) => | ||||
|         createSrcDoc( | ||||
|           `<blockquote class="twitter-tweet" data-dnt="true" data-theme="${theme}"><a href="${link}"></a></blockquote> <script async src="https://platform.twitter.com/widgets.js" charset="utf-8"></script>`, | ||||
|         ), | ||||
|       aspectRatio: { w: 480, h: 480 }, | ||||
|       sandbox: { allowSameOrigin: true }, | ||||
|     }; | ||||
|     embeddedLinkCache.set(originalLink, ret); | ||||
|     return ret; | ||||
|   } | ||||
|  | ||||
|   if (RE_GH_GIST.test(link)) { | ||||
|     let ret: EmbeddedLink; | ||||
|     // assume embed code | ||||
|     if (/<script>/.test(link)) { | ||||
|       const srcDoc = createSrcDoc(link); | ||||
|       ret = { | ||||
|         type: "document", | ||||
|         srcdoc: () => srcDoc, | ||||
|         aspectRatio: { w: 550, h: 720 }, | ||||
|       }; | ||||
|       // assume regular url | ||||
|     } else { | ||||
|       ret = { | ||||
|         type: "document", | ||||
|         srcdoc: () => | ||||
|           createSrcDoc(` | ||||
|     const ret: EmbeddedLink = { | ||||
|       type: "document", | ||||
|       srcdoc: () => | ||||
|         createSrcDoc(` | ||||
|           <script src="${link}.js"></script> | ||||
|           <style type="text/css"> | ||||
|             * { margin: 0px; } | ||||
| @@ -190,9 +172,8 @@ export const getEmbedLink = (link: string | null | undefined): EmbeddedLink => { | ||||
|             .gist .gist-file { height: calc(100vh - 2px); padding: 0px; display: grid; grid-template-rows: 1fr auto; } | ||||
|           </style> | ||||
|         `), | ||||
|         aspectRatio: { w: 550, h: 720 }, | ||||
|       }; | ||||
|     } | ||||
|       aspectRatio: { w: 550, h: 720 }, | ||||
|     }; | ||||
|     embeddedLinkCache.set(link, ret); | ||||
|     return ret; | ||||
|   } | ||||
| @@ -310,8 +291,8 @@ export const extractSrc = (htmlString: string): string => { | ||||
|   } | ||||
|  | ||||
|   const gistMatch = htmlString.match(RE_GH_GIST_EMBED); | ||||
|   if (gistMatch && gistMatch.length === 2) { | ||||
|     return gistMatch[1]; | ||||
|   if (gistMatch && gistMatch.length === 3) { | ||||
|     return `https://gist.github.com/${gistMatch[1]}/${gistMatch[2]}`; | ||||
|   } | ||||
|  | ||||
|   if (RE_GIPHY.test(htmlString)) { | ||||
|   | ||||
| @@ -67,6 +67,7 @@ export type ElementConstructorOpts = MarkOptional< | ||||
|   | "roundness" | ||||
|   | "locked" | ||||
|   | "opacity" | ||||
|   | "customData" | ||||
| >; | ||||
|  | ||||
| const _newElementBase = <T extends ExcalidrawElement>( | ||||
| @@ -120,6 +121,7 @@ const _newElementBase = <T extends ExcalidrawElement>( | ||||
|     updated: getUpdatedTimestamp(), | ||||
|     link, | ||||
|     locked, | ||||
|     customData: rest.customData, | ||||
|   }; | ||||
|   return element; | ||||
| }; | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| [ | ||||
|   { | ||||
|     "path": "dist/excalidraw.production.min.js", | ||||
|     "limit": "325 kB" | ||||
|     "limit": "335 kB" | ||||
|   }, | ||||
|   { | ||||
|     "path": "dist/excalidraw-assets/locales", | ||||
|   | ||||
| @@ -11,6 +11,72 @@ The change should be grouped under one of the below section and must contain PR | ||||
| Please add the latest change on the top under the correct section. | ||||
| --> | ||||
|  | ||||
| ## Unreleased | ||||
|  | ||||
| ### Features | ||||
|  | ||||
| - Add `onPointerUp` prop [#7638](https://github.com/excalidraw/excalidraw/pull/7638). | ||||
|  | ||||
| - Expose `getVisibleSceneBounds` helper to get scene bounds of visible canvas area. [#7450](https://github.com/excalidraw/excalidraw/pull/7450) | ||||
|  | ||||
| ### Fixes | ||||
|  | ||||
| - Keep customData when converting to ExcalidrawElement. [#7656](https://github.com/excalidraw/excalidraw/pull/7656) | ||||
|  | ||||
| ### Breaking Changes | ||||
|  | ||||
| - `ExcalidrawEmbeddableElement.validated` was removed and moved to private editor state. This should largely not affect your apps unless you were reading from this attribute. We keep validating embeddable urls internally, and the public [`props.validateEmbeddable`](https://docs.excalidraw.com/docs/@excalidraw/excalidraw/api/props#validateembeddable) still applies. [#7539](https://github.com/excalidraw/excalidraw/pull/7539) | ||||
|  | ||||
| - Create an `ESM` build for `@excalidraw/excalidraw`. The API is in progress and subject to change before stable release. There are some changes on how the package will be consumed | ||||
|  | ||||
|   #### Bundler | ||||
|  | ||||
|   - CSS needs to be imported so you will need to import the css along with the excalidraw component | ||||
|  | ||||
|   ```js | ||||
|   import { Excalidraw } from "@excalidraw/excalidraw"; | ||||
|   import "@excalidraw/excalidraw/index.css"; | ||||
|   ``` | ||||
|  | ||||
|   - The `types` path is updated | ||||
|  | ||||
|   Instead of importing from `@excalidraw/excalidraw/types/`, you will need to import from `@excalidraw/excalidraw/dist/excalidraw` or `@excalidraw/excalidraw/dist/utils` depending on the types you are using. | ||||
|  | ||||
|   However this we will be fixing before stable release, so in case you want to try it out you will need to update the types for now. | ||||
|  | ||||
|   #### Browser | ||||
|  | ||||
|   - Since its `ESM` so now script type `module` can be used to load it and css needs to be loaded as well. | ||||
|  | ||||
|   ```html | ||||
|   <link | ||||
|     rel="stylesheet" | ||||
|     href="https://unpkg.com/@excalidraw/excalidraw@next/dist/browser/dev/index.css" | ||||
|   /> | ||||
|   <script type="module"> | ||||
|     import * as ExcalidrawLib from "https://unpkg.com/@excalidraw/excalidraw@next/dist/browser/dev/index.js"; | ||||
|     window.ExcalidrawLib = ExcalidrawLib; | ||||
|   </script> | ||||
|   ``` | ||||
|  | ||||
| - `appState.openDialog` type was changed from `null | string` to `null | { name: string }`. [#7336](https://github.com/excalidraw/excalidraw/pull/7336) | ||||
|  | ||||
| ## 0.17.1 (2023-11-28) | ||||
|  | ||||
| ### Fixes | ||||
|  | ||||
| - Umd build for browser since it was breaking in v0.17.0 [#7349](https://github.com/excalidraw/excalidraw/pull/7349). Also make sure that when using `Vite`, the `process.env.IS_PREACT` is set as `"true"` (string) and not a boolean. | ||||
|  | ||||
| ``` | ||||
| define: { | ||||
|   "process.env.IS_PREACT": JSON.stringify("true"), | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ### Breaking Changes | ||||
|  | ||||
| - `appState.openDialog` type was changed from `null | string` to `null | { name: string }`. [#7336](https://github.com/excalidraw/excalidraw/pull/7336) | ||||
|  | ||||
| ## 0.17.0 (2023-11-14) | ||||
|  | ||||
| ### Features | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|   "name": "@excalidraw/excalidraw", | ||||
|   "version": "0.17.0", | ||||
|   "version": "0.17.4", | ||||
|   "main": "main.js", | ||||
|   "types": "types/packages/excalidraw/index.d.ts", | ||||
|   "files": [ | ||||
|   | ||||
| @@ -1,5 +1,3 @@ | ||||
| const { merge } = require("webpack-merge"); | ||||
|  | ||||
| const prodConfig = require("./webpack.prod.config"); | ||||
| const devConfig = require("./webpack.dev.config"); | ||||
|  | ||||
| @@ -11,6 +9,7 @@ const outputFile = isProd | ||||
|   : "excalidraw-with-preact.development"; | ||||
|  | ||||
| const preactWebpackConfig = { | ||||
|   ...config, | ||||
|   entry: { | ||||
|     [outputFile]: "./entry.js", | ||||
|   }, | ||||
| @@ -30,4 +29,4 @@ const preactWebpackConfig = { | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| module.exports = merge(config, preactWebpackConfig); | ||||
| module.exports = preactWebpackConfig; | ||||
|   | ||||
| @@ -385,6 +385,7 @@ exports[`contextMenu element > right-clicking on a group should select whole gro | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "red", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [ | ||||
| @@ -419,6 +420,7 @@ exports[`contextMenu element > right-clicking on a group should select whole gro | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "red", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [ | ||||
| @@ -580,6 +582,7 @@ exports[`contextMenu element > selecting 'Add to library' in context menu adds e | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -639,6 +642,7 @@ exports[`contextMenu element > selecting 'Add to library' in context menu adds e | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -780,6 +784,7 @@ exports[`contextMenu element > selecting 'Bring forward' in context menu brings | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -812,6 +817,7 @@ exports[`contextMenu element > selecting 'Bring forward' in context menu brings | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -871,6 +877,7 @@ exports[`contextMenu element > selecting 'Bring forward' in context menu brings | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -914,6 +921,7 @@ exports[`contextMenu element > selecting 'Bring forward' in context menu brings | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -943,6 +951,7 @@ exports[`contextMenu element > selecting 'Bring forward' in context menu brings | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -986,6 +995,7 @@ exports[`contextMenu element > selecting 'Bring forward' in context menu brings | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -1015,6 +1025,7 @@ exports[`contextMenu element > selecting 'Bring forward' in context menu brings | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -1156,6 +1167,7 @@ exports[`contextMenu element > selecting 'Bring to front' in context menu brings | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -1188,6 +1200,7 @@ exports[`contextMenu element > selecting 'Bring to front' in context menu brings | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -1247,6 +1260,7 @@ exports[`contextMenu element > selecting 'Bring to front' in context menu brings | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -1290,6 +1304,7 @@ exports[`contextMenu element > selecting 'Bring to front' in context menu brings | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -1319,6 +1334,7 @@ exports[`contextMenu element > selecting 'Bring to front' in context menu brings | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -1362,6 +1378,7 @@ exports[`contextMenu element > selecting 'Bring to front' in context menu brings | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -1391,6 +1408,7 @@ exports[`contextMenu element > selecting 'Bring to front' in context menu brings | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -1534,6 +1552,7 @@ exports[`contextMenu element > selecting 'Copy styles' in context menu copies st | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -1593,6 +1612,7 @@ exports[`contextMenu element > selecting 'Copy styles' in context menu copies st | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -1732,6 +1752,7 @@ exports[`contextMenu element > selecting 'Delete' in context menu deletes elemen | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -1791,6 +1812,7 @@ exports[`contextMenu element > selecting 'Delete' in context menu deletes elemen | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -1832,6 +1854,7 @@ exports[`contextMenu element > selecting 'Delete' in context menu deletes elemen | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -1973,6 +1996,7 @@ exports[`contextMenu element > selecting 'Duplicate' in context menu duplicates | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -2005,6 +2029,7 @@ exports[`contextMenu element > selecting 'Duplicate' in context menu duplicates | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -2064,6 +2089,7 @@ exports[`contextMenu element > selecting 'Duplicate' in context menu duplicates | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -2107,6 +2133,7 @@ exports[`contextMenu element > selecting 'Duplicate' in context menu duplicates | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -2136,6 +2163,7 @@ exports[`contextMenu element > selecting 'Duplicate' in context menu duplicates | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -2282,6 +2310,7 @@ exports[`contextMenu element > selecting 'Group selection' in context menu group | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [ | ||||
| @@ -2316,6 +2345,7 @@ exports[`contextMenu element > selecting 'Group selection' in context menu group | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [ | ||||
| @@ -2377,6 +2407,7 @@ exports[`contextMenu element > selecting 'Group selection' in context menu group | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -2420,6 +2451,7 @@ exports[`contextMenu element > selecting 'Group selection' in context menu group | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -2449,6 +2481,7 @@ exports[`contextMenu element > selecting 'Group selection' in context menu group | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -2495,6 +2528,7 @@ exports[`contextMenu element > selecting 'Group selection' in context menu group | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [ | ||||
| @@ -2526,6 +2560,7 @@ exports[`contextMenu element > selecting 'Group selection' in context menu group | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [ | ||||
| @@ -2671,6 +2706,7 @@ exports[`contextMenu element > selecting 'Paste styles' in context menu pastes s | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "#a5d8ff", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "cross-hatch", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -2703,6 +2739,7 @@ exports[`contextMenu element > selecting 'Paste styles' in context menu pastes s | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "#a5d8ff", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "cross-hatch", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -2762,6 +2799,7 @@ exports[`contextMenu element > selecting 'Paste styles' in context menu pastes s | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -2805,6 +2843,7 @@ exports[`contextMenu element > selecting 'Paste styles' in context menu pastes s | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -2834,6 +2873,7 @@ exports[`contextMenu element > selecting 'Paste styles' in context menu pastes s | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -2877,6 +2917,7 @@ exports[`contextMenu element > selecting 'Paste styles' in context menu pastes s | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -2906,6 +2947,7 @@ exports[`contextMenu element > selecting 'Paste styles' in context menu pastes s | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -2949,6 +2991,7 @@ exports[`contextMenu element > selecting 'Paste styles' in context menu pastes s | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -2978,6 +3021,7 @@ exports[`contextMenu element > selecting 'Paste styles' in context menu pastes s | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "#a5d8ff", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -3021,6 +3065,7 @@ exports[`contextMenu element > selecting 'Paste styles' in context menu pastes s | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -3050,6 +3095,7 @@ exports[`contextMenu element > selecting 'Paste styles' in context menu pastes s | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "#a5d8ff", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "cross-hatch", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -3093,6 +3139,7 @@ exports[`contextMenu element > selecting 'Paste styles' in context menu pastes s | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -3122,6 +3169,7 @@ exports[`contextMenu element > selecting 'Paste styles' in context menu pastes s | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "#a5d8ff", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "cross-hatch", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -3165,6 +3213,7 @@ exports[`contextMenu element > selecting 'Paste styles' in context menu pastes s | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -3194,6 +3243,7 @@ exports[`contextMenu element > selecting 'Paste styles' in context menu pastes s | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "#a5d8ff", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "cross-hatch", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -3237,6 +3287,7 @@ exports[`contextMenu element > selecting 'Paste styles' in context menu pastes s | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -3266,6 +3317,7 @@ exports[`contextMenu element > selecting 'Paste styles' in context menu pastes s | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "#a5d8ff", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "cross-hatch", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -3309,6 +3361,7 @@ exports[`contextMenu element > selecting 'Paste styles' in context menu pastes s | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "#a5d8ff", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "cross-hatch", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -3338,6 +3391,7 @@ exports[`contextMenu element > selecting 'Paste styles' in context menu pastes s | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "#a5d8ff", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "cross-hatch", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -3479,6 +3533,7 @@ exports[`contextMenu element > selecting 'Send backward' in context menu sends e | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -3511,6 +3566,7 @@ exports[`contextMenu element > selecting 'Send backward' in context menu sends e | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -3570,6 +3626,7 @@ exports[`contextMenu element > selecting 'Send backward' in context menu sends e | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -3613,6 +3670,7 @@ exports[`contextMenu element > selecting 'Send backward' in context menu sends e | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -3642,6 +3700,7 @@ exports[`contextMenu element > selecting 'Send backward' in context menu sends e | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -3685,6 +3744,7 @@ exports[`contextMenu element > selecting 'Send backward' in context menu sends e | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -3714,6 +3774,7 @@ exports[`contextMenu element > selecting 'Send backward' in context menu sends e | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -3855,6 +3916,7 @@ exports[`contextMenu element > selecting 'Send to back' in context menu sends el | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -3887,6 +3949,7 @@ exports[`contextMenu element > selecting 'Send to back' in context menu sends el | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -3946,6 +4009,7 @@ exports[`contextMenu element > selecting 'Send to back' in context menu sends el | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -3989,6 +4053,7 @@ exports[`contextMenu element > selecting 'Send to back' in context menu sends el | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -4018,6 +4083,7 @@ exports[`contextMenu element > selecting 'Send to back' in context menu sends el | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -4061,6 +4127,7 @@ exports[`contextMenu element > selecting 'Send to back' in context menu sends el | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -4090,6 +4157,7 @@ exports[`contextMenu element > selecting 'Send to back' in context menu sends el | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -4234,6 +4302,7 @@ exports[`contextMenu element > selecting 'Ungroup selection' in context menu ung | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -4266,6 +4335,7 @@ exports[`contextMenu element > selecting 'Ungroup selection' in context menu ung | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -4325,6 +4395,7 @@ exports[`contextMenu element > selecting 'Ungroup selection' in context menu ung | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -4368,6 +4439,7 @@ exports[`contextMenu element > selecting 'Ungroup selection' in context menu ung | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -4397,6 +4469,7 @@ exports[`contextMenu element > selecting 'Ungroup selection' in context menu ung | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -4443,6 +4516,7 @@ exports[`contextMenu element > selecting 'Ungroup selection' in context menu ung | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [ | ||||
| @@ -4474,6 +4548,7 @@ exports[`contextMenu element > selecting 'Ungroup selection' in context menu ung | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [ | ||||
| @@ -4520,6 +4595,7 @@ exports[`contextMenu element > selecting 'Ungroup selection' in context menu ung | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -4549,6 +4625,7 @@ exports[`contextMenu element > selecting 'Ungroup selection' in context menu ung | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -4966,6 +5043,7 @@ exports[`contextMenu element > shows 'Group selection' in context menu for multi | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -4998,6 +5076,7 @@ exports[`contextMenu element > shows 'Group selection' in context menu for multi | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -5057,6 +5136,7 @@ exports[`contextMenu element > shows 'Group selection' in context menu for multi | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -5100,6 +5180,7 @@ exports[`contextMenu element > shows 'Group selection' in context menu for multi | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -5129,6 +5210,7 @@ exports[`contextMenu element > shows 'Group selection' in context menu for multi | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -5548,6 +5630,7 @@ exports[`contextMenu element > shows 'Ungroup selection' in context menu for gro | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [ | ||||
| @@ -5582,6 +5665,7 @@ exports[`contextMenu element > shows 'Ungroup selection' in context menu for gro | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [ | ||||
| @@ -5643,6 +5727,7 @@ exports[`contextMenu element > shows 'Ungroup selection' in context menu for gro | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -5686,6 +5771,7 @@ exports[`contextMenu element > shows 'Ungroup selection' in context menu for gro | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -5715,6 +5801,7 @@ exports[`contextMenu element > shows 'Ungroup selection' in context menu for gro | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
| @@ -5761,6 +5848,7 @@ exports[`contextMenu element > shows 'Ungroup selection' in context menu for gro | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [ | ||||
| @@ -5792,6 +5880,7 @@ exports[`contextMenu element > shows 'Ungroup selection' in context menu for gro | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [ | ||||
| @@ -6838,6 +6927,7 @@ exports[`contextMenu element > shows context menu for element > [end of test] el | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -6870,6 +6960,7 @@ exports[`contextMenu element > shows context menu for element > [end of test] el | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "red", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -6902,6 +6993,7 @@ exports[`contextMenu element > shows context menu for element > [end of test] el | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "red", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -6961,6 +7053,7 @@ exports[`contextMenu element > shows context menu for element > [end of test] hi | ||||
|           "angle": 0, | ||||
|           "backgroundColor": "transparent", | ||||
|           "boundElements": null, | ||||
|           "customData": undefined, | ||||
|           "fillStyle": "solid", | ||||
|           "frameId": null, | ||||
|           "groupIds": [], | ||||
|   | ||||
| @@ -7,6 +7,7 @@ exports[`Test dragCreate > add element to the scene when pointer dragging long e | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "endArrowhead": "arrow", | ||||
|   "endBinding": null, | ||||
|   "fillStyle": "solid", | ||||
| @@ -56,6 +57,7 @@ exports[`Test dragCreate > add element to the scene when pointer dragging long e | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -90,6 +92,7 @@ exports[`Test dragCreate > add element to the scene when pointer dragging long e | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -122,6 +125,7 @@ exports[`Test dragCreate > add element to the scene when pointer dragging long e | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "endArrowhead": null, | ||||
|   "endBinding": null, | ||||
|   "fillStyle": "solid", | ||||
| @@ -171,6 +175,7 @@ exports[`Test dragCreate > add element to the scene when pointer dragging long e | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
|   | ||||
| @@ -5,6 +5,7 @@ exports[`duplicate element on move when ALT is clicked > rectangle 1`] = ` | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -37,6 +38,7 @@ exports[`duplicate element on move when ALT is clicked > rectangle 2`] = ` | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -69,6 +71,7 @@ exports[`move element > rectangle 1`] = ` | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -106,6 +109,7 @@ exports[`move element > rectangles with binding arrow 1`] = ` | ||||
|       "type": "arrow", | ||||
|     }, | ||||
|   ], | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -143,6 +147,7 @@ exports[`move element > rectangles with binding arrow 2`] = ` | ||||
|       "type": "arrow", | ||||
|     }, | ||||
|   ], | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -175,6 +180,7 @@ exports[`move element > rectangles with binding arrow 3`] = ` | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "endArrowhead": null, | ||||
|   "endBinding": { | ||||
|     "elementId": "id1", | ||||
|   | ||||
| @@ -5,6 +5,7 @@ exports[`multi point mode in linear elements > arrow 1`] = ` | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "endArrowhead": "arrow", | ||||
|   "endBinding": null, | ||||
|   "fillStyle": "solid", | ||||
| @@ -59,6 +60,7 @@ exports[`multi point mode in linear elements > line 1`] = ` | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "endArrowhead": null, | ||||
|   "endBinding": null, | ||||
|   "fillStyle": "solid", | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -5,6 +5,7 @@ exports[`select single element on the scene > arrow 1`] = ` | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "endArrowhead": "arrow", | ||||
|   "endBinding": null, | ||||
|   "fillStyle": "solid", | ||||
| @@ -52,6 +53,7 @@ exports[`select single element on the scene > arrow escape 1`] = ` | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "endArrowhead": null, | ||||
|   "endBinding": null, | ||||
|   "fillStyle": "solid", | ||||
| @@ -99,6 +101,7 @@ exports[`select single element on the scene > diamond 1`] = ` | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -131,6 +134,7 @@ exports[`select single element on the scene > ellipse 1`] = ` | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -163,6 +167,7 @@ exports[`select single element on the scene > rectangle 1`] = ` | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
|   | ||||
| @@ -5,6 +5,7 @@ exports[`restoreElements > should restore arrow element correctly 1`] = ` | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": [], | ||||
|   "customData": undefined, | ||||
|   "endArrowhead": null, | ||||
|   "endBinding": null, | ||||
|   "fillStyle": "solid", | ||||
| @@ -52,6 +53,7 @@ exports[`restoreElements > should restore correctly with rectangle, ellipse and | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "blue", | ||||
|   "boundElements": [], | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "cross-hatch", | ||||
|   "frameId": null, | ||||
|   "groupIds": [ | ||||
| @@ -88,6 +90,7 @@ exports[`restoreElements > should restore correctly with rectangle, ellipse and | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "blue", | ||||
|   "boundElements": [], | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "cross-hatch", | ||||
|   "frameId": null, | ||||
|   "groupIds": [ | ||||
| @@ -124,6 +127,7 @@ exports[`restoreElements > should restore correctly with rectangle, ellipse and | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "blue", | ||||
|   "boundElements": [], | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "cross-hatch", | ||||
|   "frameId": null, | ||||
|   "groupIds": [ | ||||
| @@ -160,6 +164,7 @@ exports[`restoreElements > should restore freedraw element correctly 1`] = ` | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": [], | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "frameId": null, | ||||
|   "groupIds": [], | ||||
| @@ -196,6 +201,7 @@ exports[`restoreElements > should restore line and draw elements correctly 1`] = | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": [], | ||||
|   "customData": undefined, | ||||
|   "endArrowhead": null, | ||||
|   "endBinding": null, | ||||
|   "fillStyle": "solid", | ||||
| @@ -243,6 +249,7 @@ exports[`restoreElements > should restore line and draw elements correctly 2`] = | ||||
|   "angle": 0, | ||||
|   "backgroundColor": "transparent", | ||||
|   "boundElements": [], | ||||
|   "customData": undefined, | ||||
|   "endArrowhead": null, | ||||
|   "endBinding": null, | ||||
|   "fillStyle": "solid", | ||||
| @@ -292,6 +299,7 @@ exports[`restoreElements > should restore text element correctly passing value f | ||||
|   "baseline": 0, | ||||
|   "boundElements": [], | ||||
|   "containerId": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "fontFamily": 1, | ||||
|   "fontSize": 14, | ||||
| @@ -333,6 +341,7 @@ exports[`restoreElements > should restore text element correctly with unknown fo | ||||
|   "baseline": 0, | ||||
|   "boundElements": [], | ||||
|   "containerId": null, | ||||
|   "customData": undefined, | ||||
|   "fillStyle": "solid", | ||||
|   "fontFamily": 1, | ||||
|   "fontSize": 10, | ||||
|   | ||||
		Reference in New Issue
	
	Block a user