Compare commits
33 Commits
master
...
ryan-di/fr
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
86605829c6 | ||
|
|
c398af6c92 | ||
|
|
973f2a464d | ||
|
|
02cef5ea92 | ||
|
|
d615c2cea1 | ||
|
|
446f871536 | ||
|
|
34bff557e3 | ||
|
|
a0e54e3768 | ||
|
|
d6ec1dc7e6 | ||
|
|
62e20aa247 | ||
|
|
0199c82e98 | ||
|
|
3c07ff358a | ||
|
|
d9c85ff18f | ||
|
|
6d84fa21c5 | ||
|
|
5666fd8199 | ||
|
|
abdacf8239 | ||
|
|
1068153b25 | ||
|
|
09876aba6d | ||
|
|
8ceb55dd02 | ||
|
|
b1f3cc50ee | ||
|
|
c72c47f0cd | ||
|
|
37b75263f8 | ||
|
|
c08840358b | ||
|
|
e99baaa6bb | ||
|
|
a8857f2849 | ||
|
|
df1f9281b4 | ||
|
|
c210b7b092 | ||
|
|
660d21fe46 | ||
|
|
c7780cb9cb | ||
|
|
4e265629c3 | ||
|
|
1c611d6c4f | ||
|
|
ab6af41d33 | ||
|
|
15dfe0cc7c |
@ -134,6 +134,7 @@ import DebugCanvas, {
|
|||||||
} from "./components/DebugCanvas";
|
} from "./components/DebugCanvas";
|
||||||
import { AIComponents } from "./components/AI";
|
import { AIComponents } from "./components/AI";
|
||||||
import { ExcalidrawPlusIframeExport } from "./ExcalidrawPlusIframeExport";
|
import { ExcalidrawPlusIframeExport } from "./ExcalidrawPlusIframeExport";
|
||||||
|
import { FreedrawDebugSliders } from "./components/FreedrawDebugSliders";
|
||||||
|
|
||||||
import "./index.scss";
|
import "./index.scss";
|
||||||
|
|
||||||
@ -1142,6 +1143,7 @@ const ExcalidrawWrapper = () => {
|
|||||||
ref={debugCanvasRef}
|
ref={debugCanvasRef}
|
||||||
/>
|
/>
|
||||||
)}
|
)}
|
||||||
|
{/* <FreedrawDebugSliders /> */}
|
||||||
</Excalidraw>
|
</Excalidraw>
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
|
|||||||
150
excalidraw-app/components/FreedrawDebugSliders.tsx
Normal file
150
excalidraw-app/components/FreedrawDebugSliders.tsx
Normal file
@ -0,0 +1,150 @@
|
|||||||
|
import { STROKE_OPTIONS, isFreeDrawElement } from "@excalidraw/element";
|
||||||
|
import { useState, useEffect } from "react";
|
||||||
|
|
||||||
|
import { useUIAppState } from "@excalidraw/excalidraw/context/ui-appState";
|
||||||
|
import { useExcalidrawElements } from "@excalidraw/excalidraw/components/App";
|
||||||
|
|
||||||
|
import { round } from "../../packages/math/src";
|
||||||
|
|
||||||
|
export const FreedrawDebugSliders = () => {
|
||||||
|
const [streamline, setStreamline] = useState<number>(
|
||||||
|
STROKE_OPTIONS.default.streamline,
|
||||||
|
);
|
||||||
|
const [simplify, setSimplify] = useState<number>(
|
||||||
|
STROKE_OPTIONS.default.simplify,
|
||||||
|
);
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
if (!window.h) {
|
||||||
|
window.h = {} as any;
|
||||||
|
}
|
||||||
|
if (!window.h.debugFreedraw) {
|
||||||
|
window.h.debugFreedraw = {
|
||||||
|
enabled: true,
|
||||||
|
...STROKE_OPTIONS.default,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
setStreamline(window.h.debugFreedraw.streamline);
|
||||||
|
setSimplify(window.h.debugFreedraw.simplify);
|
||||||
|
}, []);
|
||||||
|
|
||||||
|
const handleStreamlineChange = (value: number) => {
|
||||||
|
setStreamline(value);
|
||||||
|
if (window.h && window.h.debugFreedraw) {
|
||||||
|
window.h.debugFreedraw.streamline = value;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
const handleSimplifyChange = (value: number) => {
|
||||||
|
setSimplify(value);
|
||||||
|
if (window.h && window.h.debugFreedraw) {
|
||||||
|
window.h.debugFreedraw.simplify = value;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
const [enabled, setEnabled] = useState<boolean>(
|
||||||
|
window.h?.debugFreedraw?.enabled ?? true,
|
||||||
|
);
|
||||||
|
|
||||||
|
// counter incrasing each 50ms
|
||||||
|
const [, setCounter] = useState<number>(0);
|
||||||
|
useEffect(() => {
|
||||||
|
const interval = setInterval(() => {
|
||||||
|
setCounter((prev) => prev + 1);
|
||||||
|
}, 50);
|
||||||
|
|
||||||
|
return () => clearInterval(interval);
|
||||||
|
}, []);
|
||||||
|
|
||||||
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
||||||
|
const elements = useExcalidrawElements();
|
||||||
|
const appState = useUIAppState();
|
||||||
|
|
||||||
|
const newFreedrawElement =
|
||||||
|
appState.newElement && isFreeDrawElement(appState.newElement)
|
||||||
|
? appState.newElement
|
||||||
|
: null;
|
||||||
|
|
||||||
|
return (
|
||||||
|
<div
|
||||||
|
style={{
|
||||||
|
position: "absolute",
|
||||||
|
bottom: "70px",
|
||||||
|
left: "50%",
|
||||||
|
transform: "translateX(-50%)",
|
||||||
|
zIndex: 9999,
|
||||||
|
padding: "10px",
|
||||||
|
borderRadius: "8px",
|
||||||
|
border: "1px solid #ccc",
|
||||||
|
display: "flex",
|
||||||
|
flexDirection: "column",
|
||||||
|
gap: "8px",
|
||||||
|
fontSize: "12px",
|
||||||
|
fontFamily: "monospace",
|
||||||
|
}}
|
||||||
|
>
|
||||||
|
{newFreedrawElement && (
|
||||||
|
<div>
|
||||||
|
pressures:{" "}
|
||||||
|
{newFreedrawElement.simulatePressure
|
||||||
|
? "simulated"
|
||||||
|
: JSON.stringify(
|
||||||
|
newFreedrawElement.pressures
|
||||||
|
.slice(-4)
|
||||||
|
.map((x) => round(x, 2))
|
||||||
|
.join(" ") || [],
|
||||||
|
)}{" "}
|
||||||
|
({round(window.__lastPressure__ || 0, 2) || "?"})
|
||||||
|
</div>
|
||||||
|
)}
|
||||||
|
<div>
|
||||||
|
<label>
|
||||||
|
{" "}
|
||||||
|
enabled
|
||||||
|
<br />
|
||||||
|
<input
|
||||||
|
type="checkbox"
|
||||||
|
checked={enabled}
|
||||||
|
onChange={(e) => {
|
||||||
|
if (window.h.debugFreedraw) {
|
||||||
|
window.h.debugFreedraw.enabled = e.target.checked;
|
||||||
|
setEnabled(e.target.checked);
|
||||||
|
}
|
||||||
|
}}
|
||||||
|
/>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<label>
|
||||||
|
Streamline: {streamline.toFixed(2)}
|
||||||
|
<br />
|
||||||
|
<input
|
||||||
|
type="range"
|
||||||
|
min="0"
|
||||||
|
max="1"
|
||||||
|
step="0.01"
|
||||||
|
value={streamline}
|
||||||
|
onChange={(e) => handleStreamlineChange(parseFloat(e.target.value))}
|
||||||
|
style={{ width: "150px" }}
|
||||||
|
/>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<label>
|
||||||
|
Simplify: {simplify.toFixed(2)}
|
||||||
|
<br />
|
||||||
|
<input
|
||||||
|
type="range"
|
||||||
|
min="0"
|
||||||
|
max="1"
|
||||||
|
step="0.01"
|
||||||
|
value={simplify}
|
||||||
|
onChange={(e) => handleSimplifyChange(parseFloat(e.target.value))}
|
||||||
|
style={{ width: "150px" }}
|
||||||
|
/>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
);
|
||||||
|
};
|
||||||
@ -1,34 +0,0 @@
|
|||||||
import { defaultLang } from "@excalidraw/excalidraw/i18n";
|
|
||||||
import { UI } from "@excalidraw/excalidraw/tests/helpers/ui";
|
|
||||||
import {
|
|
||||||
screen,
|
|
||||||
fireEvent,
|
|
||||||
waitFor,
|
|
||||||
render,
|
|
||||||
} from "@excalidraw/excalidraw/tests/test-utils";
|
|
||||||
|
|
||||||
import ExcalidrawApp from "../App";
|
|
||||||
|
|
||||||
describe("Test LanguageList", () => {
|
|
||||||
it("rerenders UI on language change", async () => {
|
|
||||||
await render(<ExcalidrawApp />);
|
|
||||||
|
|
||||||
// select rectangle tool to show properties menu
|
|
||||||
UI.clickTool("rectangle");
|
|
||||||
// english lang should display `thin` label
|
|
||||||
expect(screen.queryByTitle(/thin/i)).not.toBeNull();
|
|
||||||
fireEvent.click(document.querySelector(".dropdown-menu-button")!);
|
|
||||||
|
|
||||||
fireEvent.change(document.querySelector(".dropdown-select__language")!, {
|
|
||||||
target: { value: "de-DE" },
|
|
||||||
});
|
|
||||||
// switching to german, `thin` label should no longer exist
|
|
||||||
await waitFor(() => expect(screen.queryByTitle(/thin/i)).toBeNull());
|
|
||||||
// reset language
|
|
||||||
fireEvent.change(document.querySelector(".dropdown-select__language")!, {
|
|
||||||
target: { value: defaultLang.code },
|
|
||||||
});
|
|
||||||
// switching back to English
|
|
||||||
await waitFor(() => expect(screen.queryByTitle(/thin/i)).not.toBeNull());
|
|
||||||
});
|
|
||||||
});
|
|
||||||
@ -415,8 +415,9 @@ export const ROUGHNESS = {
|
|||||||
|
|
||||||
export const STROKE_WIDTH = {
|
export const STROKE_WIDTH = {
|
||||||
thin: 1,
|
thin: 1,
|
||||||
bold: 2,
|
medium: 2,
|
||||||
extraBold: 4,
|
bold: 4,
|
||||||
|
extraBold: 8,
|
||||||
} as const;
|
} as const;
|
||||||
|
|
||||||
export const DEFAULT_ELEMENT_PROPS: {
|
export const DEFAULT_ELEMENT_PROPS: {
|
||||||
@ -432,7 +433,7 @@ export const DEFAULT_ELEMENT_PROPS: {
|
|||||||
strokeColor: COLOR_PALETTE.black,
|
strokeColor: COLOR_PALETTE.black,
|
||||||
backgroundColor: COLOR_PALETTE.transparent,
|
backgroundColor: COLOR_PALETTE.transparent,
|
||||||
fillStyle: "solid",
|
fillStyle: "solid",
|
||||||
strokeWidth: 2,
|
strokeWidth: STROKE_WIDTH.medium,
|
||||||
strokeStyle: "solid",
|
strokeStyle: "solid",
|
||||||
roughness: ROUGHNESS.artist,
|
roughness: ROUGHNESS.artist,
|
||||||
opacity: 100,
|
opacity: 100,
|
||||||
|
|||||||
@ -5,6 +5,7 @@ import {
|
|||||||
invariant,
|
invariant,
|
||||||
rescalePoints,
|
rescalePoints,
|
||||||
sizeOf,
|
sizeOf,
|
||||||
|
STROKE_WIDTH,
|
||||||
} from "@excalidraw/common";
|
} from "@excalidraw/common";
|
||||||
|
|
||||||
import {
|
import {
|
||||||
@ -808,9 +809,15 @@ export const getArrowheadPoints = (
|
|||||||
// This value is selected by minimizing a minimum size with the last segment of the arrowhead
|
// This value is selected by minimizing a minimum size with the last segment of the arrowhead
|
||||||
const lengthMultiplier =
|
const lengthMultiplier =
|
||||||
arrowhead === "diamond" || arrowhead === "diamond_outline" ? 0.25 : 0.5;
|
arrowhead === "diamond" || arrowhead === "diamond_outline" ? 0.25 : 0.5;
|
||||||
const minSize = Math.min(size, length * lengthMultiplier);
|
// make arrowheads bigger for thick strokes
|
||||||
const xs = x2 - nx * minSize;
|
const strokeWidthMultiplier =
|
||||||
const ys = y2 - ny * minSize;
|
element.strokeWidth >= STROKE_WIDTH.extraBold ? 1.5 : 1;
|
||||||
|
|
||||||
|
const adjustedSize =
|
||||||
|
Math.min(size, length * lengthMultiplier) * strokeWidthMultiplier;
|
||||||
|
|
||||||
|
const xs = x2 - nx * adjustedSize;
|
||||||
|
const ys = y2 - ny * adjustedSize;
|
||||||
|
|
||||||
if (
|
if (
|
||||||
arrowhead === "dot" ||
|
arrowhead === "dot" ||
|
||||||
@ -859,7 +866,7 @@ export const getArrowheadPoints = (
|
|||||||
const [px, py] = element.points.length > 1 ? element.points[1] : [0, 0];
|
const [px, py] = element.points.length > 1 ? element.points[1] : [0, 0];
|
||||||
|
|
||||||
[ox, oy] = pointRotateRads(
|
[ox, oy] = pointRotateRads(
|
||||||
pointFrom(x2 + minSize * 2, y2),
|
pointFrom(x2 + adjustedSize * 2, y2),
|
||||||
pointFrom(x2, y2),
|
pointFrom(x2, y2),
|
||||||
Math.atan2(py - y2, px - x2) as Radians,
|
Math.atan2(py - y2, px - x2) as Radians,
|
||||||
);
|
);
|
||||||
@ -870,7 +877,7 @@ export const getArrowheadPoints = (
|
|||||||
: [0, 0];
|
: [0, 0];
|
||||||
|
|
||||||
[ox, oy] = pointRotateRads(
|
[ox, oy] = pointRotateRads(
|
||||||
pointFrom(x2 - minSize * 2, y2),
|
pointFrom(x2 - adjustedSize * 2, y2),
|
||||||
pointFrom(x2, y2),
|
pointFrom(x2, y2),
|
||||||
Math.atan2(y2 - py, x2 - px) as Radians,
|
Math.atan2(y2 - py, x2 - px) as Radians,
|
||||||
);
|
);
|
||||||
|
|||||||
278
packages/element/src/freedraw.ts
Normal file
278
packages/element/src/freedraw.ts
Normal file
@ -0,0 +1,278 @@
|
|||||||
|
import { LaserPointer, type Point } from "@excalidraw/laser-pointer";
|
||||||
|
|
||||||
|
import { clamp, round, type LocalPoint } from "@excalidraw/math";
|
||||||
|
|
||||||
|
import getStroke from "perfect-freehand";
|
||||||
|
|
||||||
|
import type { StrokeOptions } from "perfect-freehand";
|
||||||
|
|
||||||
|
import type { ExcalidrawFreeDrawElement, PointerType } from "./types";
|
||||||
|
|
||||||
|
export const STROKE_OPTIONS: Record<
|
||||||
|
PointerType | "default",
|
||||||
|
{ streamline: number; simplify: number }
|
||||||
|
> = {
|
||||||
|
default: {
|
||||||
|
streamline: 0.35,
|
||||||
|
simplify: 0.1,
|
||||||
|
},
|
||||||
|
mouse: {
|
||||||
|
streamline: 0.6,
|
||||||
|
simplify: 0.1,
|
||||||
|
},
|
||||||
|
pen: {
|
||||||
|
// for optimal performance, we use a lower streamline and simplify
|
||||||
|
streamline: 0.2,
|
||||||
|
simplify: 0.1,
|
||||||
|
},
|
||||||
|
touch: {
|
||||||
|
streamline: 0.65,
|
||||||
|
simplify: 0.1,
|
||||||
|
},
|
||||||
|
} as const;
|
||||||
|
|
||||||
|
export const getFreedrawConfig = (eventType: string | null | undefined) => {
|
||||||
|
return (
|
||||||
|
STROKE_OPTIONS[(eventType as PointerType | null) || "default"] ||
|
||||||
|
STROKE_OPTIONS.default
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Calculates simulated pressure based on velocity between consecutive points.
|
||||||
|
* Fast movement (large distances) -> lower pressure
|
||||||
|
* Slow movement (small distances) -> higher pressure
|
||||||
|
*/
|
||||||
|
const calculateVelocityBasedPressure = (
|
||||||
|
points: readonly LocalPoint[],
|
||||||
|
index: number,
|
||||||
|
fixedStrokeWidth: boolean | undefined,
|
||||||
|
maxDistance = 8, // Maximum expected distance for normalization
|
||||||
|
): number => {
|
||||||
|
if (fixedStrokeWidth) {
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
// First point gets highest pressure
|
||||||
|
// This avoid "a dot followed by a line" effect, •== when first stroke is "slow"
|
||||||
|
if (index === 0) {
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
const [x1, y1] = points[index - 1];
|
||||||
|
const [x2, y2] = points[index];
|
||||||
|
|
||||||
|
// Calculate distance between consecutive points
|
||||||
|
const distance = Math.sqrt((x2 - x1) ** 2 + (y2 - y1) ** 2);
|
||||||
|
|
||||||
|
// Normalize distance and invert for pressure (0 = fast/low pressure, 1 = slow/high pressure)
|
||||||
|
const normalizedDistance = Math.min(distance / maxDistance, 1);
|
||||||
|
const basePressure = Math.max(0.1, 1 - normalizedDistance * 0.7); // Range: 0.1 to 1.0
|
||||||
|
|
||||||
|
const constantPressure = 0.5;
|
||||||
|
const pressure = constantPressure + (basePressure - constantPressure);
|
||||||
|
|
||||||
|
return Math.max(0.1, Math.min(1.0, pressure));
|
||||||
|
};
|
||||||
|
|
||||||
|
export const getFreedrawStroke = (element: ExcalidrawFreeDrawElement) => {
|
||||||
|
// Compose points as [x, y, pressure]
|
||||||
|
let points: [number, number, number][];
|
||||||
|
if (element.freedrawOptions?.fixedStrokeWidth) {
|
||||||
|
points = element.points.map(
|
||||||
|
([x, y]: LocalPoint): [number, number, number] => [x, y, 1],
|
||||||
|
);
|
||||||
|
} else if (element.simulatePressure) {
|
||||||
|
// Simulate pressure based on velocity between consecutive points
|
||||||
|
points = element.points.map(([x, y]: LocalPoint, i) => [
|
||||||
|
x,
|
||||||
|
y,
|
||||||
|
calculateVelocityBasedPressure(
|
||||||
|
element.points,
|
||||||
|
i,
|
||||||
|
element.freedrawOptions?.fixedStrokeWidth,
|
||||||
|
),
|
||||||
|
]);
|
||||||
|
} else {
|
||||||
|
points = element.points.map(([x, y]: LocalPoint, i) => {
|
||||||
|
const rawPressure = element.pressures?.[i] ?? 0.5;
|
||||||
|
|
||||||
|
const amplifiedPressure = Math.pow(rawPressure, 0.6);
|
||||||
|
const adjustedPressure = amplifiedPressure;
|
||||||
|
|
||||||
|
return [x, y, clamp(adjustedPressure, 0.1, 1.0)];
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
const streamline =
|
||||||
|
element.freedrawOptions?.streamline ?? STROKE_OPTIONS.default.streamline;
|
||||||
|
const simplify =
|
||||||
|
element.freedrawOptions?.simplify ?? STROKE_OPTIONS.default.simplify;
|
||||||
|
|
||||||
|
const laser = new LaserPointer({
|
||||||
|
size: element.strokeWidth,
|
||||||
|
streamline,
|
||||||
|
simplify,
|
||||||
|
sizeMapping: ({ pressure: t }) => {
|
||||||
|
if (element.freedrawOptions?.fixedStrokeWidth) {
|
||||||
|
return 0.6;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (element.simulatePressure) {
|
||||||
|
return 0.2 + t * 0.6;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0.2 + t * 0.8;
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
for (const pt of points) {
|
||||||
|
laser.addPoint(pt);
|
||||||
|
}
|
||||||
|
laser.close();
|
||||||
|
|
||||||
|
return laser.getStrokeOutline();
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Generates an SVG path for a freedraw element using LaserPointer logic.
|
||||||
|
* Uses actual pressure data if available, otherwise simulates pressure based on velocity.
|
||||||
|
* No streamline, smoothing, or simulation is performed.
|
||||||
|
*/
|
||||||
|
export const getFreeDrawSvgPath = (
|
||||||
|
element: ExcalidrawFreeDrawElement,
|
||||||
|
): string => {
|
||||||
|
// legacy, for backwards compatibility
|
||||||
|
if (element.freedrawOptions === null) {
|
||||||
|
return _legacy_getFreeDrawSvgPath(element);
|
||||||
|
}
|
||||||
|
|
||||||
|
return _transition_getFreeDrawSvgPath(element);
|
||||||
|
|
||||||
|
// return getSvgPathFromStroke(getFreedrawStroke(element));
|
||||||
|
};
|
||||||
|
|
||||||
|
const roundPoint = (A: Point): string => {
|
||||||
|
return `${round(A[0], 4, "round")},${round(A[1], 4, "round")} `;
|
||||||
|
};
|
||||||
|
|
||||||
|
const average = (A: Point, B: Point): string => {
|
||||||
|
return `${round((A[0] + B[0]) / 2, 4, "round")},${round(
|
||||||
|
(A[1] + B[1]) / 2,
|
||||||
|
4,
|
||||||
|
"round",
|
||||||
|
)} `;
|
||||||
|
};
|
||||||
|
|
||||||
|
export const getSvgPathFromStroke = (points: Point[]): string => {
|
||||||
|
const len = points.length;
|
||||||
|
|
||||||
|
if (len < 2) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
let a = points[0];
|
||||||
|
let b = points[1];
|
||||||
|
|
||||||
|
if (len === 2) {
|
||||||
|
return `M${roundPoint(a)}L${roundPoint(b)}`;
|
||||||
|
}
|
||||||
|
|
||||||
|
let result = "";
|
||||||
|
|
||||||
|
for (let i = 2, max = len - 1; i < max; i++) {
|
||||||
|
a = points[i];
|
||||||
|
b = points[i + 1];
|
||||||
|
result += average(a, b);
|
||||||
|
}
|
||||||
|
|
||||||
|
return `M${roundPoint(points[0])}Q${roundPoint(points[1])}${average(
|
||||||
|
points[1],
|
||||||
|
points[2],
|
||||||
|
)}${points.length > 3 ? "T" : ""}${result}L${roundPoint(points[len - 1])}`;
|
||||||
|
};
|
||||||
|
|
||||||
|
function _transition_getFreeDrawSvgPath(element: ExcalidrawFreeDrawElement) {
|
||||||
|
const inputPoints = element.simulatePressure
|
||||||
|
? element.points
|
||||||
|
: element.points.length
|
||||||
|
? element.points.map(([x, y], i) => [x, y, element.pressures[i]])
|
||||||
|
: [[0, 0, 0.5]];
|
||||||
|
|
||||||
|
// Consider changing the options for simulated pressure vs real pressure
|
||||||
|
const options: StrokeOptions = {
|
||||||
|
simulatePressure: element.simulatePressure,
|
||||||
|
size: element.strokeWidth,
|
||||||
|
thinning: 0.6,
|
||||||
|
smoothing: 0.5,
|
||||||
|
streamline: 0.5,
|
||||||
|
easing: (t) => {
|
||||||
|
if (element.freedrawOptions?.fixedStrokeWidth) {
|
||||||
|
return 0.5;
|
||||||
|
}
|
||||||
|
|
||||||
|
return Math.sin((t * Math.PI) / 2) * 0.65;
|
||||||
|
}, // https://easings.net/#easeOutSine
|
||||||
|
last: !!element.lastCommittedPoint, // LastCommittedPoint is added on pointerup
|
||||||
|
};
|
||||||
|
|
||||||
|
return _legacy_getSvgPathFromStroke(
|
||||||
|
getStroke(inputPoints as number[][], options),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
function _legacy_getFreeDrawSvgPath(element: ExcalidrawFreeDrawElement) {
|
||||||
|
// If input points are empty (should they ever be?) return a dot
|
||||||
|
const inputPoints = element.simulatePressure
|
||||||
|
? element.points
|
||||||
|
: element.points.length
|
||||||
|
? element.points.map(([x, y], i) => [x, y, element.pressures[i]])
|
||||||
|
: [[0, 0, 0.5]];
|
||||||
|
|
||||||
|
// Consider changing the options for simulated pressure vs real pressure
|
||||||
|
const options: StrokeOptions = {
|
||||||
|
simulatePressure: element.simulatePressure,
|
||||||
|
size: element.strokeWidth * 4.25,
|
||||||
|
thinning: 0.6,
|
||||||
|
smoothing: 0.5,
|
||||||
|
streamline: 0.5,
|
||||||
|
easing: (t) => Math.sin((t * Math.PI) / 2), // https://easings.net/#easeOutSine
|
||||||
|
last: !!element.lastCommittedPoint, // LastCommittedPoint is added on pointerup
|
||||||
|
};
|
||||||
|
|
||||||
|
return _legacy_getSvgPathFromStroke(
|
||||||
|
getStroke(inputPoints as number[][], options),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
const med = (A: number[], B: number[]) => {
|
||||||
|
return [(A[0] + B[0]) / 2, (A[1] + B[1]) / 2];
|
||||||
|
};
|
||||||
|
|
||||||
|
// Trim SVG path data so number are each two decimal points. This
|
||||||
|
// improves SVG exports, and prevents rendering errors on points
|
||||||
|
// with long decimals.
|
||||||
|
const TO_FIXED_PRECISION = /(\s?[A-Z]?,?-?[0-9]*\.[0-9]{0,2})(([0-9]|e|-)*)/g;
|
||||||
|
|
||||||
|
const _legacy_getSvgPathFromStroke = (points: number[][]): string => {
|
||||||
|
if (!points.length) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
const max = points.length - 1;
|
||||||
|
|
||||||
|
return points
|
||||||
|
.reduce(
|
||||||
|
(acc, point, i, arr) => {
|
||||||
|
if (i === max) {
|
||||||
|
acc.push(point, med(point, arr[0]), "L", arr[0], "Z");
|
||||||
|
} else {
|
||||||
|
acc.push(point, med(point, arr[i + 1]));
|
||||||
|
}
|
||||||
|
return acc;
|
||||||
|
},
|
||||||
|
["M", points[0], "Q"],
|
||||||
|
)
|
||||||
|
.join(" ")
|
||||||
|
.replace(TO_FIXED_PRECISION, "$1");
|
||||||
|
};
|
||||||
@ -91,6 +91,7 @@ export * from "./embeddable";
|
|||||||
export * from "./flowchart";
|
export * from "./flowchart";
|
||||||
export * from "./fractionalIndex";
|
export * from "./fractionalIndex";
|
||||||
export * from "./frame";
|
export * from "./frame";
|
||||||
|
export * from "./freedraw";
|
||||||
export * from "./groups";
|
export * from "./groups";
|
||||||
export * from "./heading";
|
export * from "./heading";
|
||||||
export * from "./image";
|
export * from "./image";
|
||||||
|
|||||||
@ -445,6 +445,7 @@ export const newFreeDrawElement = (
|
|||||||
points?: ExcalidrawFreeDrawElement["points"];
|
points?: ExcalidrawFreeDrawElement["points"];
|
||||||
simulatePressure: boolean;
|
simulatePressure: boolean;
|
||||||
pressures?: ExcalidrawFreeDrawElement["pressures"];
|
pressures?: ExcalidrawFreeDrawElement["pressures"];
|
||||||
|
strokeOptions?: ExcalidrawFreeDrawElement["freedrawOptions"];
|
||||||
} & ElementConstructorOpts,
|
} & ElementConstructorOpts,
|
||||||
): NonDeleted<ExcalidrawFreeDrawElement> => {
|
): NonDeleted<ExcalidrawFreeDrawElement> => {
|
||||||
return {
|
return {
|
||||||
@ -453,6 +454,11 @@ export const newFreeDrawElement = (
|
|||||||
pressures: opts.pressures || [],
|
pressures: opts.pressures || [],
|
||||||
simulatePressure: opts.simulatePressure,
|
simulatePressure: opts.simulatePressure,
|
||||||
lastCommittedPoint: null,
|
lastCommittedPoint: null,
|
||||||
|
freedrawOptions: opts.strokeOptions || {
|
||||||
|
fixedStrokeWidth: true,
|
||||||
|
streamline: 0.25,
|
||||||
|
simplify: 0.1,
|
||||||
|
},
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
@ -1,5 +1,4 @@
|
|||||||
import rough from "roughjs/bin/rough";
|
import rough from "roughjs/bin/rough";
|
||||||
import { getStroke } from "perfect-freehand";
|
|
||||||
|
|
||||||
import { isRightAngleRads } from "@excalidraw/math";
|
import { isRightAngleRads } from "@excalidraw/math";
|
||||||
|
|
||||||
@ -58,6 +57,8 @@ import { getCornerRadius } from "./utils";
|
|||||||
|
|
||||||
import { ShapeCache } from "./shape";
|
import { ShapeCache } from "./shape";
|
||||||
|
|
||||||
|
import { getFreeDrawSvgPath } from "./freedraw";
|
||||||
|
|
||||||
import type {
|
import type {
|
||||||
ExcalidrawElement,
|
ExcalidrawElement,
|
||||||
ExcalidrawTextElement,
|
ExcalidrawTextElement,
|
||||||
@ -70,7 +71,6 @@ import type {
|
|||||||
ElementsMap,
|
ElementsMap,
|
||||||
} from "./types";
|
} from "./types";
|
||||||
|
|
||||||
import type { StrokeOptions } from "perfect-freehand";
|
|
||||||
import type { RoughCanvas } from "roughjs/bin/canvas";
|
import type { RoughCanvas } from "roughjs/bin/canvas";
|
||||||
|
|
||||||
// using a stronger invert (100% vs our regular 93%) and saturate
|
// using a stronger invert (100% vs our regular 93%) and saturate
|
||||||
@ -1032,57 +1032,3 @@ export function generateFreeDrawShape(element: ExcalidrawFreeDrawElement) {
|
|||||||
export function getFreeDrawPath2D(element: ExcalidrawFreeDrawElement) {
|
export function getFreeDrawPath2D(element: ExcalidrawFreeDrawElement) {
|
||||||
return pathsCache.get(element);
|
return pathsCache.get(element);
|
||||||
}
|
}
|
||||||
|
|
||||||
export function getFreeDrawSvgPath(element: ExcalidrawFreeDrawElement) {
|
|
||||||
// If input points are empty (should they ever be?) return a dot
|
|
||||||
const inputPoints = element.simulatePressure
|
|
||||||
? element.points
|
|
||||||
: element.points.length
|
|
||||||
? element.points.map(([x, y], i) => [x, y, element.pressures[i]])
|
|
||||||
: [[0, 0, 0.5]];
|
|
||||||
|
|
||||||
// Consider changing the options for simulated pressure vs real pressure
|
|
||||||
const options: StrokeOptions = {
|
|
||||||
simulatePressure: element.simulatePressure,
|
|
||||||
size: element.strokeWidth * 4.25,
|
|
||||||
thinning: 0.6,
|
|
||||||
smoothing: 0.5,
|
|
||||||
streamline: 0.5,
|
|
||||||
easing: (t) => Math.sin((t * Math.PI) / 2), // https://easings.net/#easeOutSine
|
|
||||||
last: !!element.lastCommittedPoint, // LastCommittedPoint is added on pointerup
|
|
||||||
};
|
|
||||||
|
|
||||||
return getSvgPathFromStroke(getStroke(inputPoints as number[][], options));
|
|
||||||
}
|
|
||||||
|
|
||||||
function med(A: number[], B: number[]) {
|
|
||||||
return [(A[0] + B[0]) / 2, (A[1] + B[1]) / 2];
|
|
||||||
}
|
|
||||||
|
|
||||||
// Trim SVG path data so number are each two decimal points. This
|
|
||||||
// improves SVG exports, and prevents rendering errors on points
|
|
||||||
// with long decimals.
|
|
||||||
const TO_FIXED_PRECISION = /(\s?[A-Z]?,?-?[0-9]*\.[0-9]{0,2})(([0-9]|e|-)*)/g;
|
|
||||||
|
|
||||||
function getSvgPathFromStroke(points: number[][]): string {
|
|
||||||
if (!points.length) {
|
|
||||||
return "";
|
|
||||||
}
|
|
||||||
|
|
||||||
const max = points.length - 1;
|
|
||||||
|
|
||||||
return points
|
|
||||||
.reduce(
|
|
||||||
(acc, point, i, arr) => {
|
|
||||||
if (i === max) {
|
|
||||||
acc.push(point, med(point, arr[0]), "L", arr[0], "Z");
|
|
||||||
} else {
|
|
||||||
acc.push(point, med(point, arr[i + 1]));
|
|
||||||
}
|
|
||||||
return acc;
|
|
||||||
},
|
|
||||||
["M", points[0], "Q"],
|
|
||||||
)
|
|
||||||
.join(" ")
|
|
||||||
.replace(TO_FIXED_PRECISION, "$1");
|
|
||||||
}
|
|
||||||
|
|||||||
@ -21,6 +21,7 @@ import {
|
|||||||
assertNever,
|
assertNever,
|
||||||
COLOR_PALETTE,
|
COLOR_PALETTE,
|
||||||
LINE_POLYGON_POINT_MERGE_DISTANCE,
|
LINE_POLYGON_POINT_MERGE_DISTANCE,
|
||||||
|
STROKE_WIDTH,
|
||||||
} from "@excalidraw/common";
|
} from "@excalidraw/common";
|
||||||
|
|
||||||
import { RoughGenerator } from "roughjs/bin/generator";
|
import { RoughGenerator } from "roughjs/bin/generator";
|
||||||
@ -202,7 +203,7 @@ export const generateRoughOptions = (
|
|||||||
// hachureGap because if not specified, roughjs uses strokeWidth to
|
// hachureGap because if not specified, roughjs uses strokeWidth to
|
||||||
// calculate them (and we don't want the fills to be modified)
|
// calculate them (and we don't want the fills to be modified)
|
||||||
fillWeight: element.strokeWidth / 2,
|
fillWeight: element.strokeWidth / 2,
|
||||||
hachureGap: element.strokeWidth * 4,
|
hachureGap: Math.min(element.strokeWidth, STROKE_WIDTH.bold) * 4,
|
||||||
roughness: adjustRoughness(element),
|
roughness: adjustRoughness(element),
|
||||||
stroke: element.strokeColor,
|
stroke: element.strokeColor,
|
||||||
preserveVertices:
|
preserveVertices:
|
||||||
@ -806,12 +807,18 @@ const generateElementShape = (
|
|||||||
generateFreeDrawShape(element);
|
generateFreeDrawShape(element);
|
||||||
|
|
||||||
if (isPathALoop(element.points)) {
|
if (isPathALoop(element.points)) {
|
||||||
// generate rough polygon to fill freedraw shape
|
const points =
|
||||||
const simplifiedPoints = simplify(
|
element.freedrawOptions === null
|
||||||
element.points as Mutable<LocalPoint[]>,
|
? simplify(element.points as LocalPoint[], 0.75)
|
||||||
0.75,
|
: simplify(element.points as LocalPoint[], 1.5);
|
||||||
);
|
|
||||||
shape = generator.curve(simplifiedPoints as [number, number][], {
|
shape =
|
||||||
|
element.freedrawOptions === null
|
||||||
|
? generator.curve(points, {
|
||||||
|
...generateRoughOptions(element),
|
||||||
|
stroke: "none",
|
||||||
|
})
|
||||||
|
: generator.polygon(points, {
|
||||||
...generateRoughOptions(element),
|
...generateRoughOptions(element),
|
||||||
stroke: "none",
|
stroke: "none",
|
||||||
});
|
});
|
||||||
|
|||||||
@ -380,6 +380,11 @@ export type ExcalidrawFreeDrawElement = _ExcalidrawElementBase &
|
|||||||
pressures: readonly number[];
|
pressures: readonly number[];
|
||||||
simulatePressure: boolean;
|
simulatePressure: boolean;
|
||||||
lastCommittedPoint: LocalPoint | null;
|
lastCommittedPoint: LocalPoint | null;
|
||||||
|
freedrawOptions: {
|
||||||
|
streamline?: number;
|
||||||
|
simplify?: number;
|
||||||
|
fixedStrokeWidth?: boolean;
|
||||||
|
} | null;
|
||||||
}>;
|
}>;
|
||||||
|
|
||||||
export type FileId = string & { _brand: "FileId" };
|
export type FileId = string & { _brand: "FileId" };
|
||||||
|
|||||||
@ -145,26 +145,27 @@ describe("element locking", () => {
|
|||||||
queryByTestId(document.body, `strokeWidth-thin`),
|
queryByTestId(document.body, `strokeWidth-thin`),
|
||||||
).not.toBeChecked();
|
).not.toBeChecked();
|
||||||
expect(
|
expect(
|
||||||
queryByTestId(document.body, `strokeWidth-bold`),
|
queryByTestId(document.body, `strokeWidth-medium`),
|
||||||
).not.toBeChecked();
|
).not.toBeChecked();
|
||||||
expect(
|
expect(
|
||||||
queryByTestId(document.body, `strokeWidth-extraBold`),
|
queryByTestId(document.body, `strokeWidth-bold`),
|
||||||
).not.toBeChecked();
|
).not.toBeChecked();
|
||||||
});
|
});
|
||||||
|
|
||||||
it("should show properties of different element types when selected", () => {
|
it("should show properties of different element types when selected", () => {
|
||||||
const rect = API.createElement({
|
const rect = API.createElement({
|
||||||
type: "rectangle",
|
type: "rectangle",
|
||||||
strokeWidth: STROKE_WIDTH.bold,
|
strokeWidth: STROKE_WIDTH.medium,
|
||||||
});
|
});
|
||||||
const text = API.createElement({
|
const text = API.createElement({
|
||||||
type: "text",
|
type: "text",
|
||||||
fontFamily: FONT_FAMILY["Comic Shanns"],
|
fontFamily: FONT_FAMILY["Comic Shanns"],
|
||||||
|
strokeWidth: undefined,
|
||||||
});
|
});
|
||||||
API.setElements([rect, text]);
|
API.setElements([rect, text]);
|
||||||
API.setSelectedElements([rect, text]);
|
API.setSelectedElements([rect, text]);
|
||||||
|
|
||||||
expect(queryByTestId(document.body, `strokeWidth-bold`)).toBeChecked();
|
expect(queryByTestId(document.body, `strokeWidth-medium`)).toBeChecked();
|
||||||
expect(queryByTestId(document.body, `font-family-code`)).toHaveClass(
|
expect(queryByTestId(document.body, `font-family-code`)).toHaveClass(
|
||||||
"active",
|
"active",
|
||||||
);
|
);
|
||||||
|
|||||||
@ -44,6 +44,7 @@ import {
|
|||||||
isArrowElement,
|
isArrowElement,
|
||||||
isBoundToContainer,
|
isBoundToContainer,
|
||||||
isElbowArrow,
|
isElbowArrow,
|
||||||
|
isFreeDrawElement,
|
||||||
isLinearElement,
|
isLinearElement,
|
||||||
isLineElement,
|
isLineElement,
|
||||||
isTextElement,
|
isTextElement,
|
||||||
@ -126,6 +127,9 @@ import {
|
|||||||
ArrowheadCrowfootIcon,
|
ArrowheadCrowfootIcon,
|
||||||
ArrowheadCrowfootOneIcon,
|
ArrowheadCrowfootOneIcon,
|
||||||
ArrowheadCrowfootOneOrManyIcon,
|
ArrowheadCrowfootOneOrManyIcon,
|
||||||
|
strokeWidthFixedIcon,
|
||||||
|
strokeWidthVariableIcon,
|
||||||
|
StrokeWidthMediumIcon,
|
||||||
} from "../components/icons";
|
} from "../components/icons";
|
||||||
|
|
||||||
import { Fonts } from "../fonts";
|
import { Fonts } from "../fonts";
|
||||||
@ -503,6 +507,33 @@ export const actionChangeFillStyle = register({
|
|||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
|
const WIDTHS = [
|
||||||
|
{
|
||||||
|
value: STROKE_WIDTH.thin,
|
||||||
|
text: t("labels.thin"),
|
||||||
|
icon: StrokeWidthBaseIcon,
|
||||||
|
testId: "strokeWidth-thin",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
value: STROKE_WIDTH.medium,
|
||||||
|
text: t("labels.medium"),
|
||||||
|
icon: StrokeWidthMediumIcon,
|
||||||
|
testId: "strokeWidth-medium",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
value: STROKE_WIDTH.bold,
|
||||||
|
text: t("labels.bold"),
|
||||||
|
icon: StrokeWidthBoldIcon,
|
||||||
|
testId: "strokeWidth-bold",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
value: STROKE_WIDTH.extraBold,
|
||||||
|
text: t("labels.extraBold"),
|
||||||
|
icon: StrokeWidthExtraBoldIcon,
|
||||||
|
testId: "strokeWidth-extraBold",
|
||||||
|
},
|
||||||
|
];
|
||||||
|
|
||||||
export const actionChangeStrokeWidth = register({
|
export const actionChangeStrokeWidth = register({
|
||||||
name: "changeStrokeWidth",
|
name: "changeStrokeWidth",
|
||||||
label: "labels.strokeWidth",
|
label: "labels.strokeWidth",
|
||||||
@ -524,26 +555,7 @@ export const actionChangeStrokeWidth = register({
|
|||||||
<div className="buttonList">
|
<div className="buttonList">
|
||||||
<RadioSelection
|
<RadioSelection
|
||||||
group="stroke-width"
|
group="stroke-width"
|
||||||
options={[
|
options={WIDTHS}
|
||||||
{
|
|
||||||
value: STROKE_WIDTH.thin,
|
|
||||||
text: t("labels.thin"),
|
|
||||||
icon: StrokeWidthBaseIcon,
|
|
||||||
testId: "strokeWidth-thin",
|
|
||||||
},
|
|
||||||
{
|
|
||||||
value: STROKE_WIDTH.bold,
|
|
||||||
text: t("labels.bold"),
|
|
||||||
icon: StrokeWidthBoldIcon,
|
|
||||||
testId: "strokeWidth-bold",
|
|
||||||
},
|
|
||||||
{
|
|
||||||
value: STROKE_WIDTH.extraBold,
|
|
||||||
text: t("labels.extraBold"),
|
|
||||||
icon: StrokeWidthExtraBoldIcon,
|
|
||||||
testId: "strokeWidth-extraBold",
|
|
||||||
},
|
|
||||||
]}
|
|
||||||
value={getFormValue(
|
value={getFormValue(
|
||||||
elements,
|
elements,
|
||||||
app,
|
app,
|
||||||
@ -666,6 +678,70 @@ export const actionChangeStrokeStyle = register({
|
|||||||
),
|
),
|
||||||
});
|
});
|
||||||
|
|
||||||
|
export const actionChangePressureSensitivity = register({
|
||||||
|
name: "changeStrokeType",
|
||||||
|
label: "labels.strokeType",
|
||||||
|
trackEvent: false,
|
||||||
|
perform: (elements, appState, value) => {
|
||||||
|
const updatedElements = changeProperty(elements, appState, (el) => {
|
||||||
|
if (isFreeDrawElement(el)) {
|
||||||
|
return newElementWith(el, {
|
||||||
|
freedrawOptions: {
|
||||||
|
...el.freedrawOptions,
|
||||||
|
fixedStrokeWidth: value,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
}
|
||||||
|
return el;
|
||||||
|
});
|
||||||
|
|
||||||
|
return {
|
||||||
|
elements: updatedElements,
|
||||||
|
appState: { ...appState, currentItemFixedStrokeWidth: value },
|
||||||
|
captureUpdate: CaptureUpdateAction.IMMEDIATELY,
|
||||||
|
};
|
||||||
|
},
|
||||||
|
PanelComponent: ({ app, appState, updateData }) => {
|
||||||
|
const selectedElements = app.scene.getSelectedElements(app.state);
|
||||||
|
const freedraws = selectedElements.filter(isFreeDrawElement);
|
||||||
|
|
||||||
|
const currentValue =
|
||||||
|
freedraws.length > 0
|
||||||
|
? reduceToCommonValue(
|
||||||
|
freedraws,
|
||||||
|
(element) => element.freedrawOptions?.fixedStrokeWidth,
|
||||||
|
) ?? null
|
||||||
|
: appState.currentItemFixedStrokeWidth;
|
||||||
|
|
||||||
|
return (
|
||||||
|
<fieldset>
|
||||||
|
<legend>{t("labels.strokeType")}</legend>
|
||||||
|
<div className="buttonList">
|
||||||
|
<RadioSelection
|
||||||
|
group="pressure-sensitivity"
|
||||||
|
options={[
|
||||||
|
{
|
||||||
|
value: true,
|
||||||
|
text: t("labels.strokeWidthFixed"),
|
||||||
|
icon: strokeWidthFixedIcon,
|
||||||
|
testId: "pressure-fixed",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
value: false,
|
||||||
|
text: t("labels.strokeWidthVariable"),
|
||||||
|
icon: strokeWidthVariableIcon,
|
||||||
|
testId: "pressure-variable",
|
||||||
|
},
|
||||||
|
]}
|
||||||
|
value={currentValue}
|
||||||
|
onChange={(value) => updateData(value)}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
</fieldset>
|
||||||
|
);
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
export const actionChangeOpacity = register({
|
export const actionChangeOpacity = register({
|
||||||
name: "changeOpacity",
|
name: "changeOpacity",
|
||||||
label: "labels.opacity",
|
label: "labels.opacity",
|
||||||
|
|||||||
@ -13,6 +13,7 @@ export {
|
|||||||
actionChangeStrokeWidth,
|
actionChangeStrokeWidth,
|
||||||
actionChangeFillStyle,
|
actionChangeFillStyle,
|
||||||
actionChangeSloppiness,
|
actionChangeSloppiness,
|
||||||
|
actionChangePressureSensitivity,
|
||||||
actionChangeOpacity,
|
actionChangeOpacity,
|
||||||
actionChangeFontSize,
|
actionChangeFontSize,
|
||||||
actionChangeFontFamily,
|
actionChangeFontFamily,
|
||||||
|
|||||||
@ -69,6 +69,7 @@ export type ActionName =
|
|||||||
| "changeStrokeStyle"
|
| "changeStrokeStyle"
|
||||||
| "changeArrowhead"
|
| "changeArrowhead"
|
||||||
| "changeArrowType"
|
| "changeArrowType"
|
||||||
|
| "changeStrokeType"
|
||||||
| "changeOpacity"
|
| "changeOpacity"
|
||||||
| "changeFontSize"
|
| "changeFontSize"
|
||||||
| "toggleCanvasMenu"
|
| "toggleCanvasMenu"
|
||||||
|
|||||||
@ -34,6 +34,7 @@ export const getDefaultAppState = (): Omit<
|
|||||||
currentItemFontFamily: DEFAULT_FONT_FAMILY,
|
currentItemFontFamily: DEFAULT_FONT_FAMILY,
|
||||||
currentItemFontSize: DEFAULT_FONT_SIZE,
|
currentItemFontSize: DEFAULT_FONT_SIZE,
|
||||||
currentItemOpacity: DEFAULT_ELEMENT_PROPS.opacity,
|
currentItemOpacity: DEFAULT_ELEMENT_PROPS.opacity,
|
||||||
|
currentItemFixedStrokeWidth: true,
|
||||||
currentItemRoughness: DEFAULT_ELEMENT_PROPS.roughness,
|
currentItemRoughness: DEFAULT_ELEMENT_PROPS.roughness,
|
||||||
currentItemStartArrowhead: null,
|
currentItemStartArrowhead: null,
|
||||||
currentItemStrokeColor: DEFAULT_ELEMENT_PROPS.strokeColor,
|
currentItemStrokeColor: DEFAULT_ELEMENT_PROPS.strokeColor,
|
||||||
@ -163,6 +164,11 @@ const APP_STATE_STORAGE_CONF = (<
|
|||||||
server: false,
|
server: false,
|
||||||
},
|
},
|
||||||
currentItemOpacity: { browser: true, export: false, server: false },
|
currentItemOpacity: { browser: true, export: false, server: false },
|
||||||
|
currentItemFixedStrokeWidth: {
|
||||||
|
browser: true,
|
||||||
|
export: false,
|
||||||
|
server: false,
|
||||||
|
},
|
||||||
currentItemRoughness: { browser: true, export: false, server: false },
|
currentItemRoughness: { browser: true, export: false, server: false },
|
||||||
currentItemStartArrowhead: { browser: true, export: false, server: false },
|
currentItemStartArrowhead: { browser: true, export: false, server: false },
|
||||||
currentItemStrokeColor: { browser: true, export: false, server: false },
|
currentItemStrokeColor: { browser: true, export: false, server: false },
|
||||||
|
|||||||
@ -169,8 +169,12 @@ export const SelectedShapeActions = ({
|
|||||||
renderAction("changeStrokeWidth")}
|
renderAction("changeStrokeWidth")}
|
||||||
|
|
||||||
{(appState.activeTool.type === "freedraw" ||
|
{(appState.activeTool.type === "freedraw" ||
|
||||||
targetElements.some((element) => element.type === "freedraw")) &&
|
targetElements.some((element) => element.type === "freedraw")) && (
|
||||||
renderAction("changeStrokeShape")}
|
<>
|
||||||
|
{renderAction("changeStrokeShape")}
|
||||||
|
{renderAction("changeStrokeType")}
|
||||||
|
</>
|
||||||
|
)}
|
||||||
|
|
||||||
{(hasStrokeStyle(appState.activeTool.type) ||
|
{(hasStrokeStyle(appState.activeTool.type) ||
|
||||||
targetElements.some((element) => hasStrokeStyle(element.type))) && (
|
targetElements.some((element) => hasStrokeStyle(element.type))) && (
|
||||||
|
|||||||
@ -232,6 +232,8 @@ import {
|
|||||||
hitElementBoundingBox,
|
hitElementBoundingBox,
|
||||||
isLineElement,
|
isLineElement,
|
||||||
isSimpleArrow,
|
isSimpleArrow,
|
||||||
|
STROKE_OPTIONS,
|
||||||
|
getFreedrawConfig,
|
||||||
} from "@excalidraw/element";
|
} from "@excalidraw/element";
|
||||||
|
|
||||||
import type { LocalPoint, Radians } from "@excalidraw/math";
|
import type { LocalPoint, Radians } from "@excalidraw/math";
|
||||||
@ -7478,7 +7480,12 @@ class App extends React.Component<AppProps, AppState> {
|
|||||||
y: gridY,
|
y: gridY,
|
||||||
});
|
});
|
||||||
|
|
||||||
const simulatePressure = event.pressure === 0.5;
|
const simulatePressure =
|
||||||
|
event.pressure === 0.5 || event.pressure === 0 || event.pressure === 1;
|
||||||
|
|
||||||
|
window.__lastPressure__ = event.pressure;
|
||||||
|
|
||||||
|
const freedrawConfig = getFreedrawConfig(event.pointerType);
|
||||||
|
|
||||||
const element = newFreeDrawElement({
|
const element = newFreeDrawElement({
|
||||||
type: elementType,
|
type: elementType,
|
||||||
@ -7493,6 +7500,17 @@ class App extends React.Component<AppProps, AppState> {
|
|||||||
opacity: this.state.currentItemOpacity,
|
opacity: this.state.currentItemOpacity,
|
||||||
roundness: null,
|
roundness: null,
|
||||||
simulatePressure,
|
simulatePressure,
|
||||||
|
strokeOptions: {
|
||||||
|
fixedStrokeWidth: this.state.currentItemFixedStrokeWidth,
|
||||||
|
streamline:
|
||||||
|
(window.h?.debugFreedraw?.enabled
|
||||||
|
? window.h?.debugFreedraw?.streamline
|
||||||
|
: null) ?? freedrawConfig.streamline,
|
||||||
|
simplify:
|
||||||
|
(window.h?.debugFreedraw?.enabled
|
||||||
|
? window.h?.debugFreedraw?.simplify
|
||||||
|
: null) ?? freedrawConfig.simplify,
|
||||||
|
},
|
||||||
locked: false,
|
locked: false,
|
||||||
frameId: topLayerFrame ? topLayerFrame.id : null,
|
frameId: topLayerFrame ? topLayerFrame.id : null,
|
||||||
points: [pointFrom<LocalPoint>(0, 0)],
|
points: [pointFrom<LocalPoint>(0, 0)],
|
||||||
@ -11134,6 +11152,7 @@ class App extends React.Component<AppProps, AppState> {
|
|||||||
// -----------------------------------------------------------------------------
|
// -----------------------------------------------------------------------------
|
||||||
declare global {
|
declare global {
|
||||||
interface Window {
|
interface Window {
|
||||||
|
__lastPressure__?: number;
|
||||||
h: {
|
h: {
|
||||||
scene: Scene;
|
scene: Scene;
|
||||||
elements: readonly ExcalidrawElement[];
|
elements: readonly ExcalidrawElement[];
|
||||||
@ -11142,6 +11161,11 @@ declare global {
|
|||||||
app: InstanceType<typeof App>;
|
app: InstanceType<typeof App>;
|
||||||
history: History;
|
history: History;
|
||||||
store: Store;
|
store: Store;
|
||||||
|
debugFreedraw?: {
|
||||||
|
streamline: number;
|
||||||
|
simplify: number;
|
||||||
|
enabled: boolean;
|
||||||
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -11150,6 +11174,12 @@ export const createTestHook = () => {
|
|||||||
if (isTestEnv() || isDevEnv()) {
|
if (isTestEnv() || isDevEnv()) {
|
||||||
window.h = window.h || ({} as Window["h"]);
|
window.h = window.h || ({} as Window["h"]);
|
||||||
|
|
||||||
|
// Initialize debug freedraw parameters
|
||||||
|
window.h.debugFreedraw = {
|
||||||
|
enabled: true,
|
||||||
|
...(window.h.debugFreedraw || STROKE_OPTIONS.default),
|
||||||
|
};
|
||||||
|
|
||||||
Object.defineProperties(window.h, {
|
Object.defineProperties(window.h, {
|
||||||
elements: {
|
elements: {
|
||||||
configurable: true,
|
configurable: true,
|
||||||
|
|||||||
@ -1136,7 +1136,7 @@ export const StrokeWidthBaseIcon = createIcon(
|
|||||||
modifiedTablerIconProps,
|
modifiedTablerIconProps,
|
||||||
);
|
);
|
||||||
|
|
||||||
export const StrokeWidthBoldIcon = createIcon(
|
export const StrokeWidthMediumIcon = createIcon(
|
||||||
<path
|
<path
|
||||||
d="M5 10h10"
|
d="M5 10h10"
|
||||||
stroke="currentColor"
|
stroke="currentColor"
|
||||||
@ -1147,7 +1147,7 @@ export const StrokeWidthBoldIcon = createIcon(
|
|||||||
modifiedTablerIconProps,
|
modifiedTablerIconProps,
|
||||||
);
|
);
|
||||||
|
|
||||||
export const StrokeWidthExtraBoldIcon = createIcon(
|
export const StrokeWidthBoldIcon = createIcon(
|
||||||
<path
|
<path
|
||||||
d="M5 10h10"
|
d="M5 10h10"
|
||||||
stroke="currentColor"
|
stroke="currentColor"
|
||||||
@ -1158,6 +1158,17 @@ export const StrokeWidthExtraBoldIcon = createIcon(
|
|||||||
modifiedTablerIconProps,
|
modifiedTablerIconProps,
|
||||||
);
|
);
|
||||||
|
|
||||||
|
export const StrokeWidthExtraBoldIcon = createIcon(
|
||||||
|
<path
|
||||||
|
d="M5 10h10"
|
||||||
|
stroke="currentColor"
|
||||||
|
strokeWidth="5"
|
||||||
|
strokeLinecap="round"
|
||||||
|
strokeLinejoin="round"
|
||||||
|
/>,
|
||||||
|
modifiedTablerIconProps,
|
||||||
|
);
|
||||||
|
|
||||||
export const StrokeStyleSolidIcon = React.memo(({ theme }: { theme: Theme }) =>
|
export const StrokeStyleSolidIcon = React.memo(({ theme }: { theme: Theme }) =>
|
||||||
createIcon(
|
createIcon(
|
||||||
<path
|
<path
|
||||||
@ -2269,3 +2280,71 @@ export const elementLinkIcon = createIcon(
|
|||||||
</g>,
|
</g>,
|
||||||
tablerIconProps,
|
tablerIconProps,
|
||||||
);
|
);
|
||||||
|
|
||||||
|
export const strokeWidthFixedIcon = createIcon(
|
||||||
|
<g>
|
||||||
|
<path
|
||||||
|
d="M4 12 C 5 8, 6 8, 8 12"
|
||||||
|
fill="none"
|
||||||
|
strokeWidth="1"
|
||||||
|
strokeLinecap="round"
|
||||||
|
strokeLinejoin="round"
|
||||||
|
/>
|
||||||
|
<path
|
||||||
|
d="M8 12 C 9 16, 10 16, 12 12"
|
||||||
|
fill="none"
|
||||||
|
strokeWidth="1"
|
||||||
|
strokeLinecap="round"
|
||||||
|
strokeLinejoin="round"
|
||||||
|
/>
|
||||||
|
<path
|
||||||
|
d="M12 12 C 14 8, 15 8, 16 12"
|
||||||
|
fill="none"
|
||||||
|
strokeWidth="1"
|
||||||
|
strokeLinecap="round"
|
||||||
|
strokeLinejoin="round"
|
||||||
|
/>
|
||||||
|
<path
|
||||||
|
d="M16 12 C 17 16, 18 16, 19 12"
|
||||||
|
fill="none"
|
||||||
|
strokeWidth="1"
|
||||||
|
strokeLinecap="round"
|
||||||
|
strokeLinejoin="round"
|
||||||
|
/>
|
||||||
|
</g>,
|
||||||
|
tablerIconProps,
|
||||||
|
);
|
||||||
|
|
||||||
|
export const strokeWidthVariableIcon = createIcon(
|
||||||
|
<g>
|
||||||
|
<path
|
||||||
|
d="M4 12 C 5 8, 6 8, 8 12"
|
||||||
|
fill="none"
|
||||||
|
stroke-width="1.5"
|
||||||
|
strokeLinecap="round"
|
||||||
|
strokeLinejoin="round"
|
||||||
|
/>
|
||||||
|
<path
|
||||||
|
d="M8 12 C 9 16, 10 16, 12 12"
|
||||||
|
fill="none"
|
||||||
|
stroke-width="2"
|
||||||
|
strokeLinecap="round"
|
||||||
|
strokeLinejoin="round"
|
||||||
|
/>
|
||||||
|
<path
|
||||||
|
d="M12 12 C 14 8, 15 8, 16 12"
|
||||||
|
fill="none"
|
||||||
|
stroke-width="2.75"
|
||||||
|
strokeLinecap="round"
|
||||||
|
strokeLinejoin="round"
|
||||||
|
/>
|
||||||
|
<path
|
||||||
|
d="M16 12 C 17 16, 18 16, 19 12"
|
||||||
|
fill="none"
|
||||||
|
stroke-width="3.25"
|
||||||
|
strokeLinecap="round"
|
||||||
|
strokeLinejoin="round"
|
||||||
|
/>
|
||||||
|
</g>,
|
||||||
|
tablerIconProps,
|
||||||
|
);
|
||||||
|
|||||||
@ -302,6 +302,8 @@ const restoreElement = (
|
|||||||
lastCommittedPoint: null,
|
lastCommittedPoint: null,
|
||||||
simulatePressure: element.simulatePressure,
|
simulatePressure: element.simulatePressure,
|
||||||
pressures: element.pressures,
|
pressures: element.pressures,
|
||||||
|
// legacy, for backwards compatibility
|
||||||
|
freedrawOptions: element.freedrawOptions ?? null,
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
case "image":
|
case "image":
|
||||||
|
|||||||
@ -248,7 +248,7 @@ export {
|
|||||||
loadSceneOrLibraryFromBlob,
|
loadSceneOrLibraryFromBlob,
|
||||||
loadLibraryFromBlob,
|
loadLibraryFromBlob,
|
||||||
} from "./data/blob";
|
} from "./data/blob";
|
||||||
export { getFreeDrawSvgPath } from "@excalidraw/element";
|
export { getFreeDrawSvgPath } from "@excalidraw/element/freedraw";
|
||||||
export { mergeLibraryItems, getLibraryItemsHash } from "./data/library";
|
export { mergeLibraryItems, getLibraryItemsHash } from "./data/library";
|
||||||
export { isLinearElement } from "@excalidraw/element";
|
export { isLinearElement } from "@excalidraw/element";
|
||||||
|
|
||||||
|
|||||||
@ -32,6 +32,9 @@
|
|||||||
"strokeStyle_dotted": "Dotted",
|
"strokeStyle_dotted": "Dotted",
|
||||||
"sloppiness": "Sloppiness",
|
"sloppiness": "Sloppiness",
|
||||||
"opacity": "Opacity",
|
"opacity": "Opacity",
|
||||||
|
"strokeType": "Stroke Type",
|
||||||
|
"strokeWidthFixed": "Fixed width",
|
||||||
|
"strokeWidthVariable": "Variable width",
|
||||||
"textAlign": "Text align",
|
"textAlign": "Text align",
|
||||||
"edges": "Edges",
|
"edges": "Edges",
|
||||||
"sharp": "Sharp",
|
"sharp": "Sharp",
|
||||||
|
|||||||
@ -82,7 +82,7 @@
|
|||||||
"@excalidraw/common": "0.18.0",
|
"@excalidraw/common": "0.18.0",
|
||||||
"@excalidraw/element": "0.18.0",
|
"@excalidraw/element": "0.18.0",
|
||||||
"@excalidraw/math": "0.18.0",
|
"@excalidraw/math": "0.18.0",
|
||||||
"@excalidraw/laser-pointer": "1.3.1",
|
"@excalidraw/laser-pointer": "1.3.2",
|
||||||
"@excalidraw/mermaid-to-excalidraw": "1.1.2",
|
"@excalidraw/mermaid-to-excalidraw": "1.1.2",
|
||||||
"@excalidraw/random-username": "1.1.0",
|
"@excalidraw/random-username": "1.1.0",
|
||||||
"@radix-ui/react-popover": "1.1.6",
|
"@radix-ui/react-popover": "1.1.6",
|
||||||
|
|||||||
@ -894,6 +894,7 @@ exports[`contextMenu element > right-clicking on a group should select whole gro
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -1092,6 +1093,7 @@ exports[`contextMenu element > selecting 'Add to library' in context menu adds e
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -1305,6 +1307,7 @@ exports[`contextMenu element > selecting 'Bring forward' in context menu brings
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -1635,6 +1638,7 @@ exports[`contextMenu element > selecting 'Bring to front' in context menu brings
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -1965,6 +1969,7 @@ exports[`contextMenu element > selecting 'Copy styles' in context menu copies st
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -2178,6 +2183,7 @@ exports[`contextMenu element > selecting 'Delete' in context menu deletes elemen
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -2418,6 +2424,7 @@ exports[`contextMenu element > selecting 'Duplicate' in context menu duplicates
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -2715,6 +2722,7 @@ exports[`contextMenu element > selecting 'Group selection' in context menu group
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -3086,6 +3094,7 @@ exports[`contextMenu element > selecting 'Paste styles' in context menu pastes s
|
|||||||
"currentItemBackgroundColor": "#a5d8ff",
|
"currentItemBackgroundColor": "#a5d8ff",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "cross-hatch",
|
"currentItemFillStyle": "cross-hatch",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 60,
|
"currentItemOpacity": 60,
|
||||||
@ -3094,7 +3103,7 @@ exports[`contextMenu element > selecting 'Paste styles' in context menu pastes s
|
|||||||
"currentItemStartArrowhead": null,
|
"currentItemStartArrowhead": null,
|
||||||
"currentItemStrokeColor": "#e03131",
|
"currentItemStrokeColor": "#e03131",
|
||||||
"currentItemStrokeStyle": "dotted",
|
"currentItemStrokeStyle": "dotted",
|
||||||
"currentItemStrokeWidth": 2,
|
"currentItemStrokeWidth": 4,
|
||||||
"currentItemTextAlign": "left",
|
"currentItemTextAlign": "left",
|
||||||
"cursorButton": "up",
|
"cursorButton": "up",
|
||||||
"defaultSidebarDockedPreference": false,
|
"defaultSidebarDockedPreference": false,
|
||||||
@ -3205,11 +3214,11 @@ exports[`contextMenu element > selecting 'Paste styles' in context menu pastes s
|
|||||||
"seed": 449462985,
|
"seed": 449462985,
|
||||||
"strokeColor": "#e03131",
|
"strokeColor": "#e03131",
|
||||||
"strokeStyle": "dotted",
|
"strokeStyle": "dotted",
|
||||||
"strokeWidth": 2,
|
"strokeWidth": 4,
|
||||||
"type": "rectangle",
|
"type": "rectangle",
|
||||||
"updated": 1,
|
"updated": 1,
|
||||||
"version": 4,
|
"version": 4,
|
||||||
"versionNonce": 1359939303,
|
"versionNonce": 2004587015,
|
||||||
"width": 20,
|
"width": 20,
|
||||||
"x": -10,
|
"x": -10,
|
||||||
"y": 0,
|
"y": 0,
|
||||||
@ -3234,14 +3243,14 @@ exports[`contextMenu element > selecting 'Paste styles' in context menu pastes s
|
|||||||
"opacity": 60,
|
"opacity": 60,
|
||||||
"roughness": 2,
|
"roughness": 2,
|
||||||
"roundness": null,
|
"roundness": null,
|
||||||
"seed": 640725609,
|
"seed": 941653321,
|
||||||
"strokeColor": "#e03131",
|
"strokeColor": "#e03131",
|
||||||
"strokeStyle": "dotted",
|
"strokeStyle": "dotted",
|
||||||
"strokeWidth": 2,
|
"strokeWidth": 4,
|
||||||
"type": "rectangle",
|
"type": "rectangle",
|
||||||
"updated": 1,
|
"updated": 1,
|
||||||
"version": 9,
|
"version": 10,
|
||||||
"versionNonce": 908564423,
|
"versionNonce": 1359939303,
|
||||||
"width": 20,
|
"width": 20,
|
||||||
"x": 20,
|
"x": 20,
|
||||||
"y": 30,
|
"y": 30,
|
||||||
@ -3250,7 +3259,7 @@ exports[`contextMenu element > selecting 'Paste styles' in context menu pastes s
|
|||||||
|
|
||||||
exports[`contextMenu element > selecting 'Paste styles' in context menu pastes styles > [end of test] number of elements 1`] = `2`;
|
exports[`contextMenu element > selecting 'Paste styles' in context menu pastes styles > [end of test] number of elements 1`] = `2`;
|
||||||
|
|
||||||
exports[`contextMenu element > selecting 'Paste styles' in context menu pastes styles > [end of test] number of renders 1`] = `16`;
|
exports[`contextMenu element > selecting 'Paste styles' in context menu pastes styles > [end of test] number of renders 1`] = `17`;
|
||||||
|
|
||||||
exports[`contextMenu element > selecting 'Paste styles' in context menu pastes styles > [end of test] redo stack 1`] = `[]`;
|
exports[`contextMenu element > selecting 'Paste styles' in context menu pastes styles > [end of test] redo stack 1`] = `[]`;
|
||||||
|
|
||||||
@ -3450,11 +3459,11 @@ exports[`contextMenu element > selecting 'Paste styles' in context menu pastes s
|
|||||||
"updated": {
|
"updated": {
|
||||||
"id3": {
|
"id3": {
|
||||||
"deleted": {
|
"deleted": {
|
||||||
"strokeStyle": "dotted",
|
"strokeWidth": 4,
|
||||||
"version": 7,
|
"version": 7,
|
||||||
},
|
},
|
||||||
"inserted": {
|
"inserted": {
|
||||||
"strokeStyle": "solid",
|
"strokeWidth": 2,
|
||||||
"version": 6,
|
"version": 6,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
@ -3475,11 +3484,11 @@ exports[`contextMenu element > selecting 'Paste styles' in context menu pastes s
|
|||||||
"updated": {
|
"updated": {
|
||||||
"id3": {
|
"id3": {
|
||||||
"deleted": {
|
"deleted": {
|
||||||
"roughness": 2,
|
"strokeStyle": "dotted",
|
||||||
"version": 8,
|
"version": 8,
|
||||||
},
|
},
|
||||||
"inserted": {
|
"inserted": {
|
||||||
"roughness": 1,
|
"strokeStyle": "solid",
|
||||||
"version": 7,
|
"version": 7,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
@ -3500,11 +3509,11 @@ exports[`contextMenu element > selecting 'Paste styles' in context menu pastes s
|
|||||||
"updated": {
|
"updated": {
|
||||||
"id3": {
|
"id3": {
|
||||||
"deleted": {
|
"deleted": {
|
||||||
"opacity": 60,
|
"roughness": 2,
|
||||||
"version": 9,
|
"version": 9,
|
||||||
},
|
},
|
||||||
"inserted": {
|
"inserted": {
|
||||||
"opacity": 100,
|
"roughness": 1,
|
||||||
"version": 8,
|
"version": 8,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
@ -3512,6 +3521,31 @@ exports[`contextMenu element > selecting 'Paste styles' in context menu pastes s
|
|||||||
},
|
},
|
||||||
"id": "id17",
|
"id": "id17",
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"appState": AppStateDelta {
|
||||||
|
"delta": Delta {
|
||||||
|
"deleted": {},
|
||||||
|
"inserted": {},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
"elements": {
|
||||||
|
"added": {},
|
||||||
|
"removed": {},
|
||||||
|
"updated": {
|
||||||
|
"id3": {
|
||||||
|
"deleted": {
|
||||||
|
"opacity": 60,
|
||||||
|
"version": 10,
|
||||||
|
},
|
||||||
|
"inserted": {
|
||||||
|
"opacity": 100,
|
||||||
|
"version": 9,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
"id": "id19",
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"appState": AppStateDelta {
|
"appState": AppStateDelta {
|
||||||
"delta": Delta {
|
"delta": Delta {
|
||||||
@ -3539,6 +3573,7 @@ exports[`contextMenu element > selecting 'Paste styles' in context menu pastes s
|
|||||||
"roughness": 2,
|
"roughness": 2,
|
||||||
"strokeColor": "#e03131",
|
"strokeColor": "#e03131",
|
||||||
"strokeStyle": "dotted",
|
"strokeStyle": "dotted",
|
||||||
|
"strokeWidth": 4,
|
||||||
"version": 4,
|
"version": 4,
|
||||||
},
|
},
|
||||||
"inserted": {
|
"inserted": {
|
||||||
@ -3548,12 +3583,13 @@ exports[`contextMenu element > selecting 'Paste styles' in context menu pastes s
|
|||||||
"roughness": 1,
|
"roughness": 1,
|
||||||
"strokeColor": "#1e1e1e",
|
"strokeColor": "#1e1e1e",
|
||||||
"strokeStyle": "solid",
|
"strokeStyle": "solid",
|
||||||
|
"strokeWidth": 2,
|
||||||
"version": 3,
|
"version": 3,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
"id": "id19",
|
"id": "id21",
|
||||||
},
|
},
|
||||||
]
|
]
|
||||||
`;
|
`;
|
||||||
@ -3578,6 +3614,7 @@ exports[`contextMenu element > selecting 'Send backward' in context menu sends e
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -3900,6 +3937,7 @@ exports[`contextMenu element > selecting 'Send to back' in context menu sends el
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -4222,6 +4260,7 @@ exports[`contextMenu element > selecting 'Ungroup selection' in context menu ung
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -5506,6 +5545,7 @@ exports[`contextMenu element > shows 'Group selection' in context menu for multi
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -6722,6 +6762,7 @@ exports[`contextMenu element > shows 'Ungroup selection' in context menu for gro
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -7656,6 +7697,7 @@ exports[`contextMenu element > shows context menu for canvas > [end of test] app
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -8655,6 +8697,7 @@ exports[`contextMenu element > shows context menu for element > [end of test] ap
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -9645,6 +9688,7 @@ exports[`contextMenu element > shows context menu for element > [end of test] ap
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
|
|||||||
@ -20,6 +20,7 @@ exports[`history > multiplayer undo/redo > conflicts in arrows and their bindabl
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -632,6 +633,7 @@ exports[`history > multiplayer undo/redo > conflicts in arrows and their bindabl
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -1114,6 +1116,7 @@ exports[`history > multiplayer undo/redo > conflicts in arrows and their bindabl
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -1477,6 +1480,7 @@ exports[`history > multiplayer undo/redo > conflicts in arrows and their bindabl
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -1843,6 +1847,7 @@ exports[`history > multiplayer undo/redo > conflicts in arrows and their bindabl
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -2105,6 +2110,7 @@ exports[`history > multiplayer undo/redo > conflicts in arrows and their bindabl
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -2543,6 +2549,7 @@ exports[`history > multiplayer undo/redo > conflicts in bound text elements and
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -2804,6 +2811,7 @@ exports[`history > multiplayer undo/redo > conflicts in bound text elements and
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -3069,6 +3077,7 @@ exports[`history > multiplayer undo/redo > conflicts in bound text elements and
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -3362,6 +3371,7 @@ exports[`history > multiplayer undo/redo > conflicts in bound text elements and
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -3647,6 +3657,7 @@ exports[`history > multiplayer undo/redo > conflicts in bound text elements and
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -3881,6 +3892,7 @@ exports[`history > multiplayer undo/redo > conflicts in bound text elements and
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -4137,6 +4149,7 @@ exports[`history > multiplayer undo/redo > conflicts in bound text elements and
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -4407,6 +4420,7 @@ exports[`history > multiplayer undo/redo > conflicts in bound text elements and
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -4635,6 +4649,7 @@ exports[`history > multiplayer undo/redo > conflicts in bound text elements and
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -4863,6 +4878,7 @@ exports[`history > multiplayer undo/redo > conflicts in bound text elements and
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -5089,6 +5105,7 @@ exports[`history > multiplayer undo/redo > conflicts in bound text elements and
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -5315,6 +5332,7 @@ exports[`history > multiplayer undo/redo > conflicts in frames and their childre
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -5570,6 +5588,7 @@ exports[`history > multiplayer undo/redo > should iterate through the history wh
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -5831,6 +5850,7 @@ exports[`history > multiplayer undo/redo > should iterate through the history wh
|
|||||||
"currentItemBackgroundColor": "#ffc9c9",
|
"currentItemBackgroundColor": "#ffc9c9",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -6193,6 +6213,7 @@ exports[`history > multiplayer undo/redo > should iterate through the history wh
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -6566,6 +6587,7 @@ exports[`history > multiplayer undo/redo > should iterate through the history wh
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -6877,6 +6899,7 @@ exports[`history > multiplayer undo/redo > should iterate through the history wh
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -7179,6 +7202,7 @@ exports[`history > multiplayer undo/redo > should iterate through the history wh
|
|||||||
"currentItemBackgroundColor": "#ffc9c9",
|
"currentItemBackgroundColor": "#ffc9c9",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -7376,6 +7400,7 @@ exports[`history > multiplayer undo/redo > should iterate through the history wh
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -7727,6 +7752,7 @@ exports[`history > multiplayer undo/redo > should iterate through the history wh
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -8078,6 +8104,7 @@ exports[`history > multiplayer undo/redo > should not let remote changes to inte
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -8483,6 +8510,7 @@ exports[`history > multiplayer undo/redo > should not let remote changes to inte
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -8580,6 +8608,11 @@ exports[`history > multiplayer undo/redo > should not let remote changes to inte
|
|||||||
"backgroundColor": "transparent",
|
"backgroundColor": "transparent",
|
||||||
"boundElements": null,
|
"boundElements": null,
|
||||||
"customData": undefined,
|
"customData": undefined,
|
||||||
|
"drawingConfigs": {
|
||||||
|
"fixedStrokeWidth": true,
|
||||||
|
"simplify": "0.10000",
|
||||||
|
"streamline": "0.35000",
|
||||||
|
},
|
||||||
"fillStyle": "solid",
|
"fillStyle": "solid",
|
||||||
"frameId": null,
|
"frameId": null,
|
||||||
"groupIds": [],
|
"groupIds": [],
|
||||||
@ -8612,15 +8645,10 @@ exports[`history > multiplayer undo/redo > should not let remote changes to inte
|
|||||||
50,
|
50,
|
||||||
],
|
],
|
||||||
],
|
],
|
||||||
"pressures": [
|
"pressures": [],
|
||||||
0,
|
|
||||||
0,
|
|
||||||
0,
|
|
||||||
0,
|
|
||||||
],
|
|
||||||
"roughness": 1,
|
"roughness": 1,
|
||||||
"roundness": null,
|
"roundness": null,
|
||||||
"simulatePressure": false,
|
"simulatePressure": true,
|
||||||
"strokeColor": "#1e1e1e",
|
"strokeColor": "#1e1e1e",
|
||||||
"strokeStyle": "solid",
|
"strokeStyle": "solid",
|
||||||
"strokeWidth": 2,
|
"strokeWidth": 2,
|
||||||
@ -8687,6 +8715,11 @@ exports[`history > multiplayer undo/redo > should not let remote changes to inte
|
|||||||
"backgroundColor": "transparent",
|
"backgroundColor": "transparent",
|
||||||
"boundElements": null,
|
"boundElements": null,
|
||||||
"customData": undefined,
|
"customData": undefined,
|
||||||
|
"drawingConfigs": {
|
||||||
|
"fixedStrokeWidth": true,
|
||||||
|
"simplify": "0.10000",
|
||||||
|
"streamline": "0.35000",
|
||||||
|
},
|
||||||
"fillStyle": "solid",
|
"fillStyle": "solid",
|
||||||
"frameId": null,
|
"frameId": null,
|
||||||
"groupIds": [],
|
"groupIds": [],
|
||||||
@ -8718,15 +8751,10 @@ exports[`history > multiplayer undo/redo > should not let remote changes to inte
|
|||||||
50,
|
50,
|
||||||
],
|
],
|
||||||
],
|
],
|
||||||
"pressures": [
|
"pressures": [],
|
||||||
0,
|
|
||||||
0,
|
|
||||||
0,
|
|
||||||
0,
|
|
||||||
],
|
|
||||||
"roughness": 1,
|
"roughness": 1,
|
||||||
"roundness": null,
|
"roundness": null,
|
||||||
"simulatePressure": false,
|
"simulatePressure": true,
|
||||||
"strokeColor": "#1e1e1e",
|
"strokeColor": "#1e1e1e",
|
||||||
"strokeStyle": "solid",
|
"strokeStyle": "solid",
|
||||||
"strokeWidth": 2,
|
"strokeWidth": 2,
|
||||||
@ -8769,6 +8797,7 @@ exports[`history > multiplayer undo/redo > should not let remote changes to inte
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -9032,6 +9061,7 @@ exports[`history > multiplayer undo/redo > should not override remote changes on
|
|||||||
"currentItemBackgroundColor": "#ffc9c9",
|
"currentItemBackgroundColor": "#ffc9c9",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -9296,6 +9326,7 @@ exports[`history > multiplayer undo/redo > should not override remote changes on
|
|||||||
"currentItemBackgroundColor": "#ffc9c9",
|
"currentItemBackgroundColor": "#ffc9c9",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -9527,6 +9558,7 @@ exports[`history > multiplayer undo/redo > should override remotely added groups
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -9823,6 +9855,7 @@ exports[`history > multiplayer undo/redo > should override remotely added points
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -10168,6 +10201,7 @@ exports[`history > multiplayer undo/redo > should redistribute deltas when eleme
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -10392,6 +10426,7 @@ exports[`history > multiplayer undo/redo > should redraw arrows on undo > [end o
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -10839,6 +10874,7 @@ exports[`history > multiplayer undo/redo > should update history entries after r
|
|||||||
"currentItemBackgroundColor": "#a5d8ff",
|
"currentItemBackgroundColor": "#a5d8ff",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -11098,6 +11134,7 @@ exports[`history > singleplayer undo/redo > remounting undo/redo buttons should
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -11332,6 +11369,7 @@ exports[`history > singleplayer undo/redo > should clear the redo stack on eleme
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -11568,6 +11606,7 @@ exports[`history > singleplayer undo/redo > should create entry when selecting f
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -11695,6 +11734,11 @@ exports[`history > singleplayer undo/redo > should create entry when selecting f
|
|||||||
"backgroundColor": "transparent",
|
"backgroundColor": "transparent",
|
||||||
"boundElements": null,
|
"boundElements": null,
|
||||||
"customData": undefined,
|
"customData": undefined,
|
||||||
|
"drawingConfigs": {
|
||||||
|
"fixedStrokeWidth": true,
|
||||||
|
"simplify": "0.10000",
|
||||||
|
"streamline": "0.35000",
|
||||||
|
},
|
||||||
"fillStyle": "solid",
|
"fillStyle": "solid",
|
||||||
"frameId": null,
|
"frameId": null,
|
||||||
"groupIds": [],
|
"groupIds": [],
|
||||||
@ -11723,14 +11767,10 @@ exports[`history > singleplayer undo/redo > should create entry when selecting f
|
|||||||
10,
|
10,
|
||||||
],
|
],
|
||||||
],
|
],
|
||||||
"pressures": [
|
"pressures": [],
|
||||||
0,
|
|
||||||
0,
|
|
||||||
0,
|
|
||||||
],
|
|
||||||
"roughness": 1,
|
"roughness": 1,
|
||||||
"roundness": null,
|
"roundness": null,
|
||||||
"simulatePressure": false,
|
"simulatePressure": true,
|
||||||
"strokeColor": "#1e1e1e",
|
"strokeColor": "#1e1e1e",
|
||||||
"strokeStyle": "solid",
|
"strokeStyle": "solid",
|
||||||
"strokeWidth": 2,
|
"strokeWidth": 2,
|
||||||
@ -11749,6 +11789,11 @@ exports[`history > singleplayer undo/redo > should create entry when selecting f
|
|||||||
"backgroundColor": "transparent",
|
"backgroundColor": "transparent",
|
||||||
"boundElements": null,
|
"boundElements": null,
|
||||||
"customData": undefined,
|
"customData": undefined,
|
||||||
|
"drawingConfigs": {
|
||||||
|
"fixedStrokeWidth": true,
|
||||||
|
"simplify": "0.10000",
|
||||||
|
"streamline": "0.35000",
|
||||||
|
},
|
||||||
"fillStyle": "solid",
|
"fillStyle": "solid",
|
||||||
"frameId": null,
|
"frameId": null,
|
||||||
"groupIds": [],
|
"groupIds": [],
|
||||||
@ -11777,14 +11822,10 @@ exports[`history > singleplayer undo/redo > should create entry when selecting f
|
|||||||
10,
|
10,
|
||||||
],
|
],
|
||||||
],
|
],
|
||||||
"pressures": [
|
"pressures": [],
|
||||||
0,
|
|
||||||
0,
|
|
||||||
0,
|
|
||||||
],
|
|
||||||
"roughness": 1,
|
"roughness": 1,
|
||||||
"roundness": null,
|
"roundness": null,
|
||||||
"simulatePressure": false,
|
"simulatePressure": true,
|
||||||
"strokeColor": "#e03131",
|
"strokeColor": "#e03131",
|
||||||
"strokeStyle": "solid",
|
"strokeStyle": "solid",
|
||||||
"strokeWidth": 2,
|
"strokeWidth": 2,
|
||||||
@ -11893,6 +11934,11 @@ exports[`history > singleplayer undo/redo > should create entry when selecting f
|
|||||||
"backgroundColor": "transparent",
|
"backgroundColor": "transparent",
|
||||||
"boundElements": null,
|
"boundElements": null,
|
||||||
"customData": undefined,
|
"customData": undefined,
|
||||||
|
"drawingConfigs": {
|
||||||
|
"fixedStrokeWidth": true,
|
||||||
|
"simplify": "0.10000",
|
||||||
|
"streamline": "0.35000",
|
||||||
|
},
|
||||||
"fillStyle": "solid",
|
"fillStyle": "solid",
|
||||||
"frameId": null,
|
"frameId": null,
|
||||||
"groupIds": [],
|
"groupIds": [],
|
||||||
@ -11920,14 +11966,10 @@ exports[`history > singleplayer undo/redo > should create entry when selecting f
|
|||||||
10,
|
10,
|
||||||
],
|
],
|
||||||
],
|
],
|
||||||
"pressures": [
|
"pressures": [],
|
||||||
0,
|
|
||||||
0,
|
|
||||||
0,
|
|
||||||
],
|
|
||||||
"roughness": 1,
|
"roughness": 1,
|
||||||
"roundness": null,
|
"roundness": null,
|
||||||
"simulatePressure": false,
|
"simulatePressure": true,
|
||||||
"strokeColor": "#e03131",
|
"strokeColor": "#e03131",
|
||||||
"strokeStyle": "solid",
|
"strokeStyle": "solid",
|
||||||
"strokeWidth": 2,
|
"strokeWidth": 2,
|
||||||
@ -11970,6 +12012,7 @@ exports[`history > singleplayer undo/redo > should create new history entry on e
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -12179,6 +12222,7 @@ exports[`history > singleplayer undo/redo > should create new history entry on e
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -12388,6 +12432,7 @@ exports[`history > singleplayer undo/redo > should create new history entry on i
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -12611,6 +12656,7 @@ exports[`history > singleplayer undo/redo > should create new history entry on i
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -12834,6 +12880,7 @@ exports[`history > singleplayer undo/redo > should create new history entry on s
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -13078,6 +13125,7 @@ exports[`history > singleplayer undo/redo > should disable undo/redo buttons whe
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -13314,6 +13362,7 @@ exports[`history > singleplayer undo/redo > should end up with no history entry
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -13550,6 +13599,7 @@ exports[`history > singleplayer undo/redo > should iterate through the history w
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -13796,6 +13846,7 @@ exports[`history > singleplayer undo/redo > should not clear the redo stack on s
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -14126,6 +14177,7 @@ exports[`history > singleplayer undo/redo > should not collapse when applying co
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -14295,6 +14347,7 @@ exports[`history > singleplayer undo/redo > should not end up with history entry
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -14578,6 +14631,7 @@ exports[`history > singleplayer undo/redo > should not end up with history entry
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -14840,6 +14894,7 @@ exports[`history > singleplayer undo/redo > should not modify anything on unrela
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -14992,6 +15047,7 @@ exports[`history > singleplayer undo/redo > should not override appstate changes
|
|||||||
"currentItemBackgroundColor": "#a5d8ff",
|
"currentItemBackgroundColor": "#a5d8ff",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -15273,6 +15329,7 @@ exports[`history > singleplayer undo/redo > should support appstate name or view
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -15434,6 +15491,7 @@ exports[`history > singleplayer undo/redo > should support bidirectional binding
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -16132,6 +16190,7 @@ exports[`history > singleplayer undo/redo > should support bidirectional binding
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -16763,6 +16822,7 @@ exports[`history > singleplayer undo/redo > should support bidirectional binding
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -17394,6 +17454,7 @@ exports[`history > singleplayer undo/redo > should support bidirectional binding
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -18106,6 +18167,7 @@ exports[`history > singleplayer undo/redo > should support bidirectional binding
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -18850,6 +18912,7 @@ exports[`history > singleplayer undo/redo > should support changes in elements'
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -19329,6 +19392,7 @@ exports[`history > singleplayer undo/redo > should support duplication of groups
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -19839,6 +19903,7 @@ exports[`history > singleplayer undo/redo > should support element creation, del
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -20297,6 +20362,7 @@ exports[`history > singleplayer undo/redo > should support linear element creati
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
|
|||||||
@ -20,6 +20,7 @@ exports[`given element A and group of elements B and given both are selected whe
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -445,6 +446,7 @@ exports[`given element A and group of elements B and given both are selected whe
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -860,6 +862,7 @@ exports[`regression tests > Cmd/Ctrl-click exclusively select element under poin
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -1425,6 +1428,7 @@ exports[`regression tests > Drags selected element when hitting only bounding bo
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -1631,6 +1635,7 @@ exports[`regression tests > adjusts z order when grouping > [end of test] appSta
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -2014,6 +2019,7 @@ exports[`regression tests > alt-drag duplicates an element > [end of test] appSt
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -2258,6 +2264,7 @@ exports[`regression tests > arrow keys > [end of test] appState 1`] = `
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -2437,6 +2444,7 @@ exports[`regression tests > can drag element that covers another element, while
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -2761,6 +2769,7 @@ exports[`regression tests > change the properties of a shape > [end of test] app
|
|||||||
"currentItemBackgroundColor": "#ffc9c9",
|
"currentItemBackgroundColor": "#ffc9c9",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -3015,6 +3024,7 @@ exports[`regression tests > click on an element and drag it > [dragged] appState
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -3255,6 +3265,7 @@ exports[`regression tests > click on an element and drag it > [end of test] appS
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -3490,6 +3501,7 @@ exports[`regression tests > click to select a shape > [end of test] appState 1`]
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -3747,6 +3759,7 @@ exports[`regression tests > click-drag to select a group > [end of test] appStat
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -4060,6 +4073,7 @@ exports[`regression tests > deleting last but one element in editing group shoul
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -4495,6 +4509,7 @@ exports[`regression tests > deselects group of selected elements on pointer down
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -4777,6 +4792,7 @@ exports[`regression tests > deselects group of selected elements on pointer up w
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -5052,6 +5068,7 @@ exports[`regression tests > deselects selected element on pointer down when poin
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -5259,6 +5276,7 @@ exports[`regression tests > deselects selected element, on pointer up, when clic
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -5458,6 +5476,7 @@ exports[`regression tests > double click to edit a group > [end of test] appStat
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -5850,6 +5869,7 @@ exports[`regression tests > drags selected elements from point inside common bou
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -6146,6 +6166,7 @@ exports[`regression tests > draw every type of shape > [end of test] appState 1`
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -6900,6 +6921,11 @@ exports[`regression tests > draw every type of shape > [end of test] undo stack
|
|||||||
"backgroundColor": "transparent",
|
"backgroundColor": "transparent",
|
||||||
"boundElements": null,
|
"boundElements": null,
|
||||||
"customData": undefined,
|
"customData": undefined,
|
||||||
|
"drawingConfigs": {
|
||||||
|
"fixedStrokeWidth": true,
|
||||||
|
"simplify": "0.10000",
|
||||||
|
"streamline": "0.35000",
|
||||||
|
},
|
||||||
"fillStyle": "solid",
|
"fillStyle": "solid",
|
||||||
"frameId": null,
|
"frameId": null,
|
||||||
"groupIds": [],
|
"groupIds": [],
|
||||||
@ -6927,14 +6953,10 @@ exports[`regression tests > draw every type of shape > [end of test] undo stack
|
|||||||
10,
|
10,
|
||||||
],
|
],
|
||||||
],
|
],
|
||||||
"pressures": [
|
"pressures": [],
|
||||||
0,
|
|
||||||
0,
|
|
||||||
0,
|
|
||||||
],
|
|
||||||
"roughness": 1,
|
"roughness": 1,
|
||||||
"roundness": null,
|
"roundness": null,
|
||||||
"simulatePressure": false,
|
"simulatePressure": true,
|
||||||
"strokeColor": "#1e1e1e",
|
"strokeColor": "#1e1e1e",
|
||||||
"strokeStyle": "solid",
|
"strokeStyle": "solid",
|
||||||
"strokeWidth": 2,
|
"strokeWidth": 2,
|
||||||
@ -6977,6 +6999,7 @@ exports[`regression tests > given a group of selected elements with an element t
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -7310,6 +7333,7 @@ exports[`regression tests > given a selected element A and a not selected elemen
|
|||||||
"currentItemBackgroundColor": "#ffc9c9",
|
"currentItemBackgroundColor": "#ffc9c9",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -7588,6 +7612,7 @@ exports[`regression tests > given selected element A with lower z-index than uns
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -7822,6 +7847,7 @@ exports[`regression tests > given selected element A with lower z-index than uns
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -8061,6 +8087,7 @@ exports[`regression tests > key 2 selects rectangle tool > [end of test] appStat
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -8240,6 +8267,7 @@ exports[`regression tests > key 3 selects diamond tool > [end of test] appState
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -8419,6 +8447,7 @@ exports[`regression tests > key 4 selects ellipse tool > [end of test] appState
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -8598,6 +8627,7 @@ exports[`regression tests > key 5 selects arrow tool > [end of test] appState 1`
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -8823,6 +8853,7 @@ exports[`regression tests > key 6 selects line tool > [end of test] appState 1`]
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -9046,6 +9077,7 @@ exports[`regression tests > key 7 selects freedraw tool > [end of test] appState
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -9164,6 +9196,11 @@ exports[`regression tests > key 7 selects freedraw tool > [end of test] undo sta
|
|||||||
"backgroundColor": "transparent",
|
"backgroundColor": "transparent",
|
||||||
"boundElements": null,
|
"boundElements": null,
|
||||||
"customData": undefined,
|
"customData": undefined,
|
||||||
|
"drawingConfigs": {
|
||||||
|
"fixedStrokeWidth": true,
|
||||||
|
"simplify": "0.10000",
|
||||||
|
"streamline": "0.35000",
|
||||||
|
},
|
||||||
"fillStyle": "solid",
|
"fillStyle": "solid",
|
||||||
"frameId": null,
|
"frameId": null,
|
||||||
"groupIds": [],
|
"groupIds": [],
|
||||||
@ -9191,14 +9228,10 @@ exports[`regression tests > key 7 selects freedraw tool > [end of test] undo sta
|
|||||||
10,
|
10,
|
||||||
],
|
],
|
||||||
],
|
],
|
||||||
"pressures": [
|
"pressures": [],
|
||||||
0,
|
|
||||||
0,
|
|
||||||
0,
|
|
||||||
],
|
|
||||||
"roughness": 1,
|
"roughness": 1,
|
||||||
"roundness": null,
|
"roundness": null,
|
||||||
"simulatePressure": false,
|
"simulatePressure": true,
|
||||||
"strokeColor": "#1e1e1e",
|
"strokeColor": "#1e1e1e",
|
||||||
"strokeStyle": "solid",
|
"strokeStyle": "solid",
|
||||||
"strokeWidth": 2,
|
"strokeWidth": 2,
|
||||||
@ -9241,6 +9274,7 @@ exports[`regression tests > key a selects arrow tool > [end of test] appState 1`
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -9466,6 +9500,7 @@ exports[`regression tests > key d selects diamond tool > [end of test] appState
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -9645,6 +9680,7 @@ exports[`regression tests > key l selects line tool > [end of test] appState 1`]
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -9868,6 +9904,7 @@ exports[`regression tests > key o selects ellipse tool > [end of test] appState
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -10047,6 +10084,7 @@ exports[`regression tests > key p selects freedraw tool > [end of test] appState
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -10165,6 +10203,11 @@ exports[`regression tests > key p selects freedraw tool > [end of test] undo sta
|
|||||||
"backgroundColor": "transparent",
|
"backgroundColor": "transparent",
|
||||||
"boundElements": null,
|
"boundElements": null,
|
||||||
"customData": undefined,
|
"customData": undefined,
|
||||||
|
"drawingConfigs": {
|
||||||
|
"fixedStrokeWidth": true,
|
||||||
|
"simplify": "0.10000",
|
||||||
|
"streamline": "0.35000",
|
||||||
|
},
|
||||||
"fillStyle": "solid",
|
"fillStyle": "solid",
|
||||||
"frameId": null,
|
"frameId": null,
|
||||||
"groupIds": [],
|
"groupIds": [],
|
||||||
@ -10192,14 +10235,10 @@ exports[`regression tests > key p selects freedraw tool > [end of test] undo sta
|
|||||||
10,
|
10,
|
||||||
],
|
],
|
||||||
],
|
],
|
||||||
"pressures": [
|
"pressures": [],
|
||||||
0,
|
|
||||||
0,
|
|
||||||
0,
|
|
||||||
],
|
|
||||||
"roughness": 1,
|
"roughness": 1,
|
||||||
"roundness": null,
|
"roundness": null,
|
||||||
"simulatePressure": false,
|
"simulatePressure": true,
|
||||||
"strokeColor": "#1e1e1e",
|
"strokeColor": "#1e1e1e",
|
||||||
"strokeStyle": "solid",
|
"strokeStyle": "solid",
|
||||||
"strokeWidth": 2,
|
"strokeWidth": 2,
|
||||||
@ -10242,6 +10281,7 @@ exports[`regression tests > key r selects rectangle tool > [end of test] appStat
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -10421,6 +10461,7 @@ exports[`regression tests > make a group and duplicate it > [end of test] appSta
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -10951,6 +10992,7 @@ exports[`regression tests > noop interaction after undo shouldn't create history
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -11230,6 +11272,7 @@ exports[`regression tests > pinch-to-zoom works > [end of test] appState 1`] = `
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -11352,6 +11395,7 @@ exports[`regression tests > shift click on selected element should deselect it o
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -11551,6 +11595,7 @@ exports[`regression tests > shift-click to multiselect, then drag > [end of test
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -11869,6 +11914,7 @@ exports[`regression tests > should group elements and ungroup them > [end of tes
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -12297,6 +12343,7 @@ exports[`regression tests > single-clicking on a subgroup of a selected group sh
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -12936,6 +12983,7 @@ exports[`regression tests > spacebar + drag scrolls the canvas > [end of test] a
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -13061,6 +13109,7 @@ exports[`regression tests > supports nested groups > [end of test] appState 1`]
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -13691,6 +13740,7 @@ exports[`regression tests > switches from group of selected elements to another
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -14029,6 +14079,7 @@ exports[`regression tests > switches selected element on pointer down > [end of
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -14292,6 +14343,7 @@ exports[`regression tests > two-finger scroll works > [end of test] appState 1`]
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -14414,6 +14466,7 @@ exports[`regression tests > undo/redo drawing an element > [end of test] appStat
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -14802,6 +14855,7 @@ exports[`regression tests > updates fontSize & fontFamily appState > [end of tes
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 8,
|
"currentItemFontFamily": 8,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
@ -14924,6 +14978,7 @@ exports[`regression tests > zoom hotkeys > [end of test] appState 1`] = `
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
|
|||||||
@ -78,7 +78,7 @@ describe("actionStyles", () => {
|
|||||||
expect(firstRect.strokeColor).toBe("#e03131");
|
expect(firstRect.strokeColor).toBe("#e03131");
|
||||||
expect(firstRect.backgroundColor).toBe("#a5d8ff");
|
expect(firstRect.backgroundColor).toBe("#a5d8ff");
|
||||||
expect(firstRect.fillStyle).toBe("cross-hatch");
|
expect(firstRect.fillStyle).toBe("cross-hatch");
|
||||||
expect(firstRect.strokeWidth).toBe(2); // Bold: 2
|
expect(firstRect.strokeWidth).toBe(4); // Bold: 4
|
||||||
expect(firstRect.strokeStyle).toBe("dotted");
|
expect(firstRect.strokeStyle).toBe("dotted");
|
||||||
expect(firstRect.roughness).toBe(2); // Cartoonist: 2
|
expect(firstRect.roughness).toBe(2); // Cartoonist: 2
|
||||||
expect(firstRect.opacity).toBe(60);
|
expect(firstRect.opacity).toBe(60);
|
||||||
|
|||||||
@ -381,7 +381,7 @@ describe("contextMenu element", () => {
|
|||||||
expect(firstRect.strokeColor).toBe("#e03131");
|
expect(firstRect.strokeColor).toBe("#e03131");
|
||||||
expect(firstRect.backgroundColor).toBe("#a5d8ff");
|
expect(firstRect.backgroundColor).toBe("#a5d8ff");
|
||||||
expect(firstRect.fillStyle).toBe("cross-hatch");
|
expect(firstRect.fillStyle).toBe("cross-hatch");
|
||||||
expect(firstRect.strokeWidth).toBe(2); // Bold: 2
|
expect(firstRect.strokeWidth).toBe(4); // Bold: 4
|
||||||
expect(firstRect.strokeStyle).toBe("dotted");
|
expect(firstRect.strokeStyle).toBe("dotted");
|
||||||
expect(firstRect.roughness).toBe(2); // Cartoonist: 2
|
expect(firstRect.roughness).toBe(2); // Cartoonist: 2
|
||||||
expect(firstRect.opacity).toBe(60);
|
expect(firstRect.opacity).toBe(60);
|
||||||
|
|||||||
@ -168,6 +168,11 @@ exports[`restoreElements > should restore freedraw element correctly 1`] = `
|
|||||||
"backgroundColor": "transparent",
|
"backgroundColor": "transparent",
|
||||||
"boundElements": [],
|
"boundElements": [],
|
||||||
"customData": undefined,
|
"customData": undefined,
|
||||||
|
"drawingConfigs": {
|
||||||
|
"fixedStrokeWidth": true,
|
||||||
|
"simplify": "0.10000",
|
||||||
|
"streamline": "0.25000",
|
||||||
|
},
|
||||||
"fillStyle": "solid",
|
"fillStyle": "solid",
|
||||||
"frameId": null,
|
"frameId": null,
|
||||||
"groupIds": [],
|
"groupIds": [],
|
||||||
|
|||||||
@ -331,6 +331,7 @@ export interface AppState {
|
|||||||
currentItemStrokeStyle: ExcalidrawElement["strokeStyle"];
|
currentItemStrokeStyle: ExcalidrawElement["strokeStyle"];
|
||||||
currentItemRoughness: number;
|
currentItemRoughness: number;
|
||||||
currentItemOpacity: number;
|
currentItemOpacity: number;
|
||||||
|
currentItemFixedStrokeWidth: boolean;
|
||||||
currentItemFontFamily: FontFamilyValues;
|
currentItemFontFamily: FontFamilyValues;
|
||||||
currentItemFontSize: number;
|
currentItemFontSize: number;
|
||||||
currentItemTextAlign: TextAlign;
|
currentItemTextAlign: TextAlign;
|
||||||
|
|||||||
@ -49,7 +49,7 @@
|
|||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@braintree/sanitize-url": "6.0.2",
|
"@braintree/sanitize-url": "6.0.2",
|
||||||
"@excalidraw/laser-pointer": "1.3.1",
|
"@excalidraw/laser-pointer": "1.3.2",
|
||||||
"browser-fs-access": "0.29.1",
|
"browser-fs-access": "0.29.1",
|
||||||
"open-color": "1.9.1",
|
"open-color": "1.9.1",
|
||||||
"pako": "2.0.3",
|
"pako": "2.0.3",
|
||||||
|
|||||||
@ -20,6 +20,7 @@ exports[`exportToSvg > with default arguments 1`] = `
|
|||||||
"currentItemBackgroundColor": "transparent",
|
"currentItemBackgroundColor": "transparent",
|
||||||
"currentItemEndArrowhead": "arrow",
|
"currentItemEndArrowhead": "arrow",
|
||||||
"currentItemFillStyle": "solid",
|
"currentItemFillStyle": "solid",
|
||||||
|
"currentItemFixedStrokeWidth": true,
|
||||||
"currentItemFontFamily": 5,
|
"currentItemFontFamily": 5,
|
||||||
"currentItemFontSize": 20,
|
"currentItemFontSize": 20,
|
||||||
"currentItemOpacity": 100,
|
"currentItemOpacity": 100,
|
||||||
|
|||||||
@ -1442,10 +1442,10 @@
|
|||||||
resolved "https://registry.yarnpkg.com/@excalidraw/eslint-config/-/eslint-config-1.0.3.tgz#2122ef7413ae77874ae9848ce0f1c6b3f0d8bbbd"
|
resolved "https://registry.yarnpkg.com/@excalidraw/eslint-config/-/eslint-config-1.0.3.tgz#2122ef7413ae77874ae9848ce0f1c6b3f0d8bbbd"
|
||||||
integrity sha512-GemHNF5Z6ga0BWBSX7GJaNBUchLu6RwTcAB84eX1MeckRNhNasAsPCdelDlFalz27iS4RuYEQh0bPE8SRxJgbQ==
|
integrity sha512-GemHNF5Z6ga0BWBSX7GJaNBUchLu6RwTcAB84eX1MeckRNhNasAsPCdelDlFalz27iS4RuYEQh0bPE8SRxJgbQ==
|
||||||
|
|
||||||
"@excalidraw/laser-pointer@1.3.1":
|
"@excalidraw/laser-pointer@1.3.2":
|
||||||
version "1.3.1"
|
version "1.3.2"
|
||||||
resolved "https://registry.yarnpkg.com/@excalidraw/laser-pointer/-/laser-pointer-1.3.1.tgz#7c40836598e8e6ad91f01057883ed8b88fb9266c"
|
resolved "https://registry.yarnpkg.com/@excalidraw/laser-pointer/-/laser-pointer-1.3.2.tgz#1f91182dfc77291df72551c83fa7bf9d740ad9ae"
|
||||||
integrity sha512-psA1z1N2qeAfsORdXc9JmD2y4CmDwmuMRxnNdJHZexIcPwaNEyIpNcelw+QkL9rz9tosaN9krXuKaRqYpRAR6g==
|
integrity sha512-aKhVj3/lLV7TCkZr6q5kn9sBFxzpOQ/yyRwBGm6smsakMdp0o1FVp9HNKOPerEpkKEt34VTURekZLfqa3E1Few==
|
||||||
|
|
||||||
"@excalidraw/markdown-to-text@0.1.2":
|
"@excalidraw/markdown-to-text@0.1.2":
|
||||||
version "0.1.2"
|
version "0.1.2"
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user