@zsviczian/excalidraw 0.9.0-obsidian-13 → 0.9.0-obsidian-image-support-9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +61 -8
- package/README.md +1 -1
- package/dist/excalidraw-assets-dev/{image-7e0eecf06fd4ae95db83.js → image-4d82da8a5abfcee0a489.js} +1 -1
- package/dist/excalidraw.development.js +129 -64
- package/dist/excalidraw.production.min.js +1 -1
- package/dist/excalidraw.production.min.js.LICENSE.txt +22 -0
- package/package.json +1 -1
- package/types/actions/actionCanvas.d.ts +4 -2
- package/types/actions/manager.d.ts +3 -11
- package/types/actions/types.d.ts +2 -8
- package/types/appState.d.ts +10 -4
- package/types/clipboard.d.ts +1 -0
- package/types/components/Actions.d.ts +5 -2
- package/types/components/App.d.ts +21 -5
- package/types/components/DarkModeToggle.d.ts +3 -3
- package/types/components/InitializeApp.d.ts +2 -10
- package/types/components/LayerUI.d.ts +4 -1
- package/types/components/LibraryUnit.d.ts +3 -2
- package/types/components/MobileMenu.d.ts +4 -1
- package/types/components/ToolButton.d.ts +5 -2
- package/types/components/icons.d.ts +41 -40
- package/types/constants.d.ts +8 -0
- package/types/data/blob.d.ts +13 -2
- package/types/data/encode.d.ts +29 -1
- package/types/data/json.d.ts +1 -1
- package/types/element/collision.d.ts +2 -2
- package/types/element/dragElements.d.ts +1 -1
- package/types/element/index.d.ts +2 -1
- package/types/element/mutateElement.d.ts +1 -1
- package/types/element/newElement.d.ts +4 -1
- package/types/element/resizeElements.d.ts +3 -3
- package/types/element/typeChecks.d.ts +3 -1
- package/types/element/types.d.ts +16 -3
- package/types/keys.d.ts +4 -3
- package/types/packages/excalidraw/dist/excalidraw-assets-dev/image-4d82da8a5abfcee0a489.d.ts +0 -0
- package/types/packages/excalidraw/index.d.ts +1 -1
- package/types/packages/excalidraw/webpack.prod.config.d.ts +3 -1
- package/types/packages/utils.d.ts +1 -1
- package/types/renderer/renderElement.d.ts +3 -2
- package/types/renderer/renderScene.d.ts +3 -2
- package/types/scene/export.d.ts +2 -1
- package/types/scene/types.d.ts +3 -2
- package/types/shapes.d.ts +5 -1
- package/types/types.d.ts +29 -4
- package/types/utils.d.ts +1 -0
- package/types/zindex.d.ts +2 -2
- package/dist/excalidraw-assets-dev/image-bd6a627ff1bbdbae8366.js +0 -32
- package/dist/excalidraw-assets-dev/vendor-ac67d7e09cdab8faffe3.js +0 -323
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import * as GA from "../ga";
|
|
2
|
-
import { NonDeletedExcalidrawElement, ExcalidrawBindableElement, ExcalidrawElement, ExcalidrawRectangleElement, ExcalidrawDiamondElement, ExcalidrawTextElement, ExcalidrawEllipseElement, NonDeleted } from "./types";
|
|
2
|
+
import { NonDeletedExcalidrawElement, ExcalidrawBindableElement, ExcalidrawElement, ExcalidrawRectangleElement, ExcalidrawDiamondElement, ExcalidrawTextElement, ExcalidrawEllipseElement, NonDeleted, ExcalidrawImageElement } from "./types";
|
|
3
3
|
import { Point } from "../types";
|
|
4
4
|
import { AppState } from "../types";
|
|
5
5
|
export declare const hitTest: (element: NonDeletedExcalidrawElement, appState: AppState, x: number, y: number) => boolean;
|
|
@@ -16,4 +16,4 @@ export declare const determineFocusPoint: (element: ExcalidrawBindableElement, f
|
|
|
16
16
|
export declare const intersectElementWithLine: (element: ExcalidrawBindableElement, a: readonly [number, number], b: readonly [number, number], gap?: number) => Point[];
|
|
17
17
|
export declare const getCircleIntersections: (center: readonly [number, number, number, number, number, number, number, number], radius: number, line: readonly [number, number, number, number, number, number, number, number]) => GA.Point[];
|
|
18
18
|
export declare const findFocusPointForEllipse: (ellipse: ExcalidrawEllipseElement, relativeDistance: number, point: readonly [number, number, number, number, number, number, number, number]) => readonly [number, number, number, number, number, number, number, number];
|
|
19
|
-
export declare const findFocusPointForRectangulars: (element: ExcalidrawRectangleElement | ExcalidrawDiamondElement | ExcalidrawTextElement, relativeDistance: number, point: readonly [number, number, number, number, number, number, number, number]) => readonly [number, number, number, number, number, number, number, number];
|
|
19
|
+
export declare const findFocusPointForRectangulars: (element: ExcalidrawRectangleElement | ExcalidrawImageElement | ExcalidrawDiamondElement | ExcalidrawTextElement, relativeDistance: number, point: readonly [number, number, number, number, number, number, number, number]) => readonly [number, number, number, number, number, number, number, number];
|
|
@@ -4,4 +4,4 @@ import { NonDeletedExcalidrawElement } from "./types";
|
|
|
4
4
|
import { PointerDownState } from "../types";
|
|
5
5
|
export declare const dragSelectedElements: (pointerDownState: PointerDownState, selectedElements: NonDeletedExcalidrawElement[], pointerX: number, pointerY: number, scene: Scene, lockDirection?: boolean, distanceX?: number, distanceY?: number) => void;
|
|
6
6
|
export declare const getDragOffsetXY: (selectedElements: NonDeletedExcalidrawElement[], x: number, y: number) => [number, number];
|
|
7
|
-
export declare const dragNewElement: (draggingElement: NonDeletedExcalidrawElement, elementType: typeof SHAPES[number]["value"], originX: number, originY: number, x: number, y: number, width: number, height: number,
|
|
7
|
+
export declare const dragNewElement: (draggingElement: NonDeletedExcalidrawElement, elementType: typeof SHAPES[number]["value"], originX: number, originY: number, x: number, y: number, width: number, height: number, shouldMaintainAspectRatio: boolean, shouldResizeFromCenter: boolean, widthAspectRatio?: number | null | undefined) => void;
|
package/types/element/index.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { ExcalidrawElement, NonDeletedExcalidrawElement, NonDeleted } from "./types";
|
|
2
|
-
export { newElement, newTextElement, updateTextElement, newLinearElement, duplicateElement, } from "./newElement";
|
|
2
|
+
export { newElement, newTextElement, updateTextElement, newLinearElement, newImageElement, duplicateElement, } from "./newElement";
|
|
3
3
|
export { getElementAbsoluteCoords, getElementBounds, getCommonBounds, getDiamondPoints, getArrowheadPoints, getClosestElementBounds, } from "./bounds";
|
|
4
4
|
export { OMIT_SIDES_FOR_MULTIPLE_ELEMENTS, getTransformHandlesFromCoords, getTransformHandles, } from "./transformHandles";
|
|
5
5
|
export { hitTest, isHittingElementBoundingBoxWithoutHittingElement, } from "./collision";
|
|
@@ -18,5 +18,6 @@ export declare const getSceneVersion: (elements: readonly ExcalidrawElement[]) =
|
|
|
18
18
|
export declare const getVisibleElements: (elements: readonly ExcalidrawElement[]) => readonly NonDeletedExcalidrawElement[];
|
|
19
19
|
export declare const getNonDeletedElements: (elements: readonly ExcalidrawElement[]) => readonly NonDeletedExcalidrawElement[];
|
|
20
20
|
export declare const isNonDeletedElement: <T extends ExcalidrawElement>(element: T) => element is NonDeleted<T>;
|
|
21
|
+
export declare const clearElementsForDatabase: (elements: readonly ExcalidrawElement[]) => ExcalidrawElement[];
|
|
21
22
|
export declare const clearElementsForExport: (elements: readonly ExcalidrawElement[]) => ExcalidrawElement[];
|
|
22
23
|
export declare const clearElementsForLocalStorage: (elements: readonly ExcalidrawElement[]) => ExcalidrawElement[];
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { ExcalidrawElement } from "./types";
|
|
2
2
|
declare type ElementUpdate<TElement extends ExcalidrawElement> = Omit<Partial<TElement>, "id" | "version" | "versionNonce">;
|
|
3
|
-
export declare const mutateElement: <TElement extends Mutable<ExcalidrawElement>>(element: TElement, updates: ElementUpdate<TElement
|
|
3
|
+
export declare const mutateElement: <TElement extends Mutable<ExcalidrawElement>>(element: TElement, updates: ElementUpdate<TElement>, informMutation?: boolean) => TElement;
|
|
4
4
|
export declare const newElementWith: <TElement extends ExcalidrawElement>(element: TElement, updates: ElementUpdate<TElement>) => TElement;
|
|
5
5
|
/**
|
|
6
6
|
* Mutates element and updates `version` & `versionNonce`.
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ExcalidrawElement, ExcalidrawTextElement, ExcalidrawLinearElement, ExcalidrawGenericElement, NonDeleted, TextAlign, GroupId, VerticalAlign, Arrowhead, ExcalidrawFreeDrawElement, FontFamilyValues } from "../element/types";
|
|
1
|
+
import { ExcalidrawElement, ExcalidrawImageElement, ExcalidrawTextElement, ExcalidrawLinearElement, ExcalidrawGenericElement, NonDeleted, TextAlign, GroupId, VerticalAlign, Arrowhead, ExcalidrawFreeDrawElement, FontFamilyValues } from "../element/types";
|
|
2
2
|
import { AppState } from "../types";
|
|
3
3
|
declare type ElementConstructorOpts = MarkOptional<Omit<ExcalidrawGenericElement, "id" | "type" | "isDeleted">, "width" | "height" | "angle" | "groupIds" | "boundElementIds" | "seed" | "version" | "versionNonce">;
|
|
4
4
|
export declare const newElement: (opts: {
|
|
@@ -28,6 +28,9 @@ export declare const newLinearElement: (opts: {
|
|
|
28
28
|
endArrowhead: Arrowhead | null;
|
|
29
29
|
points?: ExcalidrawLinearElement["points"];
|
|
30
30
|
} & ElementConstructorOpts) => NonDeleted<ExcalidrawLinearElement>;
|
|
31
|
+
export declare const newImageElement: (opts: {
|
|
32
|
+
type: ExcalidrawImageElement["type"];
|
|
33
|
+
} & ElementConstructorOpts) => NonDeleted<ExcalidrawImageElement>;
|
|
31
34
|
export declare const deepCopyElement: (val: any, depth?: number) => any;
|
|
32
35
|
/**
|
|
33
36
|
* Duplicate an element, often used in the alt-drag operation.
|
|
@@ -2,8 +2,8 @@ import { ExcalidrawLinearElement, NonDeletedExcalidrawElement, NonDeleted } from
|
|
|
2
2
|
import { MaybeTransformHandleType, TransformHandleDirection } from "./transformHandles";
|
|
3
3
|
import { PointerDownState } from "../types";
|
|
4
4
|
export declare const normalizeAngle: (angle: number) => number;
|
|
5
|
-
export declare const transformElements: (pointerDownState: PointerDownState, transformHandleType: MaybeTransformHandleType, selectedElements: readonly NonDeletedExcalidrawElement[], resizeArrowDirection: "origin" | "end",
|
|
6
|
-
export declare const reshapeSingleTwoPointElement: (element: NonDeleted<ExcalidrawLinearElement>, resizeArrowDirection: "origin" | "end",
|
|
7
|
-
export declare const resizeSingleElement: (stateAtResizeStart: NonDeletedExcalidrawElement,
|
|
5
|
+
export declare const transformElements: (pointerDownState: PointerDownState, transformHandleType: MaybeTransformHandleType, selectedElements: readonly NonDeletedExcalidrawElement[], resizeArrowDirection: "origin" | "end", shouldRotateWithDiscreteAngle: boolean, shouldResizeFromCenter: boolean, shouldMaintainAspectRatio: boolean, pointerX: number, pointerY: number, centerX: number, centerY: number) => boolean;
|
|
6
|
+
export declare const reshapeSingleTwoPointElement: (element: NonDeleted<ExcalidrawLinearElement>, resizeArrowDirection: "origin" | "end", shouldRotateWithDiscreteAngle: boolean, pointerX: number, pointerY: number) => void;
|
|
7
|
+
export declare const resizeSingleElement: (stateAtResizeStart: NonDeletedExcalidrawElement, shouldMaintainAspectRatio: boolean, element: NonDeletedExcalidrawElement, transformHandleDirection: TransformHandleDirection, shouldResizeFromCenter: boolean, pointerX: number, pointerY: number) => void;
|
|
8
8
|
export declare const getResizeOffsetXY: (transformHandleType: MaybeTransformHandleType, selectedElements: NonDeletedExcalidrawElement[], x: number, y: number) => [number, number];
|
|
9
9
|
export declare const getResizeArrowDirection: (transformHandleType: MaybeTransformHandleType, element: NonDeleted<ExcalidrawLinearElement>) => "origin" | "end";
|
|
@@ -1,5 +1,7 @@
|
|
|
1
|
-
import { ExcalidrawElement, ExcalidrawTextElement, ExcalidrawLinearElement, ExcalidrawBindableElement, ExcalidrawGenericElement, ExcalidrawFreeDrawElement } from "./types";
|
|
1
|
+
import { ExcalidrawElement, ExcalidrawTextElement, ExcalidrawLinearElement, ExcalidrawBindableElement, ExcalidrawGenericElement, ExcalidrawFreeDrawElement, InitializedExcalidrawImageElement, ExcalidrawImageElement } from "./types";
|
|
2
2
|
export declare const isGenericElement: (element: ExcalidrawElement | null) => element is ExcalidrawGenericElement;
|
|
3
|
+
export declare const isInitializedImageElement: (element: ExcalidrawElement | null) => element is InitializedExcalidrawImageElement;
|
|
4
|
+
export declare const isImageElement: (element: ExcalidrawElement | null) => element is ExcalidrawImageElement;
|
|
3
5
|
export declare const isTextElement: (element: ExcalidrawElement | null) => element is ExcalidrawTextElement;
|
|
4
6
|
export declare const isFreeDrawElement: (element?: ExcalidrawElement | null | undefined) => element is ExcalidrawFreeDrawElement;
|
|
5
7
|
export declare const isFreeDrawElementType: (elementType: ExcalidrawElement["type"]) => boolean;
|
package/types/element/types.d.ts
CHANGED
|
@@ -1,9 +1,10 @@
|
|
|
1
1
|
import { Point } from "../types";
|
|
2
|
-
import { FONT_FAMILY } from "../constants";
|
|
2
|
+
import { FONT_FAMILY, THEME } from "../constants";
|
|
3
3
|
export declare type ChartType = "bar" | "line";
|
|
4
4
|
export declare type FillStyle = "hachure" | "cross-hatch" | "solid";
|
|
5
5
|
export declare type FontFamilyKeys = keyof typeof FONT_FAMILY;
|
|
6
6
|
export declare type FontFamilyValues = typeof FONT_FAMILY[FontFamilyKeys];
|
|
7
|
+
export declare type Theme = typeof THEME[keyof typeof THEME];
|
|
7
8
|
export declare type FontString = string & {
|
|
8
9
|
_brand: "fontString";
|
|
9
10
|
};
|
|
@@ -57,6 +58,15 @@ export declare type ExcalidrawDiamondElement = _ExcalidrawElementBase & {
|
|
|
57
58
|
export declare type ExcalidrawEllipseElement = _ExcalidrawElementBase & {
|
|
58
59
|
type: "ellipse";
|
|
59
60
|
};
|
|
61
|
+
export declare type ExcalidrawImageElement = _ExcalidrawElementBase & Readonly<{
|
|
62
|
+
type: "image";
|
|
63
|
+
fileId: FileId | null;
|
|
64
|
+
/** whether respective file is persisted */
|
|
65
|
+
status: "pending" | "saved" | "error";
|
|
66
|
+
/** X and Y scale factors <-1, 1>, used for image axis flipping */
|
|
67
|
+
scale: [number, number];
|
|
68
|
+
}>;
|
|
69
|
+
export declare type InitializedExcalidrawImageElement = MarkNonNullable<ExcalidrawImageElement, "fileId">;
|
|
60
70
|
/**
|
|
61
71
|
* These are elements that don't have any additional properties.
|
|
62
72
|
*/
|
|
@@ -66,7 +76,7 @@ export declare type ExcalidrawGenericElement = ExcalidrawSelectionElement | Exca
|
|
|
66
76
|
* no computed data. The list of all ExcalidrawElements should be shareable
|
|
67
77
|
* between peers and contain no state local to the peer.
|
|
68
78
|
*/
|
|
69
|
-
export declare type ExcalidrawElement = ExcalidrawGenericElement | ExcalidrawTextElement | ExcalidrawLinearElement | ExcalidrawFreeDrawElement;
|
|
79
|
+
export declare type ExcalidrawElement = ExcalidrawGenericElement | ExcalidrawTextElement | ExcalidrawLinearElement | ExcalidrawFreeDrawElement | ExcalidrawImageElement;
|
|
70
80
|
export declare type NonDeleted<TElement extends ExcalidrawElement> = TElement & {
|
|
71
81
|
isDeleted: false;
|
|
72
82
|
};
|
|
@@ -81,7 +91,7 @@ export declare type ExcalidrawTextElement = _ExcalidrawElementBase & Readonly<{
|
|
|
81
91
|
textAlign: TextAlign;
|
|
82
92
|
verticalAlign: VerticalAlign;
|
|
83
93
|
}>;
|
|
84
|
-
export declare type ExcalidrawBindableElement = ExcalidrawRectangleElement | ExcalidrawDiamondElement | ExcalidrawEllipseElement | ExcalidrawTextElement;
|
|
94
|
+
export declare type ExcalidrawBindableElement = ExcalidrawRectangleElement | ExcalidrawDiamondElement | ExcalidrawEllipseElement | ExcalidrawTextElement | ExcalidrawImageElement;
|
|
85
95
|
export declare type PointBinding = {
|
|
86
96
|
elementId: ExcalidrawBindableElement["id"];
|
|
87
97
|
focus: number;
|
|
@@ -104,4 +114,7 @@ export declare type ExcalidrawFreeDrawElement = _ExcalidrawElementBase & Readonl
|
|
|
104
114
|
simulatePressure: boolean;
|
|
105
115
|
lastCommittedPoint: Point | null;
|
|
106
116
|
}>;
|
|
117
|
+
export declare type FileId = string & {
|
|
118
|
+
_brand: "FileId";
|
|
119
|
+
};
|
|
107
120
|
export {};
|
package/types/keys.d.ts
CHANGED
|
@@ -42,6 +42,7 @@ export declare const KEYS: {
|
|
|
42
42
|
readonly D: "d";
|
|
43
43
|
readonly E: "e";
|
|
44
44
|
readonly G: "g";
|
|
45
|
+
readonly I: "i";
|
|
45
46
|
readonly L: "l";
|
|
46
47
|
readonly O: "o";
|
|
47
48
|
readonly P: "p";
|
|
@@ -56,6 +57,6 @@ export declare const KEYS: {
|
|
|
56
57
|
};
|
|
57
58
|
export declare type Key = keyof typeof KEYS;
|
|
58
59
|
export declare const isArrowKey: (key: string) => boolean;
|
|
59
|
-
export declare const
|
|
60
|
-
export declare const
|
|
61
|
-
export declare const
|
|
60
|
+
export declare const shouldResizeFromCenter: (event: MouseEvent | KeyboardEvent) => boolean;
|
|
61
|
+
export declare const shouldMaintainAspectRatio: (event: MouseEvent | KeyboardEvent) => boolean;
|
|
62
|
+
export declare const shouldRotateWithDiscreteAngle: (event: MouseEvent | KeyboardEvent) => boolean;
|
|
File without changes
|
|
@@ -10,4 +10,4 @@ export { getSceneVersion, getElementMap, isInvisiblySmallElement, } from "../../
|
|
|
10
10
|
export { defaultLang, languages } from "../../i18n";
|
|
11
11
|
export { restore, restoreAppState, restoreElements } from "../../data/restore";
|
|
12
12
|
export { exportToCanvas, exportToBlob, exportToSvg, serializeAsJSON, loadLibraryFromBlob, loadFromBlob, getFreeDrawSvgPath, } from "../../packages/utils";
|
|
13
|
-
export { FONT_FAMILY } from "../../constants";
|
|
13
|
+
export { FONT_FAMILY, THEME } from "../../constants";
|
|
@@ -9,7 +9,7 @@ declare type ExportOpts = {
|
|
|
9
9
|
scale: number;
|
|
10
10
|
};
|
|
11
11
|
};
|
|
12
|
-
export declare const exportToCanvas: ({ elements, appState, getDimensions, }: ExportOpts) => HTMLCanvasElement
|
|
12
|
+
export declare const exportToCanvas: ({ elements, appState, getDimensions, }: ExportOpts) => Promise<HTMLCanvasElement>;
|
|
13
13
|
export declare const exportToBlob: (opts: ExportOpts & {
|
|
14
14
|
mimeType?: string;
|
|
15
15
|
quality?: number;
|
|
@@ -3,10 +3,11 @@ import { RoughCanvas } from "roughjs/bin/canvas";
|
|
|
3
3
|
import { Drawable, Options } from "roughjs/bin/core";
|
|
4
4
|
import { RoughSVG } from "roughjs/bin/svg";
|
|
5
5
|
import { SceneState } from "../scene/types";
|
|
6
|
-
import { Zoom } from "../types";
|
|
6
|
+
import { AppState, Zoom } from "../types";
|
|
7
7
|
export interface ExcalidrawElementWithCanvas {
|
|
8
8
|
element: ExcalidrawElement | ExcalidrawTextElement;
|
|
9
9
|
canvas: HTMLCanvasElement;
|
|
10
|
+
theme: SceneState["theme"];
|
|
10
11
|
canvasZoom: Zoom["value"];
|
|
11
12
|
canvasOffsetX: number;
|
|
12
13
|
canvasOffsetY: number;
|
|
@@ -15,7 +16,7 @@ export declare const getShapeForElement: (element: ExcalidrawElement) => Drawabl
|
|
|
15
16
|
export declare const invalidateShapeForElement: (element: ExcalidrawElement) => boolean;
|
|
16
17
|
export declare const generateRoughOptions: (element: ExcalidrawElement, continuousPath?: boolean) => Options;
|
|
17
18
|
export declare const renderElement: (element: NonDeletedExcalidrawElement, rc: RoughCanvas, context: CanvasRenderingContext2D, renderOptimizations: boolean, sceneState: SceneState) => void;
|
|
18
|
-
export declare const renderElementToSvg: (element: NonDeletedExcalidrawElement, rsvg: RoughSVG, svgRoot: SVGElement, offsetX?: number | undefined, offsetY?: number | undefined) => void;
|
|
19
|
+
export declare const renderElementToSvg: (element: NonDeletedExcalidrawElement, rsvg: RoughSVG, svgRoot: SVGElement, files: AppState["files"], offsetX?: number | undefined, offsetY?: number | undefined) => void;
|
|
19
20
|
export declare const pathsCache: WeakMap<ExcalidrawFreeDrawElement, Path2D>;
|
|
20
21
|
export declare function generateFreeDrawShape(element: ExcalidrawFreeDrawElement): Path2D;
|
|
21
22
|
export declare function getFreeDrawPath2D(element: ExcalidrawFreeDrawElement): Path2D | undefined;
|
|
@@ -3,11 +3,12 @@ import { RoughSVG } from "roughjs/bin/svg";
|
|
|
3
3
|
import { AppState } from "../types";
|
|
4
4
|
import { NonDeletedExcalidrawElement } from "../element/types";
|
|
5
5
|
import { SceneState } from "../scene/types";
|
|
6
|
-
export declare const renderScene: (elements: readonly NonDeletedExcalidrawElement[], appState: AppState, selectionElement: NonDeletedExcalidrawElement | null, scale: number, rc: RoughCanvas, canvas: HTMLCanvasElement, sceneState: SceneState, { renderScrollbars, renderSelection, renderOptimizations, renderGrid, }?: {
|
|
6
|
+
export declare const renderScene: (elements: readonly NonDeletedExcalidrawElement[], appState: AppState, selectionElement: NonDeletedExcalidrawElement | null, scale: number, rc: RoughCanvas, canvas: HTMLCanvasElement, sceneState: SceneState, { renderScrollbars, renderSelection, renderOptimizations, renderGrid, isExport, }?: {
|
|
7
7
|
renderScrollbars?: boolean | undefined;
|
|
8
8
|
renderSelection?: boolean | undefined;
|
|
9
9
|
renderOptimizations?: boolean | undefined;
|
|
10
10
|
renderGrid?: boolean | undefined;
|
|
11
|
+
isExport?: boolean | undefined;
|
|
11
12
|
}) => {
|
|
12
13
|
atLeastOneVisibleElement: boolean;
|
|
13
14
|
scrollBars?: undefined;
|
|
@@ -15,7 +16,7 @@ export declare const renderScene: (elements: readonly NonDeletedExcalidrawElemen
|
|
|
15
16
|
atLeastOneVisibleElement: boolean;
|
|
16
17
|
scrollBars: import("../scene/types").ScrollBars | undefined;
|
|
17
18
|
};
|
|
18
|
-
export declare const renderSceneToSvg: (elements: readonly NonDeletedExcalidrawElement[], rsvg: RoughSVG, svgRoot: SVGElement, { offsetX, offsetY, }?: {
|
|
19
|
+
export declare const renderSceneToSvg: (elements: readonly NonDeletedExcalidrawElement[], rsvg: RoughSVG, svgRoot: SVGElement, files: AppState["files"], { offsetX, offsetY, }?: {
|
|
19
20
|
offsetX?: number | undefined;
|
|
20
21
|
offsetY?: number | undefined;
|
|
21
22
|
}) => void;
|
package/types/scene/export.d.ts
CHANGED
|
@@ -8,7 +8,7 @@ export declare const exportToCanvas: (elements: readonly NonDeletedExcalidrawEle
|
|
|
8
8
|
}, createCanvas?: (width: number, height: number) => {
|
|
9
9
|
canvas: HTMLCanvasElement;
|
|
10
10
|
scale: number;
|
|
11
|
-
}) => HTMLCanvasElement
|
|
11
|
+
}) => Promise<HTMLCanvasElement>;
|
|
12
12
|
export declare const exportToSvg: (elements: readonly NonDeletedExcalidrawElement[], appState: {
|
|
13
13
|
exportBackground: boolean;
|
|
14
14
|
exportPadding?: number;
|
|
@@ -16,5 +16,6 @@ export declare const exportToSvg: (elements: readonly NonDeletedExcalidrawElemen
|
|
|
16
16
|
viewBackgroundColor: string;
|
|
17
17
|
exportWithDarkMode?: boolean;
|
|
18
18
|
exportEmbedScene?: boolean;
|
|
19
|
+
files: AppState["files"];
|
|
19
20
|
}) => Promise<SVGSVGElement>;
|
|
20
21
|
export declare const getExportSize: (elements: readonly NonDeletedExcalidrawElement[], exportPadding: number, scale: number) => [number, number];
|
package/types/scene/types.d.ts
CHANGED
|
@@ -1,10 +1,9 @@
|
|
|
1
1
|
import { ExcalidrawTextElement } from "../element/types";
|
|
2
|
-
import { Zoom } from "../types";
|
|
2
|
+
import { AppClassProperties, AppState, Zoom } from "../types";
|
|
3
3
|
export declare type SceneState = {
|
|
4
4
|
scrollX: number;
|
|
5
5
|
scrollY: number;
|
|
6
6
|
viewBackgroundColor: string | null;
|
|
7
|
-
exportWithDarkMode?: boolean;
|
|
8
7
|
zoom: Zoom;
|
|
9
8
|
shouldCacheIgnoreZoom: boolean;
|
|
10
9
|
remotePointerViewportCoords: {
|
|
@@ -25,6 +24,8 @@ export declare type SceneState = {
|
|
|
25
24
|
remotePointerUserStates: {
|
|
26
25
|
[id: string]: string;
|
|
27
26
|
};
|
|
27
|
+
theme: AppState["theme"];
|
|
28
|
+
imageCache: AppClassProperties["imageCache"];
|
|
28
29
|
};
|
|
29
30
|
export declare type SceneScroll = {
|
|
30
31
|
scrollX: number;
|
package/types/shapes.d.ts
CHANGED
|
@@ -31,5 +31,9 @@ export declare const SHAPES: readonly [{
|
|
|
31
31
|
readonly icon: JSX.Element;
|
|
32
32
|
readonly value: "text";
|
|
33
33
|
readonly key: "t";
|
|
34
|
+
}, {
|
|
35
|
+
readonly icon: JSX.Element;
|
|
36
|
+
readonly value: "image";
|
|
37
|
+
readonly key: "i";
|
|
34
38
|
}];
|
|
35
|
-
export declare const findShapeByKey: (key: string) => "line" | "selection" | "rectangle" | "diamond" | "ellipse" | "text" | "arrow" | "freedraw" | null;
|
|
39
|
+
export declare const findShapeByKey: (key: string) => "line" | "selection" | "rectangle" | "diamond" | "ellipse" | "image" | "text" | "arrow" | "freedraw" | null;
|
package/types/types.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
|
-
import { PointerType, ExcalidrawLinearElement, NonDeletedExcalidrawElement, NonDeleted, TextAlign, ExcalidrawElement, GroupId, ExcalidrawBindableElement, Arrowhead, ChartType, FontFamilyValues, ExcalidrawTextElement } from "./element/types";
|
|
2
|
+
import { PointerType, ExcalidrawLinearElement, NonDeletedExcalidrawElement, NonDeleted, TextAlign, ExcalidrawElement, GroupId, ExcalidrawBindableElement, Arrowhead, ChartType, FontFamilyValues, FileId, ExcalidrawTextElement, ExcalidrawImageElement, Theme } from "./element/types";
|
|
3
3
|
import { SHAPES } from "./shapes";
|
|
4
4
|
import { Point as RoughPoint } from "roughjs/bin/geometry";
|
|
5
5
|
import { LinearElementEditor } from "./element/linearElementEditor";
|
|
@@ -12,7 +12,8 @@ import { Language } from "./i18n";
|
|
|
12
12
|
import { ClipboardData } from "./clipboard";
|
|
13
13
|
import { isOverScrollBars } from "./scene";
|
|
14
14
|
import { MaybeTransformHandleType } from "./element/transformHandles";
|
|
15
|
-
import
|
|
15
|
+
import Library from "./data/library";
|
|
16
|
+
import type { FileSystemHandle } from "./data/filesystem";
|
|
16
17
|
export declare type Point = Readonly<RoughPoint>;
|
|
17
18
|
export declare type Collaborator = {
|
|
18
19
|
pointer?: {
|
|
@@ -28,7 +29,18 @@ export declare type Collaborator = {
|
|
|
28
29
|
stroke: string;
|
|
29
30
|
};
|
|
30
31
|
};
|
|
32
|
+
export declare type DataURL = string & {
|
|
33
|
+
_brand: "DataURL";
|
|
34
|
+
};
|
|
35
|
+
export declare type BinaryFileData = {
|
|
36
|
+
type: "image" | "other";
|
|
37
|
+
id: FileId;
|
|
38
|
+
dataURL: DataURL;
|
|
39
|
+
created: number;
|
|
40
|
+
};
|
|
41
|
+
export declare type BinaryFileMetadata = Omit<BinaryFileData, "dataURL">;
|
|
31
42
|
export declare type AppState = {
|
|
43
|
+
files: Record<ExcalidrawElement["id"], BinaryFileData>;
|
|
32
44
|
isLoading: boolean;
|
|
33
45
|
errorMessage: string | null;
|
|
34
46
|
draggingElement: NonDeletedExcalidrawElement | null;
|
|
@@ -82,7 +94,7 @@ export declare type AppState = {
|
|
|
82
94
|
showHelpDialog: boolean;
|
|
83
95
|
toastMessage: string | null;
|
|
84
96
|
zenModeEnabled: boolean;
|
|
85
|
-
theme:
|
|
97
|
+
theme: Theme;
|
|
86
98
|
gridSize: number | null;
|
|
87
99
|
viewModeEnabled: boolean;
|
|
88
100
|
/** top-most selected groups (i.e. does not include nested groups) */
|
|
@@ -108,6 +120,8 @@ export declare type AppState = {
|
|
|
108
120
|
shown: true;
|
|
109
121
|
data: Spreadsheet;
|
|
110
122
|
};
|
|
123
|
+
/** imageElement waiting to be placed on canvas */
|
|
124
|
+
pendingImageElement: NonDeleted<ExcalidrawImageElement> | null;
|
|
111
125
|
};
|
|
112
126
|
export declare type NormalizedZoomValue = number & {
|
|
113
127
|
_brand: "normalizedZoom";
|
|
@@ -165,7 +179,7 @@ export interface ExcalidrawProps {
|
|
|
165
179
|
zenModeEnabled?: boolean;
|
|
166
180
|
gridModeEnabled?: boolean;
|
|
167
181
|
libraryReturnUrl?: string;
|
|
168
|
-
theme?:
|
|
182
|
+
theme?: Theme;
|
|
169
183
|
name?: string;
|
|
170
184
|
renderCustomStats?: (elements: readonly NonDeletedExcalidrawElement[], appState: AppState) => JSX.Element;
|
|
171
185
|
UIOptions?: UIOptions;
|
|
@@ -175,6 +189,7 @@ export interface ExcalidrawProps {
|
|
|
175
189
|
autoFocus?: boolean;
|
|
176
190
|
onBeforeTextEdit?: (textElement: ExcalidrawTextElement) => string;
|
|
177
191
|
onBeforeTextSubmit?: (textElement: ExcalidrawTextElement, textToSubmit: string, isDeleted: boolean) => string;
|
|
192
|
+
generateIdForFile?: (file: File) => string | Promise<string>;
|
|
178
193
|
}
|
|
179
194
|
export declare type SceneData = {
|
|
180
195
|
elements?: ImportedDataState["elements"];
|
|
@@ -213,6 +228,15 @@ export declare type AppProps = ExcalidrawProps & {
|
|
|
213
228
|
detectScroll: boolean;
|
|
214
229
|
handleKeyboardGlobally: boolean;
|
|
215
230
|
};
|
|
231
|
+
/** A subset of App class properties that we need to use elsewhere
|
|
232
|
+
* in the app, eg Manager. Factored out into a separate type to keep DRY. */
|
|
233
|
+
export declare type AppClassProperties = {
|
|
234
|
+
props: AppProps;
|
|
235
|
+
canvas: HTMLCanvasElement | null;
|
|
236
|
+
focusContainer(): void;
|
|
237
|
+
library: Library;
|
|
238
|
+
imageCache: Map<FileId, HTMLImageElement | Promise<HTMLImageElement>>;
|
|
239
|
+
};
|
|
216
240
|
export declare type PointerDownState = Readonly<{
|
|
217
241
|
origin: Readonly<{
|
|
218
242
|
x: number;
|
|
@@ -277,6 +301,7 @@ export declare type ExcalidrawImperativeAPI = {
|
|
|
277
301
|
refresh: InstanceType<typeof App>["refresh"];
|
|
278
302
|
importLibrary: InstanceType<typeof App>["importLibraryFromUrl"];
|
|
279
303
|
setToastMessage: InstanceType<typeof App>["setToastMessage"];
|
|
304
|
+
addFiles: (data: BinaryFileData[]) => void;
|
|
280
305
|
readyPromise: ResolvablePromise<ExcalidrawImperativeAPI>;
|
|
281
306
|
ready: true;
|
|
282
307
|
id: string;
|
package/types/utils.d.ts
CHANGED
|
@@ -92,3 +92,4 @@ export declare const getVersion: () => string;
|
|
|
92
92
|
export declare const supportsEmoji: () => boolean;
|
|
93
93
|
export declare const getNearestScrollableContainer: (element: HTMLElement) => HTMLElement | Document;
|
|
94
94
|
export declare const focusNearestParent: (element: HTMLInputElement) => void;
|
|
95
|
+
export declare const preventUnload: (event: BeforeUnloadEvent) => void;
|
package/types/zindex.d.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { ExcalidrawElement } from "./element/types";
|
|
2
2
|
import { AppState } from "./types";
|
|
3
|
-
export declare const moveOneLeft: (elements: readonly ExcalidrawElement[], appState: AppState) => (import("./element/types").ExcalidrawLinearElement | import("./element/types").ExcalidrawSelectionElement | import("./element/types").ExcalidrawRectangleElement | import("./element/types").ExcalidrawDiamondElement | import("./element/types").ExcalidrawEllipseElement | import("./element/types").ExcalidrawTextElement | import("./element/types").ExcalidrawFreeDrawElement)[];
|
|
4
|
-
export declare const moveOneRight: (elements: readonly ExcalidrawElement[], appState: AppState) => (import("./element/types").ExcalidrawLinearElement | import("./element/types").ExcalidrawSelectionElement | import("./element/types").ExcalidrawRectangleElement | import("./element/types").ExcalidrawDiamondElement | import("./element/types").ExcalidrawEllipseElement | import("./element/types").ExcalidrawTextElement | import("./element/types").ExcalidrawFreeDrawElement)[];
|
|
3
|
+
export declare const moveOneLeft: (elements: readonly ExcalidrawElement[], appState: AppState) => (import("./element/types").ExcalidrawLinearElement | import("./element/types").ExcalidrawSelectionElement | import("./element/types").ExcalidrawRectangleElement | import("./element/types").ExcalidrawDiamondElement | import("./element/types").ExcalidrawEllipseElement | import("./element/types").ExcalidrawImageElement | import("./element/types").ExcalidrawTextElement | import("./element/types").ExcalidrawFreeDrawElement)[];
|
|
4
|
+
export declare const moveOneRight: (elements: readonly ExcalidrawElement[], appState: AppState) => (import("./element/types").ExcalidrawLinearElement | import("./element/types").ExcalidrawSelectionElement | import("./element/types").ExcalidrawRectangleElement | import("./element/types").ExcalidrawDiamondElement | import("./element/types").ExcalidrawEllipseElement | import("./element/types").ExcalidrawImageElement | import("./element/types").ExcalidrawTextElement | import("./element/types").ExcalidrawFreeDrawElement)[];
|
|
5
5
|
export declare const moveAllLeft: (elements: readonly ExcalidrawElement[], appState: AppState) => readonly ExcalidrawElement[];
|
|
6
6
|
export declare const moveAllRight: (elements: readonly ExcalidrawElement[], appState: AppState) => readonly ExcalidrawElement[];
|
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/*
|
|
3
|
-
* ATTENTION: An "eval-source-map" devtool has been used.
|
|
4
|
-
* This devtool is neither made for production nor for readable output files.
|
|
5
|
-
* It uses "eval()" calls to create a separate source file with attached SourceMaps in the browser devtools.
|
|
6
|
-
* If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
|
|
7
|
-
* or disable the default devtool with "devtool: false".
|
|
8
|
-
* If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
|
|
9
|
-
*/
|
|
10
|
-
(globalThis["webpackChunkExcalidraw"] = globalThis["webpackChunkExcalidraw"] || []).push([["image"],{
|
|
11
|
-
|
|
12
|
-
/***/ "../../data/encode.ts":
|
|
13
|
-
/*!****************************!*\
|
|
14
|
-
!*** ../../data/encode.ts ***!
|
|
15
|
-
\****************************/
|
|
16
|
-
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
17
|
-
|
|
18
|
-
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"toByteString\": () => (/* binding */ toByteString),\n/* harmony export */ \"stringToBase64\": () => (/* binding */ stringToBase64),\n/* harmony export */ \"base64ToString\": () => (/* binding */ base64ToString),\n/* harmony export */ \"encode\": () => (/* binding */ encode),\n/* harmony export */ \"decode\": () => (/* binding */ decode)\n/* harmony export */ });\n/* harmony import */ var _babel_runtime_helpers_asyncToGenerator__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/asyncToGenerator */ \"../../../node_modules/@babel/runtime/helpers/esm/asyncToGenerator.js\");\n/* harmony import */ var pako__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! pako */ \"../../../node_modules/pako/index.js\");\n/* harmony import */ var pako__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(pako__WEBPACK_IMPORTED_MODULE_1__);\n\r\n // -----------------------------------------------------------------------------\r\n// byte (binary) strings\r\n// -----------------------------------------------------------------------------\r\n// fast, Buffer-compatible implem\r\nconst toByteString = function (data) {\r\n return new Promise(function (resolve, reject) {\r\n const blob = typeof data === \"string\" ? new Blob([new TextEncoder().encode(data)]) : new Blob([data]);\r\n const reader = new FileReader();\r\n reader.onload = function (event) {\r\n if (!event.target || typeof event.target.result !== \"string\") {\r\n return reject(new Error(\"couldn't convert to byte string\"));\r\n }\r\n resolve(event.target.result);\r\n };\r\n reader.readAsBinaryString(blob);\r\n });\r\n};\r\nconst byteStringToArrayBuffer = function (byteString) {\r\n const buffer = new ArrayBuffer(byteString.length);\r\n const bufferView = new Uint8Array(buffer);\r\n for (let i = 0, len = byteString.length; i < len; i++) {\r\n bufferView[i] = byteString.charCodeAt(i);\r\n }\r\n return buffer;\r\n};\r\nconst byteStringToString = function (byteString) {\r\n return new TextDecoder(\"utf-8\").decode(byteStringToArrayBuffer(byteString));\r\n}; // -----------------------------------------------------------------------------\r\n// base64\r\n// -----------------------------------------------------------------------------\r\n/**\r\n * @param isByteString set to true if already byte string to prevent bloat\r\n * due to reencoding\r\n */\r\nconst stringToBase64 = /*#__PURE__*/ function () {\r\n var _ref = (0,_babel_runtime_helpers_asyncToGenerator__WEBPACK_IMPORTED_MODULE_0__.default)(function* (str, isByteString = false) {\r\n return isByteString ? btoa(str) : btoa(yield toByteString(str));\r\n });\r\n return function stringToBase64(_x) {\r\n return _ref.apply(this, arguments);\r\n };\r\n}(); // async to align with stringToBase64\r\nconst base64ToString = /*#__PURE__*/ function () {\r\n var _ref2 = (0,_babel_runtime_helpers_asyncToGenerator__WEBPACK_IMPORTED_MODULE_0__.default)(function* (base64, isByteString = false) {\r\n return isByteString ? atob(base64) : byteStringToString(atob(base64));\r\n });\r\n return function base64ToString(_x2) {\r\n return _ref2.apply(this, arguments);\r\n };\r\n}(); // -----------------------------------------------------------------------------\r\n// text encoding\r\n// -----------------------------------------------------------------------------\r\n/**\r\n * Encodes (and potentially compresses via zlib) text to byte string\r\n */\r\nconst encode = /*#__PURE__*/ function () {\r\n var _ref3 = (0,_babel_runtime_helpers_asyncToGenerator__WEBPACK_IMPORTED_MODULE_0__.default)(function* ({ text, compress }) {\r\n let deflated;\r\n if (compress !== false) {\r\n try {\r\n deflated = yield toByteString((0,pako__WEBPACK_IMPORTED_MODULE_1__.deflate)(text));\r\n }\r\n catch (error) {\r\n console.error(\"encode: cannot deflate\", error);\r\n }\r\n }\r\n return {\r\n version: \"1\",\r\n encoding: \"bstring\",\r\n compressed: !!deflated,\r\n encoded: deflated || (yield toByteString(text))\r\n };\r\n });\r\n return function encode(_x3) {\r\n return _ref3.apply(this, arguments);\r\n };\r\n}();\r\nconst decode = /*#__PURE__*/ function () {\r\n var _ref4 = (0,_babel_runtime_helpers_asyncToGenerator__WEBPACK_IMPORTED_MODULE_0__.default)(function* (data) {\r\n let decoded;\r\n switch (data.encoding) {\r\n case \"bstring\":\r\n // if compressed, do not double decode the bstring\r\n decoded = data.compressed ? data.encoded : yield byteStringToString(data.encoded);\r\n break;\r\n default:\r\n throw new Error(`decode: unknown encoding \"${data.encoding}\"`);\r\n }\r\n if (data.compressed) {\r\n return (0,pako__WEBPACK_IMPORTED_MODULE_1__.inflate)(new Uint8Array(byteStringToArrayBuffer(decoded)), {\r\n to: \"string\"\r\n });\r\n }\r\n return decoded;\r\n });\r\n return function decode(_x4) {\r\n return _ref4.apply(this, arguments);\r\n };\r\n}();\r\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../data/encode.ts.js","mappings":"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","sources":["webpack:///../../data/encode.ts?6fcb"],"sourcesContent":["import _asyncToGenerator from \"@babel/runtime/helpers/asyncToGenerator\";\nimport { deflate, inflate } from \"pako\"; // -----------------------------------------------------------------------------\n// byte (binary) strings\n// -----------------------------------------------------------------------------\n// fast, Buffer-compatible implem\n\nexport const toByteString = function (data) {\n  return new Promise(function (resolve, reject) {\n    const blob = typeof data === \"string\" ? new Blob([new TextEncoder().encode(data)]) : new Blob([data]);\n    const reader = new FileReader();\n\n    reader.onload = function (event) {\n      if (!event.target || typeof event.target.result !== \"string\") {\n        return reject(new Error(\"couldn't convert to byte string\"));\n      }\n\n      resolve(event.target.result);\n    };\n\n    reader.readAsBinaryString(blob);\n  });\n};\n\nconst byteStringToArrayBuffer = function (byteString) {\n  const buffer = new ArrayBuffer(byteString.length);\n  const bufferView = new Uint8Array(buffer);\n\n  for (let i = 0, len = byteString.length; i < len; i++) {\n    bufferView[i] = byteString.charCodeAt(i);\n  }\n\n  return buffer;\n};\n\nconst byteStringToString = function (byteString) {\n  return new TextDecoder(\"utf-8\").decode(byteStringToArrayBuffer(byteString));\n}; // -----------------------------------------------------------------------------\n// base64\n// -----------------------------------------------------------------------------\n\n/**\n * @param isByteString set to true if already byte string to prevent bloat\n *  due to reencoding\n */\n\n\nexport const stringToBase64 = /*#__PURE__*/function () {\n  var _ref = _asyncToGenerator(function* (str, isByteString = false) {\n    return isByteString ? btoa(str) : btoa(yield toByteString(str));\n  });\n\n  return function stringToBase64(_x) {\n    return _ref.apply(this, arguments);\n  };\n}(); // async to align with stringToBase64\n\nexport const base64ToString = /*#__PURE__*/function () {\n  var _ref2 = _asyncToGenerator(function* (base64, isByteString = false) {\n    return isByteString ? atob(base64) : byteStringToString(atob(base64));\n  });\n\n  return function base64ToString(_x2) {\n    return _ref2.apply(this, arguments);\n  };\n}(); // -----------------------------------------------------------------------------\n// text encoding\n// -----------------------------------------------------------------------------\n\n/**\n * Encodes (and potentially compresses via zlib) text to byte string\n */\nexport const encode = /*#__PURE__*/function () {\n  var _ref3 = _asyncToGenerator(function* ({\n    text,\n    compress\n  }) {\n    let deflated;\n\n    if (compress !== false) {\n      try {\n        deflated = yield toByteString(deflate(text));\n      } catch (error) {\n        console.error(\"encode: cannot deflate\", error);\n      }\n    }\n\n    return {\n      version: \"1\",\n      encoding: \"bstring\",\n      compressed: !!deflated,\n      encoded: deflated || (yield toByteString(text))\n    };\n  });\n\n  return function encode(_x3) {\n    return _ref3.apply(this, arguments);\n  };\n}();\nexport const decode = /*#__PURE__*/function () {\n  var _ref4 = _asyncToGenerator(function* (data) {\n    let decoded;\n\n    switch (data.encoding) {\n      case \"bstring\":\n        // if compressed, do not double decode the bstring\n        decoded = data.compressed ? data.encoded : yield byteStringToString(data.encoded);\n        break;\n\n      default:\n        throw new Error(`decode: unknown encoding \"${data.encoding}\"`);\n    }\n\n    if (data.compressed) {\n      return inflate(new Uint8Array(byteStringToArrayBuffer(decoded)), {\n        to: \"string\"\n      });\n    }\n\n    return decoded;\n  });\n\n  return function decode(_x4) {\n    return _ref4.apply(this, arguments);\n  };\n}();"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../data/encode.ts\n");
|
|
19
|
-
|
|
20
|
-
/***/ }),
|
|
21
|
-
|
|
22
|
-
/***/ "../../data/image.ts":
|
|
23
|
-
/*!***************************!*\
|
|
24
|
-
!*** ../../data/image.ts ***!
|
|
25
|
-
\***************************/
|
|
26
|
-
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
27
|
-
|
|
28
|
-
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"getTEXtChunk\": () => (/* binding */ getTEXtChunk),\n/* harmony export */ \"encodePngMetadata\": () => (/* binding */ encodePngMetadata),\n/* harmony export */ \"decodePngMetadata\": () => (/* binding */ decodePngMetadata),\n/* harmony export */ \"encodeSvgMetadata\": () => (/* binding */ encodeSvgMetadata),\n/* harmony export */ \"decodeSvgMetadata\": () => (/* binding */ decodeSvgMetadata)\n/* harmony export */ });\n/* harmony import */ var _babel_runtime_helpers_asyncToGenerator__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/asyncToGenerator */ \"../../../node_modules/@babel/runtime/helpers/esm/asyncToGenerator.js\");\n/* harmony import */ var png_chunks_extract__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! png-chunks-extract */ \"../../../node_modules/png-chunks-extract/index.js\");\n/* harmony import */ var png_chunks_extract__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(png_chunks_extract__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var png_chunk_text__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! png-chunk-text */ \"../../../node_modules/png-chunk-text/index.js\");\n/* harmony import */ var png_chunks_encode__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! png-chunks-encode */ \"../../../node_modules/png-chunks-encode/index.js\");\n/* harmony import */ var png_chunks_encode__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(png_chunks_encode__WEBPACK_IMPORTED_MODULE_3__);\n/* harmony import */ var _encode__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./encode */ \"../../data/encode.ts\");\n/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../constants */ \"../../constants.ts\");\n\r\n\r\n\r\n\r\n\r\n // -----------------------------------------------------------------------------\r\n// PNG\r\n// -----------------------------------------------------------------------------\r\nconst blobToArrayBuffer = function (blob) {\r\n if (\"arrayBuffer\" in blob) {\r\n return blob.arrayBuffer();\r\n } // Safari\r\n return new Promise(function (resolve, reject) {\r\n const reader = new FileReader();\r\n reader.onload = function (event) {\r\n var _event$target;\r\n if (!((_event$target = event.target) !== null && _event$target !== void 0 && _event$target.result)) {\r\n return reject(new Error(\"couldn't convert blob to ArrayBuffer\"));\r\n }\r\n resolve(event.target.result);\r\n };\r\n reader.readAsArrayBuffer(blob);\r\n });\r\n};\r\nconst getTEXtChunk = /*#__PURE__*/ function () {\r\n var _ref = (0,_babel_runtime_helpers_asyncToGenerator__WEBPACK_IMPORTED_MODULE_0__.default)(function* (blob) {\r\n const chunks = png_chunks_extract__WEBPACK_IMPORTED_MODULE_1___default()(new Uint8Array(yield blobToArrayBuffer(blob)));\r\n const metadataChunk = chunks.find(function (chunk) {\r\n return chunk.name === \"tEXt\";\r\n });\r\n if (metadataChunk) {\r\n return png_chunk_text__WEBPACK_IMPORTED_MODULE_2__.decode(metadataChunk.data);\r\n }\r\n return null;\r\n });\r\n return function getTEXtChunk(_x) {\r\n return _ref.apply(this, arguments);\r\n };\r\n}();\r\nconst encodePngMetadata = /*#__PURE__*/ function () {\r\n var _ref2 = (0,_babel_runtime_helpers_asyncToGenerator__WEBPACK_IMPORTED_MODULE_0__.default)(function* ({ blob, metadata }) {\r\n const chunks = png_chunks_extract__WEBPACK_IMPORTED_MODULE_1___default()(new Uint8Array(yield blobToArrayBuffer(blob)));\r\n const metadataChunk = png_chunk_text__WEBPACK_IMPORTED_MODULE_2__.encode(_constants__WEBPACK_IMPORTED_MODULE_5__.MIME_TYPES.excalidraw, JSON.stringify(yield (0,_encode__WEBPACK_IMPORTED_MODULE_4__.encode)({\r\n text: metadata,\r\n compress: true\r\n }))); // insert metadata before last chunk (iEND)\r\n chunks.splice(-1, 0, metadataChunk);\r\n return new Blob([png_chunks_encode__WEBPACK_IMPORTED_MODULE_3___default()(chunks)], {\r\n type: \"image/png\"\r\n });\r\n });\r\n return function encodePngMetadata(_x2) {\r\n return _ref2.apply(this, arguments);\r\n };\r\n}();\r\nconst decodePngMetadata = /*#__PURE__*/ function () {\r\n var _ref3 = (0,_babel_runtime_helpers_asyncToGenerator__WEBPACK_IMPORTED_MODULE_0__.default)(function* (blob) {\r\n const metadata = yield getTEXtChunk(blob);\r\n if ((metadata === null || metadata === void 0 ? void 0 : metadata.keyword) === _constants__WEBPACK_IMPORTED_MODULE_5__.MIME_TYPES.excalidraw) {\r\n try {\r\n const encodedData = JSON.parse(metadata.text);\r\n if (!(\"encoded\" in encodedData)) {\r\n // legacy, un-encoded scene JSON\r\n if (\"type\" in encodedData && encodedData.type === _constants__WEBPACK_IMPORTED_MODULE_5__.EXPORT_DATA_TYPES.excalidraw) {\r\n return metadata.text;\r\n }\r\n throw new Error(\"FAILED\");\r\n }\r\n return yield (0,_encode__WEBPACK_IMPORTED_MODULE_4__.decode)(encodedData);\r\n }\r\n catch (error) {\r\n console.error(error);\r\n throw new Error(\"FAILED\");\r\n }\r\n }\r\n throw new Error(\"INVALID\");\r\n });\r\n return function decodePngMetadata(_x3) {\r\n return _ref3.apply(this, arguments);\r\n };\r\n}(); // -----------------------------------------------------------------------------\r\n// SVG\r\n// -----------------------------------------------------------------------------\r\nconst encodeSvgMetadata = /*#__PURE__*/ function () {\r\n var _ref4 = (0,_babel_runtime_helpers_asyncToGenerator__WEBPACK_IMPORTED_MODULE_0__.default)(function* ({ text }) {\r\n const base64 = yield (0,_encode__WEBPACK_IMPORTED_MODULE_4__.stringToBase64)(JSON.stringify(yield (0,_encode__WEBPACK_IMPORTED_MODULE_4__.encode)({\r\n text\r\n })), true\r\n /* is already byte string */\r\n );\r\n let metadata = \"\";\r\n metadata += `<!-- payload-type:${_constants__WEBPACK_IMPORTED_MODULE_5__.MIME_TYPES.excalidraw} -->`;\r\n metadata += `<!-- payload-version:2 -->`;\r\n metadata += \"<!-- payload-start -->\";\r\n metadata += base64;\r\n metadata += \"<!-- payload-end -->\";\r\n return metadata;\r\n });\r\n return function encodeSvgMetadata(_x4) {\r\n return _ref4.apply(this, arguments);\r\n };\r\n}();\r\nconst decodeSvgMetadata = /*#__PURE__*/ function () {\r\n var _ref5 = (0,_babel_runtime_helpers_asyncToGenerator__WEBPACK_IMPORTED_MODULE_0__.default)(function* ({ svg }) {\r\n if (svg.includes(`payload-type:${_constants__WEBPACK_IMPORTED_MODULE_5__.MIME_TYPES.excalidraw}`)) {\r\n const match = svg.match(/<!-- payload-start -->(.+?)<!-- payload-end -->/);\r\n if (!match) {\r\n throw new Error(\"INVALID\");\r\n }\r\n const versionMatch = svg.match(/<!-- payload-version:(\\d+) -->/);\r\n const version = (versionMatch === null || versionMatch === void 0 ? void 0 : versionMatch[1]) || \"1\";\r\n const isByteString = version !== \"1\";\r\n try {\r\n const json = yield (0,_encode__WEBPACK_IMPORTED_MODULE_4__.base64ToString)(match[1], isByteString);\r\n const encodedData = JSON.parse(json);\r\n if (!(\"encoded\" in encodedData)) {\r\n // legacy, un-encoded scene JSON\r\n if (\"type\" in encodedData && encodedData.type === _constants__WEBPACK_IMPORTED_MODULE_5__.EXPORT_DATA_TYPES.excalidraw) {\r\n return json;\r\n }\r\n throw new Error(\"FAILED\");\r\n }\r\n return yield (0,_encode__WEBPACK_IMPORTED_MODULE_4__.decode)(encodedData);\r\n }\r\n catch (error) {\r\n console.error(error);\r\n throw new Error(\"FAILED\");\r\n }\r\n }\r\n throw new Error(\"INVALID\");\r\n });\r\n return function decodeSvgMetadata(_x5) {\r\n return _ref5.apply(this, arguments);\r\n };\r\n}();\r\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../data/image.ts.js","mappings":"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","sources":["webpack:///../../data/image.ts?8ce9"],"sourcesContent":["import _asyncToGenerator from \"@babel/runtime/helpers/asyncToGenerator\";\nimport decodePng from \"png-chunks-extract\";\nimport tEXt from \"png-chunk-text\";\nimport encodePng from \"png-chunks-encode\";\nimport { stringToBase64, encode, decode, base64ToString } from \"./encode\";\nimport { EXPORT_DATA_TYPES, MIME_TYPES } from \"../constants\"; // -----------------------------------------------------------------------------\n// PNG\n// -----------------------------------------------------------------------------\n\nconst blobToArrayBuffer = function (blob) {\n  if (\"arrayBuffer\" in blob) {\n    return blob.arrayBuffer();\n  } // Safari\n\n\n  return new Promise(function (resolve, reject) {\n    const reader = new FileReader();\n\n    reader.onload = function (event) {\n      var _event$target;\n\n      if (!((_event$target = event.target) !== null && _event$target !== void 0 && _event$target.result)) {\n        return reject(new Error(\"couldn't convert blob to ArrayBuffer\"));\n      }\n\n      resolve(event.target.result);\n    };\n\n    reader.readAsArrayBuffer(blob);\n  });\n};\n\nexport const getTEXtChunk = /*#__PURE__*/function () {\n  var _ref = _asyncToGenerator(function* (blob) {\n    const chunks = decodePng(new Uint8Array(yield blobToArrayBuffer(blob)));\n    const metadataChunk = chunks.find(function (chunk) {\n      return chunk.name === \"tEXt\";\n    });\n\n    if (metadataChunk) {\n      return tEXt.decode(metadataChunk.data);\n    }\n\n    return null;\n  });\n\n  return function getTEXtChunk(_x) {\n    return _ref.apply(this, arguments);\n  };\n}();\nexport const encodePngMetadata = /*#__PURE__*/function () {\n  var _ref2 = _asyncToGenerator(function* ({\n    blob,\n    metadata\n  }) {\n    const chunks = decodePng(new Uint8Array(yield blobToArrayBuffer(blob)));\n    const metadataChunk = tEXt.encode(MIME_TYPES.excalidraw, JSON.stringify(yield encode({\n      text: metadata,\n      compress: true\n    }))); // insert metadata before last chunk (iEND)\n\n    chunks.splice(-1, 0, metadataChunk);\n    return new Blob([encodePng(chunks)], {\n      type: \"image/png\"\n    });\n  });\n\n  return function encodePngMetadata(_x2) {\n    return _ref2.apply(this, arguments);\n  };\n}();\nexport const decodePngMetadata = /*#__PURE__*/function () {\n  var _ref3 = _asyncToGenerator(function* (blob) {\n    const metadata = yield getTEXtChunk(blob);\n\n    if ((metadata === null || metadata === void 0 ? void 0 : metadata.keyword) === MIME_TYPES.excalidraw) {\n      try {\n        const encodedData = JSON.parse(metadata.text);\n\n        if (!(\"encoded\" in encodedData)) {\n          // legacy, un-encoded scene JSON\n          if (\"type\" in encodedData && encodedData.type === EXPORT_DATA_TYPES.excalidraw) {\n            return metadata.text;\n          }\n\n          throw new Error(\"FAILED\");\n        }\n\n        return yield decode(encodedData);\n      } catch (error) {\n        console.error(error);\n        throw new Error(\"FAILED\");\n      }\n    }\n\n    throw new Error(\"INVALID\");\n  });\n\n  return function decodePngMetadata(_x3) {\n    return _ref3.apply(this, arguments);\n  };\n}(); // -----------------------------------------------------------------------------\n// SVG\n// -----------------------------------------------------------------------------\n\nexport const encodeSvgMetadata = /*#__PURE__*/function () {\n  var _ref4 = _asyncToGenerator(function* ({\n    text\n  }) {\n    const base64 = yield stringToBase64(JSON.stringify(yield encode({\n      text\n    })), true\n    /* is already byte string */\n    );\n    let metadata = \"\";\n    metadata += `<!-- payload-type:${MIME_TYPES.excalidraw} -->`;\n    metadata += `<!-- payload-version:2 -->`;\n    metadata += \"<!-- payload-start -->\";\n    metadata += base64;\n    metadata += \"<!-- payload-end -->\";\n    return metadata;\n  });\n\n  return function encodeSvgMetadata(_x4) {\n    return _ref4.apply(this, arguments);\n  };\n}();\nexport const decodeSvgMetadata = /*#__PURE__*/function () {\n  var _ref5 = _asyncToGenerator(function* ({\n    svg\n  }) {\n    if (svg.includes(`payload-type:${MIME_TYPES.excalidraw}`)) {\n      const match = svg.match(/<!-- payload-start -->(.+?)<!-- payload-end -->/);\n\n      if (!match) {\n        throw new Error(\"INVALID\");\n      }\n\n      const versionMatch = svg.match(/<!-- payload-version:(\\d+) -->/);\n      const version = (versionMatch === null || versionMatch === void 0 ? void 0 : versionMatch[1]) || \"1\";\n      const isByteString = version !== \"1\";\n\n      try {\n        const json = yield base64ToString(match[1], isByteString);\n        const encodedData = JSON.parse(json);\n\n        if (!(\"encoded\" in encodedData)) {\n          // legacy, un-encoded scene JSON\n          if (\"type\" in encodedData && encodedData.type === EXPORT_DATA_TYPES.excalidraw) {\n            return json;\n          }\n\n          throw new Error(\"FAILED\");\n        }\n\n        return yield decode(encodedData);\n      } catch (error) {\n        console.error(error);\n        throw new Error(\"FAILED\");\n      }\n    }\n\n    throw new Error(\"INVALID\");\n  });\n\n  return function decodeSvgMetadata(_x5) {\n    return _ref5.apply(this, arguments);\n  };\n}();"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///../../data/image.ts\n");
|
|
29
|
-
|
|
30
|
-
/***/ })
|
|
31
|
-
|
|
32
|
-
}]);
|