@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.
Files changed (48) hide show
  1. package/CHANGELOG.md +61 -8
  2. package/README.md +1 -1
  3. package/dist/excalidraw-assets-dev/{image-7e0eecf06fd4ae95db83.js → image-4d82da8a5abfcee0a489.js} +1 -1
  4. package/dist/excalidraw.development.js +129 -64
  5. package/dist/excalidraw.production.min.js +1 -1
  6. package/dist/excalidraw.production.min.js.LICENSE.txt +22 -0
  7. package/package.json +1 -1
  8. package/types/actions/actionCanvas.d.ts +4 -2
  9. package/types/actions/manager.d.ts +3 -11
  10. package/types/actions/types.d.ts +2 -8
  11. package/types/appState.d.ts +10 -4
  12. package/types/clipboard.d.ts +1 -0
  13. package/types/components/Actions.d.ts +5 -2
  14. package/types/components/App.d.ts +21 -5
  15. package/types/components/DarkModeToggle.d.ts +3 -3
  16. package/types/components/InitializeApp.d.ts +2 -10
  17. package/types/components/LayerUI.d.ts +4 -1
  18. package/types/components/LibraryUnit.d.ts +3 -2
  19. package/types/components/MobileMenu.d.ts +4 -1
  20. package/types/components/ToolButton.d.ts +5 -2
  21. package/types/components/icons.d.ts +41 -40
  22. package/types/constants.d.ts +8 -0
  23. package/types/data/blob.d.ts +13 -2
  24. package/types/data/encode.d.ts +29 -1
  25. package/types/data/json.d.ts +1 -1
  26. package/types/element/collision.d.ts +2 -2
  27. package/types/element/dragElements.d.ts +1 -1
  28. package/types/element/index.d.ts +2 -1
  29. package/types/element/mutateElement.d.ts +1 -1
  30. package/types/element/newElement.d.ts +4 -1
  31. package/types/element/resizeElements.d.ts +3 -3
  32. package/types/element/typeChecks.d.ts +3 -1
  33. package/types/element/types.d.ts +16 -3
  34. package/types/keys.d.ts +4 -3
  35. package/types/packages/excalidraw/dist/excalidraw-assets-dev/image-4d82da8a5abfcee0a489.d.ts +0 -0
  36. package/types/packages/excalidraw/index.d.ts +1 -1
  37. package/types/packages/excalidraw/webpack.prod.config.d.ts +3 -1
  38. package/types/packages/utils.d.ts +1 -1
  39. package/types/renderer/renderElement.d.ts +3 -2
  40. package/types/renderer/renderScene.d.ts +3 -2
  41. package/types/scene/export.d.ts +2 -1
  42. package/types/scene/types.d.ts +3 -2
  43. package/types/shapes.d.ts +5 -1
  44. package/types/types.d.ts +29 -4
  45. package/types/utils.d.ts +1 -0
  46. package/types/zindex.d.ts +2 -2
  47. package/dist/excalidraw-assets-dev/image-bd6a627ff1bbdbae8366.js +0 -32
  48. 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, isResizeWithSidesSameLength: boolean, isResizeCenterPoint: boolean) => void;
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;
@@ -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>) => void;
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", isRotateWithDiscreteAngle: boolean, isResizeCenterPoint: boolean, shouldKeepSidesRatio: boolean, pointerX: number, pointerY: number, centerX: number, centerY: number) => boolean;
6
- export declare const reshapeSingleTwoPointElement: (element: NonDeleted<ExcalidrawLinearElement>, resizeArrowDirection: "origin" | "end", isRotateWithDiscreteAngle: boolean, pointerX: number, pointerY: number) => void;
7
- export declare const resizeSingleElement: (stateAtResizeStart: NonDeletedExcalidrawElement, shouldKeepSidesRatio: boolean, element: NonDeletedExcalidrawElement, transformHandleDirection: TransformHandleDirection, isResizeFromCenter: boolean, pointerX: number, pointerY: number) => void;
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;
@@ -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 getResizeCenterPointKey: (event: MouseEvent | KeyboardEvent) => boolean;
60
- export declare const getResizeWithSidesSameLengthKey: (event: MouseEvent | KeyboardEvent) => boolean;
61
- export declare const getRotateWithDiscreteAngleKey: (event: MouseEvent | KeyboardEvent) => boolean;
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;
@@ -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";
@@ -44,7 +44,9 @@ export namespace module {
44
44
  } | {
45
45
  loader: string;
46
46
  options: {
47
- presets: string[];
47
+ presets: (string | (string | {
48
+ runtime: string;
49
+ })[])[];
48
50
  plugins: string[];
49
51
  transpileOnly?: undefined;
50
52
  configFile?: undefined;
@@ -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;
@@ -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];
@@ -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 { FileSystemHandle } from "./data/filesystem";
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: "light" | "dark";
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?: "dark" | "light";
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
- }]);