@zsviczian/excalidraw 0.17.1-obsidian-11 → 0.17.1-obsidian-12
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/dist/excalidraw.development.js +103 -59
- package/dist/excalidraw.production.min.js +1 -1
- package/dist/styles.development.css +7 -5
- package/dist/styles.production.css +1 -1
- package/package.json +2 -2
- package/types/excalidraw/actions/actionCanvas.d.ts +14 -14
- package/types/excalidraw/animated-trail.d.ts +33 -0
- package/types/excalidraw/animation-frame-handler.d.ts +16 -0
- package/types/excalidraw/components/App.d.ts +20 -16
- package/types/excalidraw/components/LaserPointerButton.d.ts +10 -0
- package/types/excalidraw/components/SVGLayer.d.ts +7 -0
- package/types/excalidraw/components/icons.d.ts +1 -1
- package/types/excalidraw/element/Hyperlink.d.ts +3 -2
- package/types/excalidraw/element/embeddable.d.ts +1 -1
- package/types/excalidraw/element/linearElementEditor.d.ts +1 -1
- package/types/excalidraw/element/newElement.d.ts +0 -1
- package/types/excalidraw/element/textElement.d.ts +0 -1
- package/types/excalidraw/element/types.d.ts +0 -8
- package/types/excalidraw/laser-trails.d.ts +19 -0
- package/types/excalidraw/obsidianUtils.d.ts +3 -0
- package/types/excalidraw/reactUtils.d.ts +14 -0
- package/types/excalidraw/renderer/renderElement.d.ts +3 -2
- package/types/excalidraw/scene/Shape.d.ts +3 -1
- package/types/excalidraw/scene/ShapeCache.d.ts +2 -1
- package/types/excalidraw/scene/export.d.ts +3 -0
- package/types/excalidraw/scene/types.d.ts +4 -1
- package/types/excalidraw/types.d.ts +3 -7
- package/types/excalidraw/utils.d.ts +2 -14
|
@@ -4508,10 +4508,10 @@
|
|
|
4508
4508
|
opacity: 1;
|
|
4509
4509
|
}
|
|
4510
4510
|
}
|
|
4511
|
-
|
|
4512
|
-
!*** css ../../node_modules/css-loader/dist/cjs.js!../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[0].use[2]!../../node_modules/sass-loader/dist/cjs.js!./components/
|
|
4513
|
-
|
|
4514
|
-
.excalidraw .
|
|
4511
|
+
/*!*****************************************************************************************************************************************************************************************************!*\
|
|
4512
|
+
!*** css ../../node_modules/css-loader/dist/cjs.js!../../node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[0].use[2]!../../node_modules/sass-loader/dist/cjs.js!./components/SVGLayer.scss ***!
|
|
4513
|
+
\*****************************************************************************************************************************************************************************************************/
|
|
4514
|
+
.excalidraw .SVGLayer {
|
|
4515
4515
|
pointer-events: none;
|
|
4516
4516
|
width: 100vw;
|
|
4517
4517
|
height: 100vh;
|
|
@@ -4520,10 +4520,12 @@
|
|
|
4520
4520
|
left: 0;
|
|
4521
4521
|
z-index: 2;
|
|
4522
4522
|
}
|
|
4523
|
-
.excalidraw .
|
|
4523
|
+
.excalidraw .SVGLayer svg {
|
|
4524
4524
|
image-rendering: auto;
|
|
4525
4525
|
overflow: visible;
|
|
4526
4526
|
position: absolute;
|
|
4527
|
+
width: 100%;
|
|
4528
|
+
height: 100%;
|
|
4527
4529
|
top: 0;
|
|
4528
4530
|
left: 0;
|
|
4529
4531
|
}
|
|
@@ -49,7 +49,7 @@
|
|
|
49
49
|
.excalidraw .MagicSettings .Island{height:100%;display:flex;flex-direction:column}.excalidraw .MagicSettings-confirm{padding:.5rem 1rem}.excalidraw .MagicSettings__confirm{margin-top:2rem;margin-right:auto}
|
|
50
50
|
:export{themeFilter:invert(93%) hue-rotate(180deg);rightSidebarWidth:302px}.excalidraw .Modal.Dialog.ttd-dialog{padding:1.25rem}.excalidraw .Modal.Dialog.ttd-dialog.Dialog--fullscreen{margin-top:0}.excalidraw .Modal.Dialog.ttd-dialog .Island{padding-inline:0 !important;height:100%;display:flex;flex-direction:column;flex:1 1 auto;box-shadow:none}.excalidraw .Modal.Dialog.ttd-dialog .Modal__content{height:auto;max-height:100%}@media screen and (min-width: 861px){.excalidraw .Modal.Dialog.ttd-dialog .Modal__content{max-height:750px;height:100%}}.excalidraw .Modal.Dialog.ttd-dialog .Dialog__content{flex:1 1 auto}.excalidraw .ttd-dialog-desc{font-size:15px;font-style:italic;font-weight:500;margin-bottom:1.5rem}.excalidraw .ttd-dialog-tabs-root{width:100%;height:100%;display:flex;flex-direction:column}.excalidraw .ttd-dialog-tab-trigger{color:var(--color-on-surface);font-size:.875rem;margin:0;padding:0 1rem;background-color:rgba(0,0,0,0);border:0;height:2.875rem;font-weight:600;font-family:inherit;letter-spacing:.4px}.excalidraw .ttd-dialog-tab-trigger[data-state=active]{border-bottom:2px solid var(--color-primary)}.excalidraw .ttd-dialog-triggers{border-bottom:1px solid var(--color-surface-high);margin-bottom:1.5rem;padding-inline:2.5rem}.excalidraw .ttd-dialog-content{padding-inline:2.5rem;height:100%;display:flex;flex-direction:column}.excalidraw .ttd-dialog-content[hidden]{display:none}.excalidraw .ttd-dialog-input{width:auto;height:10rem;resize:none;border-radius:var(--border-radius-lg);border:1px solid var(--dialog-border-color);white-space:pre-wrap;padding:.85rem;box-sizing:border-box;font-family:monospace;text-wrap:wrap !important}@media screen and (min-width: 861px){.excalidraw .ttd-dialog-input{width:100%;height:100%}}.excalidraw .ttd-dialog-output-wrapper{display:flex;align-items:center;justify-content:center;padding:.85rem;box-sizing:border-box;flex-grow:1;position:relative;background:url() left center;border-radius:var(--border-radius-lg);border:1px solid var(--dialog-border-color);height:400px;width:auto}@media screen and (min-width: 861px){.excalidraw .ttd-dialog-output-wrapper{width:100%;height:200px}}.excalidraw .ttd-dialog-output-wrapper canvas{max-width:100%;max-height:100%}.excalidraw .ttd-dialog-output-canvas-container{display:flex;width:100%;height:100%;align-items:center;justify-content:center;flex-grow:1}.excalidraw .ttd-dialog-output-error{color:red;font-weight:800;font-size:30px;word-break:break-word;overflow:auto;max-height:100%;height:100%;width:100%;text-align:center;position:absolute;z-index:10}.excalidraw .ttd-dialog-output-error p{font-weight:500;font-family:Cascadia;text-align:left;white-space:pre-wrap;font-size:.875rem;padding:0 10px}.excalidraw .ttd-dialog-panels{height:100%}@media screen and (min-width: 861px){.excalidraw .ttd-dialog-panels{display:grid;grid-template-columns:1fr 1fr;gap:4rem}}.excalidraw .ttd-dialog-panel{display:flex;flex-direction:column;width:100%}.excalidraw .ttd-dialog-panel__header{display:flex;margin:0px 4px 4px 4px;align-items:center;gap:1rem}.excalidraw .ttd-dialog-panel__header label{font-size:14px;font-style:normal;font-weight:600}.excalidraw .ttd-dialog-panel:first-child .ttd-dialog-panel-button-container:not(.invisible){margin-bottom:4rem}@media screen and (min-width: 861px){.excalidraw .ttd-dialog-panel .ttd-dialog-panel-button-container:not(.invisible){margin-bottom:.5rem !important}}.excalidraw .ttd-dialog-panel textarea{height:100%;resize:none;border-radius:var(--border-radius-lg);border:1px solid var(--dialog-border-color);white-space:pre-wrap;padding:.85rem;box-sizing:border-box;width:100%;font-family:monospace}@media screen and (max-width: 861px){.excalidraw .ttd-dialog-panel textarea{width:auto;height:10rem}}.excalidraw .ttd-dialog-panel-button-container{margin-top:1rem;margin-bottom:.5rem}.excalidraw .ttd-dialog-panel-button-container.invisible .ttd-dialog-panel-button{display:none}@media screen and (min-width: 861px){.excalidraw .ttd-dialog-panel-button-container.invisible .ttd-dialog-panel-button{display:block;visibility:hidden}}.excalidraw .ttd-dialog-panel-button{position:relative}.excalidraw .ttd-dialog-panel-button.excalidraw-button{font-family:inherit;font-weight:600;height:2.5rem;font-size:12px;color:#fff;background-color:var(--color-primary);width:100%}.excalidraw .ttd-dialog-panel-button.excalidraw-button:hover{background-color:var(--color-primary-darker)}.excalidraw .ttd-dialog-panel-button.excalidraw-button:active{background-color:var(--color-primary-darkest)}.excalidraw .ttd-dialog-panel-button.excalidraw-button:disabled{opacity:.5;cursor:not-allowed}.excalidraw .ttd-dialog-panel-button.excalidraw-button:disabled:hover{background-color:var(--color-primary)}@media screen and (min-width: 861px){.excalidraw .ttd-dialog-panel-button.excalidraw-button{width:auto;min-width:7.5rem}}.excalidraw.theme--dark.excalidraw .ttd-dialog-panel-button.excalidraw-button{color:var(--color-gray-100)}.excalidraw .ttd-dialog-panel-button div{display:contents}.excalidraw .ttd-dialog-panel-button div.invisible{visibility:hidden}.excalidraw .ttd-dialog-panel-button div.Spinner{display:flex !important;position:absolute;inset:0;--spinner-color: white}.excalidraw.theme--dark.excalidraw .ttd-dialog-panel-button div.Spinner{--spinner-color: var(--color-gray-100)}.excalidraw .ttd-dialog-panel-button div span{padding-left:.5rem;display:flex}.excalidraw .ttd-dialog-submit-shortcut{margin-inline-start:.5rem;font-size:.625rem;opacity:.6;display:flex;gap:.125rem}.excalidraw .ttd-dialog-submit-shortcut__key{border:1px solid gray;padding:2px 3px;border-radius:4px}
|
|
51
51
|
:export{themeFilter:invert(93%) hue-rotate(180deg);rightSidebarWidth:302px}.excalidraw .Toast{animation:fade-in .5s;background-color:var(--button-gray-1);border-radius:4px;bottom:10px;box-sizing:border-box;cursor:default;left:50%;margin-left:-150px;padding:4px 0;position:absolute;text-align:center;width:300px;z-index:999999}.excalidraw .Toast .Toast__message{padding:0 1.6rem;color:var(--popup-text-color);white-space:pre-wrap}.excalidraw .Toast .close{position:absolute;top:0;right:0;padding:.4rem}.excalidraw .Toast .close .ToolIcon__icon{width:1.2rem;height:1.2rem}@keyframes fade-in{from{opacity:0}to{opacity:1}}
|
|
52
|
-
.excalidraw .
|
|
52
|
+
.excalidraw .SVGLayer{pointer-events:none;width:100vw;height:100vh;position:fixed;top:0;left:0;z-index:2}.excalidraw .SVGLayer svg{image-rendering:auto;overflow:visible;position:absolute;width:100%;height:100%;top:0;left:0}
|
|
53
53
|
.excalidraw .excalidraw-canvas-buttons{position:absolute;box-shadow:0px 2px 4px 0 rgba(0,0,0,.3);z-index:var(--zIndex-canvasButtons);background:var(--island-bg-color);border-radius:var(--border-radius-lg);display:flex;flex-direction:column;gap:.375rem}
|
|
54
54
|
.excalidraw .follow-mode{position:absolute;box-sizing:border-box;pointer-events:none;border:2px solid var(--color-primary-hover);z-index:9999;display:flex;align-items:flex-end;justify-content:center}.excalidraw .follow-mode__badge{background-color:var(--color-primary-hover);color:var(--color-primary-light);padding:.25rem .5rem;margin-bottom:.5rem;border-radius:.5rem;pointer-events:all;font-size:.75rem;display:flex;gap:.5rem;align-items:center}.excalidraw .follow-mode__badge__label{display:flex;white-space:pre-wrap;line-height:1}.excalidraw .follow-mode__badge__username{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100px}.excalidraw .follow-mode__disconnect-btn{all:unset;cursor:pointer;border-radius:.25rem}.excalidraw .follow-mode__disconnect-btn:hover{background-color:var(--color-primary-darker)}.excalidraw .follow-mode__disconnect-btn:active{background-color:var(--color-primary-darkest)}.excalidraw .follow-mode__disconnect-btn svg{display:block;width:1rem;height:1rem}
|
|
55
55
|
.visually-hidden{position:absolute !important;height:1px;width:1px;overflow:hidden;clip:rect(1px, 1px, 1px, 1px);white-space:nowrap;-webkit-user-select:none;user-select:none}.LoadingMessage{position:absolute;top:0;right:0;bottom:0;left:0;z-index:999;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}.LoadingMessage .Spinner{font-size:2.8em}.LoadingMessage .LoadingMessage-text{margin-top:1em;font-size:.8em}.LoadingMessage--dark{background-color:#121212;color:#ced4da}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@zsviczian/excalidraw",
|
|
3
|
-
"version": "0.17.1-obsidian-
|
|
3
|
+
"version": "0.17.1-obsidian-12",
|
|
4
4
|
"main": "main.js",
|
|
5
5
|
"types": "types/excalidraw/index.d.ts",
|
|
6
6
|
"files": [
|
|
@@ -45,7 +45,7 @@
|
|
|
45
45
|
},
|
|
46
46
|
"dependencies": {
|
|
47
47
|
"@braintree/sanitize-url": "6.0.2",
|
|
48
|
-
"@excalidraw/laser-pointer": "1.
|
|
48
|
+
"@excalidraw/laser-pointer": "1.3.1",
|
|
49
49
|
"@zsviczian/mermaid-to-excalidraw": "0.2.0-obsidian-2",
|
|
50
50
|
"@excalidraw/random-username": "1.1.0",
|
|
51
51
|
"@radix-ui/react-popover": "1.0.3",
|
|
@@ -121,7 +121,7 @@ export declare const actionClearCanvas: {
|
|
|
121
121
|
openDialog: {
|
|
122
122
|
name: "help" | "imageExport" | "jsonExport";
|
|
123
123
|
} | {
|
|
124
|
-
name: "settings";
|
|
124
|
+
name: "settings"; /** zoom content to cover X of the viewport, when fitToViewport=true */
|
|
125
125
|
source: "settings" | "tool" | "generation";
|
|
126
126
|
tab: "text-to-diagram" | "diagram-to-code";
|
|
127
127
|
} | {
|
|
@@ -285,7 +285,7 @@ export declare const actionZoomIn: {
|
|
|
285
285
|
openDialog: {
|
|
286
286
|
name: "help" | "imageExport" | "jsonExport";
|
|
287
287
|
} | {
|
|
288
|
-
name: "settings";
|
|
288
|
+
name: "settings"; /** zoom content to cover X of the viewport, when fitToViewport=true */
|
|
289
289
|
source: "settings" | "tool" | "generation";
|
|
290
290
|
tab: "text-to-diagram" | "diagram-to-code";
|
|
291
291
|
} | {
|
|
@@ -479,7 +479,7 @@ export declare const actionZoomOut: {
|
|
|
479
479
|
openDialog: {
|
|
480
480
|
name: "help" | "imageExport" | "jsonExport";
|
|
481
481
|
} | {
|
|
482
|
-
name: "settings";
|
|
482
|
+
name: "settings"; /** zoom content to cover X of the viewport, when fitToViewport=true */
|
|
483
483
|
source: "settings" | "tool" | "generation";
|
|
484
484
|
tab: "text-to-diagram" | "diagram-to-code";
|
|
485
485
|
} | {
|
|
@@ -673,7 +673,7 @@ export declare const actionResetZoom: {
|
|
|
673
673
|
openDialog: {
|
|
674
674
|
name: "help" | "imageExport" | "jsonExport";
|
|
675
675
|
} | {
|
|
676
|
-
name: "settings";
|
|
676
|
+
name: "settings"; /** zoom content to cover X of the viewport, when fitToViewport=true */
|
|
677
677
|
source: "settings" | "tool" | "generation";
|
|
678
678
|
tab: "text-to-diagram" | "diagram-to-code";
|
|
679
679
|
} | {
|
|
@@ -867,7 +867,7 @@ export declare const zoomToFitBounds: ({ bounds, appState, fitToViewport, viewpo
|
|
|
867
867
|
openDialog: {
|
|
868
868
|
name: "help" | "imageExport" | "jsonExport";
|
|
869
869
|
} | {
|
|
870
|
-
name: "settings";
|
|
870
|
+
name: "settings"; /** zoom content to cover X of the viewport, when fitToViewport=true */
|
|
871
871
|
source: "settings" | "tool" | "generation";
|
|
872
872
|
tab: "text-to-diagram" | "diagram-to-code";
|
|
873
873
|
} | {
|
|
@@ -1057,7 +1057,7 @@ export declare const zoomToFit: ({ targetElements, appState, fitToViewport, view
|
|
|
1057
1057
|
openDialog: {
|
|
1058
1058
|
name: "help" | "imageExport" | "jsonExport";
|
|
1059
1059
|
} | {
|
|
1060
|
-
name: "settings";
|
|
1060
|
+
name: "settings"; /** zoom content to cover X of the viewport, when fitToViewport=true */
|
|
1061
1061
|
source: "settings" | "tool" | "generation";
|
|
1062
1062
|
tab: "text-to-diagram" | "diagram-to-code";
|
|
1063
1063
|
} | {
|
|
@@ -1245,7 +1245,7 @@ export declare const actionZoomToFitSelectionInViewport: {
|
|
|
1245
1245
|
openDialog: {
|
|
1246
1246
|
name: "help" | "imageExport" | "jsonExport";
|
|
1247
1247
|
} | {
|
|
1248
|
-
name: "settings";
|
|
1248
|
+
name: "settings"; /** zoom content to cover X of the viewport, when fitToViewport=true */
|
|
1249
1249
|
source: "settings" | "tool" | "generation";
|
|
1250
1250
|
tab: "text-to-diagram" | "diagram-to-code";
|
|
1251
1251
|
} | {
|
|
@@ -1437,7 +1437,7 @@ export declare const actionZoomToFitSelection: {
|
|
|
1437
1437
|
openDialog: {
|
|
1438
1438
|
name: "help" | "imageExport" | "jsonExport";
|
|
1439
1439
|
} | {
|
|
1440
|
-
name: "settings";
|
|
1440
|
+
name: "settings"; /** zoom content to cover X of the viewport, when fitToViewport=true */
|
|
1441
1441
|
source: "settings" | "tool" | "generation";
|
|
1442
1442
|
tab: "text-to-diagram" | "diagram-to-code";
|
|
1443
1443
|
} | {
|
|
@@ -1630,7 +1630,7 @@ export declare const actionZoomToFit: {
|
|
|
1630
1630
|
openDialog: {
|
|
1631
1631
|
name: "help" | "imageExport" | "jsonExport";
|
|
1632
1632
|
} | {
|
|
1633
|
-
name: "settings";
|
|
1633
|
+
name: "settings"; /** zoom content to cover X of the viewport, when fitToViewport=true */
|
|
1634
1634
|
source: "settings" | "tool" | "generation";
|
|
1635
1635
|
tab: "text-to-diagram" | "diagram-to-code";
|
|
1636
1636
|
} | {
|
|
@@ -1824,7 +1824,7 @@ export declare const actionToggleTheme: {
|
|
|
1824
1824
|
openDialog: {
|
|
1825
1825
|
name: "help" | "imageExport" | "jsonExport";
|
|
1826
1826
|
} | {
|
|
1827
|
-
name: "settings";
|
|
1827
|
+
name: "settings"; /** zoom content to cover X of the viewport, when fitToViewport=true */
|
|
1828
1828
|
source: "settings" | "tool" | "generation";
|
|
1829
1829
|
tab: "text-to-diagram" | "diagram-to-code";
|
|
1830
1830
|
} | {
|
|
@@ -2015,7 +2015,7 @@ export declare const actionToggleEraserTool: {
|
|
|
2015
2015
|
openDialog: {
|
|
2016
2016
|
name: "help" | "imageExport" | "jsonExport";
|
|
2017
2017
|
} | {
|
|
2018
|
-
name: "settings";
|
|
2018
|
+
name: "settings"; /** zoom content to cover X of the viewport, when fitToViewport=true */
|
|
2019
2019
|
source: "settings" | "tool" | "generation";
|
|
2020
2020
|
tab: "text-to-diagram" | "diagram-to-code";
|
|
2021
2021
|
} | {
|
|
@@ -2200,7 +2200,7 @@ export declare const actionToggleHandTool: {
|
|
|
2200
2200
|
openDialog: {
|
|
2201
2201
|
name: "help" | "imageExport" | "jsonExport";
|
|
2202
2202
|
} | {
|
|
2203
|
-
name: "settings";
|
|
2203
|
+
name: "settings"; /** zoom content to cover X of the viewport, when fitToViewport=true */
|
|
2204
2204
|
source: "settings" | "tool" | "generation";
|
|
2205
2205
|
tab: "text-to-diagram" | "diagram-to-code";
|
|
2206
2206
|
} | {
|
|
@@ -2386,7 +2386,7 @@ export declare const actionToggleLaserPointer: {
|
|
|
2386
2386
|
openDialog: {
|
|
2387
2387
|
name: "help" | "imageExport" | "jsonExport";
|
|
2388
2388
|
} | {
|
|
2389
|
-
name: "settings";
|
|
2389
|
+
name: "settings"; /** zoom content to cover X of the viewport, when fitToViewport=true */
|
|
2390
2390
|
source: "settings" | "tool" | "generation";
|
|
2391
2391
|
tab: "text-to-diagram" | "diagram-to-code";
|
|
2392
2392
|
} | {
|
|
@@ -2568,7 +2568,7 @@ export declare const zoomToFitElements: (elements: readonly ExcalidrawElement[],
|
|
|
2568
2568
|
openDialog: {
|
|
2569
2569
|
name: "help" | "imageExport" | "jsonExport";
|
|
2570
2570
|
} | {
|
|
2571
|
-
name: "settings";
|
|
2571
|
+
name: "settings"; /** zoom content to cover X of the viewport, when fitToViewport=true */
|
|
2572
2572
|
source: "settings" | "tool" | "generation";
|
|
2573
2573
|
tab: "text-to-diagram" | "diagram-to-code";
|
|
2574
2574
|
} | {
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { LaserPointerOptions } from "@excalidraw/laser-pointer";
|
|
2
|
+
import { AnimationFrameHandler } from "./animation-frame-handler";
|
|
3
|
+
import type App from "./components/App";
|
|
4
|
+
export interface Trail {
|
|
5
|
+
start(container: SVGSVGElement): void;
|
|
6
|
+
stop(): void;
|
|
7
|
+
startPath(x: number, y: number): void;
|
|
8
|
+
addPointToPath(x: number, y: number): void;
|
|
9
|
+
endPath(): void;
|
|
10
|
+
}
|
|
11
|
+
export interface AnimatedTrailOptions {
|
|
12
|
+
fill: (trail: AnimatedTrail) => string;
|
|
13
|
+
}
|
|
14
|
+
export declare class AnimatedTrail implements Trail {
|
|
15
|
+
private animationFrameHandler;
|
|
16
|
+
private app;
|
|
17
|
+
private options;
|
|
18
|
+
private currentTrail?;
|
|
19
|
+
private pastTrails;
|
|
20
|
+
private container?;
|
|
21
|
+
private trailElement;
|
|
22
|
+
constructor(animationFrameHandler: AnimationFrameHandler, app: App, options: Partial<LaserPointerOptions> & Partial<AnimatedTrailOptions>);
|
|
23
|
+
get hasCurrentTrail(): boolean;
|
|
24
|
+
hasLastPoint(x: number, y: number): boolean;
|
|
25
|
+
start(container?: SVGSVGElement): void;
|
|
26
|
+
stop(): void;
|
|
27
|
+
startPath(x: number, y: number): void;
|
|
28
|
+
addPointToPath(x: number, y: number): void;
|
|
29
|
+
endPath(): void;
|
|
30
|
+
private update;
|
|
31
|
+
private onFrame;
|
|
32
|
+
private drawTrail;
|
|
33
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
export type AnimationCallback = (timestamp: number) => void | boolean;
|
|
2
|
+
export type AnimationTarget = {
|
|
3
|
+
callback: AnimationCallback;
|
|
4
|
+
stopped: boolean;
|
|
5
|
+
};
|
|
6
|
+
export declare class AnimationFrameHandler {
|
|
7
|
+
private targets;
|
|
8
|
+
private rafIds;
|
|
9
|
+
register(key: object, callback: AnimationCallback): void;
|
|
10
|
+
start(key: object): void;
|
|
11
|
+
stop(key: object): void;
|
|
12
|
+
private constructFrame;
|
|
13
|
+
private scheduleFrame;
|
|
14
|
+
private cancelFrame;
|
|
15
|
+
private onFrame;
|
|
16
|
+
}
|
|
@@ -4,14 +4,16 @@ import { ActionManager } from "../actions/manager";
|
|
|
4
4
|
import { EXPORT_IMAGE_TYPES } from "../constants";
|
|
5
5
|
import { ExportedElements } from "../data";
|
|
6
6
|
import { LinearElementEditor } from "../element/linearElementEditor";
|
|
7
|
-
import { ExcalidrawElement, ExcalidrawLinearElement, NonDeleted, NonDeletedExcalidrawElement, ExcalidrawFrameLikeElement, ExcalidrawIframeElement } from "../element/types";
|
|
7
|
+
import { ExcalidrawElement, ExcalidrawLinearElement, NonDeleted, NonDeletedExcalidrawElement, ExcalidrawFrameLikeElement, ExcalidrawIframeElement, ExcalidrawEmbeddableElement } from "../element/types";
|
|
8
8
|
import History from "../history";
|
|
9
9
|
import Scene from "../scene/Scene";
|
|
10
10
|
import { AppClassProperties, AppProps, AppState, ExcalidrawImperativeAPI, BinaryFiles, LibraryItems, SceneData, Device, FrameNameBoundsCache, SidebarName, SidebarTabName, ToolType, OnUserFollowedPayload } from "../types";
|
|
11
11
|
import { FileSystemHandle } from "../data/filesystem";
|
|
12
12
|
import { Renderer } from "../scene/Renderer";
|
|
13
|
-
import { LaserPathManager } from "./LaserTool/LaserPathManager";
|
|
14
13
|
import { Emitter } from "../emitter";
|
|
14
|
+
import { AnimationFrameHandler } from "../animation-frame-handler";
|
|
15
|
+
import { AnimatedTrail } from "../animated-trail";
|
|
16
|
+
import { LaserTrails } from "../laser-trails";
|
|
15
17
|
export declare let showFourthFont: boolean;
|
|
16
18
|
export declare const ExcalidrawContainerContext: React.Context<{
|
|
17
19
|
container: HTMLDivElement | null;
|
|
@@ -60,6 +62,17 @@ declare class App extends React.Component<AppProps, AppState> {
|
|
|
60
62
|
files: BinaryFiles;
|
|
61
63
|
imageCache: AppClassProperties["imageCache"];
|
|
62
64
|
private iFrameRefs;
|
|
65
|
+
/**
|
|
66
|
+
* Indicates whether the embeddable's url has been validated for rendering.
|
|
67
|
+
* If value not set, indicates that the validation is pending.
|
|
68
|
+
* Initially or on url change the flag is not reset so that we can guarantee
|
|
69
|
+
* the validation came from a trusted source (the editor).
|
|
70
|
+
**/
|
|
71
|
+
private embedsValidationStatus;
|
|
72
|
+
/** embeds that have been inserted to DOM (as a perf optim, we don't want to
|
|
73
|
+
* insert to DOM before user initially scrolls to them) */
|
|
74
|
+
private initializedEmbeds;
|
|
75
|
+
private elementsPendingErasure;
|
|
63
76
|
hitLinkElement?: NonDeletedExcalidrawElement;
|
|
64
77
|
lastPointerDownEvent: React.PointerEvent<HTMLElement> | null;
|
|
65
78
|
lastPointerUpEvent: React.PointerEvent<HTMLElement> | PointerEvent | null;
|
|
@@ -69,7 +82,9 @@ declare class App extends React.Component<AppProps, AppState> {
|
|
|
69
82
|
y: number;
|
|
70
83
|
};
|
|
71
84
|
allowMobileMode: boolean;
|
|
72
|
-
|
|
85
|
+
animationFrameHandler: AnimationFrameHandler;
|
|
86
|
+
laserTrails: LaserTrails;
|
|
87
|
+
eraserTrail: AnimatedTrail;
|
|
73
88
|
onChangeEmitter: Emitter<[elements: readonly ExcalidrawElement[], appState: AppState, files: BinaryFiles]>;
|
|
74
89
|
onPointerDownEmitter: Emitter<[activeTool: {
|
|
75
90
|
lastActiveTool: import("../types").ActiveTool | null;
|
|
@@ -134,12 +149,6 @@ declare class App extends React.Component<AppProps, AppState> {
|
|
|
134
149
|
boxSelection: {
|
|
135
150
|
hasOccurred: boolean;
|
|
136
151
|
};
|
|
137
|
-
elementIdsToErase: {
|
|
138
|
-
[key: string]: {
|
|
139
|
-
opacity: number;
|
|
140
|
-
erase: boolean;
|
|
141
|
-
};
|
|
142
|
-
};
|
|
143
152
|
}>, event: React.PointerEvent<HTMLElement>]>;
|
|
144
153
|
onPointerUpEmitter: Emitter<[activeTool: {
|
|
145
154
|
lastActiveTool: import("../types").ActiveTool | null;
|
|
@@ -204,12 +213,6 @@ declare class App extends React.Component<AppProps, AppState> {
|
|
|
204
213
|
boxSelection: {
|
|
205
214
|
hasOccurred: boolean;
|
|
206
215
|
};
|
|
207
|
-
elementIdsToErase: {
|
|
208
|
-
[key: string]: {
|
|
209
|
-
opacity: number;
|
|
210
|
-
erase: boolean;
|
|
211
|
-
};
|
|
212
|
-
};
|
|
213
216
|
}>, event: PointerEvent]>;
|
|
214
217
|
onUserFollowEmitter: Emitter<[payload: OnUserFollowedPayload]>;
|
|
215
218
|
onScrollChangeEmitter: Emitter<[scrollX: number, scrollY: number, zoom: Readonly<{
|
|
@@ -223,6 +226,7 @@ declare class App extends React.Component<AppProps, AppState> {
|
|
|
223
226
|
private getHTMLIFrameElement;
|
|
224
227
|
private handleEmbeddableCenterClick;
|
|
225
228
|
private isIframeLikeElementCenter;
|
|
229
|
+
private updateEmbedValidationStatus;
|
|
226
230
|
private updateEmbeddables;
|
|
227
231
|
private renderEmbeddables;
|
|
228
232
|
private getFrameNameDOMId;
|
|
@@ -434,7 +438,7 @@ declare class App extends React.Component<AppProps, AppState> {
|
|
|
434
438
|
sceneX: number;
|
|
435
439
|
sceneY: number;
|
|
436
440
|
link: string;
|
|
437
|
-
}) => NonDeleted<
|
|
441
|
+
}) => NonDeleted<ExcalidrawEmbeddableElement> | undefined;
|
|
438
442
|
private createImageElement;
|
|
439
443
|
private handleLinearElementOnPointerDown;
|
|
440
444
|
private getCurrentItemRoundness;
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import "./ToolIcon.scss";
|
|
2
|
+
type LaserPointerIconProps = {
|
|
3
|
+
title?: string;
|
|
4
|
+
name?: string;
|
|
5
|
+
checked: boolean;
|
|
6
|
+
onChange?(): void;
|
|
7
|
+
isMobile?: boolean;
|
|
8
|
+
};
|
|
9
|
+
export declare const LaserPointerButton: (props: LaserPointerIconProps) => import("react/jsx-runtime").JSX.Element;
|
|
10
|
+
export {};
|
|
@@ -42,7 +42,7 @@ export declare const HelpIcon: import("react/jsx-runtime").JSX.Element;
|
|
|
42
42
|
export declare const ExternalLinkIcon: import("react/jsx-runtime").JSX.Element;
|
|
43
43
|
export declare const GithubIcon: import("react/jsx-runtime").JSX.Element;
|
|
44
44
|
export declare const DiscordIcon: import("react/jsx-runtime").JSX.Element;
|
|
45
|
-
export declare const
|
|
45
|
+
export declare const XBrandIcon: import("react/jsx-runtime").JSX.Element;
|
|
46
46
|
export declare const checkIcon: import("react/jsx-runtime").JSX.Element;
|
|
47
47
|
export declare const LinkIcon: import("react/jsx-runtime").JSX.Element;
|
|
48
48
|
export declare const save: import("react/jsx-runtime").JSX.Element;
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { AppState, ExcalidrawProps, UIAppState } from "../types";
|
|
2
|
-
import { NonDeletedExcalidrawElement } from "./types";
|
|
2
|
+
import { ExcalidrawEmbeddableElement, NonDeletedExcalidrawElement } from "./types";
|
|
3
3
|
import { Bounds } from "./bounds";
|
|
4
4
|
import "./Hyperlink.scss";
|
|
5
5
|
export declare const EXTERNAL_LINK_IMG: HTMLImageElement;
|
|
6
|
-
export declare const Hyperlink: ({ element, setAppState, onLinkOpen, setToast, }: {
|
|
6
|
+
export declare const Hyperlink: ({ element, setAppState, onLinkOpen, setToast, updateEmbedValidationStatus, }: {
|
|
7
7
|
element: NonDeletedExcalidrawElement;
|
|
8
8
|
setAppState: React.Component<any, AppState>["setState"];
|
|
9
9
|
onLinkOpen: ExcalidrawProps["onLinkOpen"];
|
|
@@ -12,6 +12,7 @@ export declare const Hyperlink: ({ element, setAppState, onLinkOpen, setToast, }
|
|
|
12
12
|
closable?: boolean;
|
|
13
13
|
duration?: number;
|
|
14
14
|
} | null) => void;
|
|
15
|
+
updateEmbedValidationStatus: (element: ExcalidrawEmbeddableElement, status: boolean) => void;
|
|
15
16
|
}) => import("react/jsx-runtime").JSX.Element | null;
|
|
16
17
|
export declare const actionLink: {
|
|
17
18
|
name: "hyperlink";
|
|
@@ -196,5 +196,5 @@ export declare const actionSetEmbeddableAsActiveTool: {
|
|
|
196
196
|
} & {
|
|
197
197
|
keyTest?: undefined;
|
|
198
198
|
};
|
|
199
|
-
export declare const
|
|
199
|
+
export declare const maybeParseEmbedSrc: (str: string) => string;
|
|
200
200
|
export declare const embeddableURLValidator: (url: string | null | undefined, validateEmbeddable: ExcalidrawProps["validateEmbeddable"]) => boolean;
|
|
@@ -232,7 +232,7 @@ export declare class LinearElementEditor {
|
|
|
232
232
|
offsetLeft: number;
|
|
233
233
|
fileHandle: import("browser-fs-access").FileSystemHandle | null;
|
|
234
234
|
collaborators: Map<import("../types").SocketId, Readonly<{
|
|
235
|
-
pointer?: import("../types").CollaboratorPointer | undefined;
|
|
235
|
+
pointer?: import("../types").CollaboratorPointer | undefined;
|
|
236
236
|
button?: "up" | "down" | undefined;
|
|
237
237
|
selectedElementIds?: Readonly<{
|
|
238
238
|
[id: string]: true;
|
|
@@ -7,7 +7,6 @@ export declare const newElement: (opts: {
|
|
|
7
7
|
} & ElementConstructorOpts) => NonDeleted<ExcalidrawGenericElement>;
|
|
8
8
|
export declare const newEmbeddableElement: (opts: {
|
|
9
9
|
type: "embeddable";
|
|
10
|
-
validated: ExcalidrawEmbeddableElement["validated"];
|
|
11
10
|
} & ElementConstructorOpts) => NonDeleted<ExcalidrawEmbeddableElement>;
|
|
12
11
|
export declare const newIframeElement: (opts: {
|
|
13
12
|
type: "iframe";
|
|
@@ -3,7 +3,6 @@ import { MaybeTransformHandleType } from "./transformHandles";
|
|
|
3
3
|
import { AppState } from "../types";
|
|
4
4
|
import { ExtractSetType } from "../utility-types";
|
|
5
5
|
export declare const normalizeText: (text: string) => string;
|
|
6
|
-
export declare const splitIntoLines: (text: string) => string[];
|
|
7
6
|
export declare const redrawTextBoundingBox: (textElement: ExcalidrawTextElement, container: ExcalidrawElement | null) => void;
|
|
8
7
|
export declare const bindTextToShapeAfterDuplication: (sceneElements: ExcalidrawElement[], oldElements: ExcalidrawElement[], oldIdToDuplicatedId: Map<ExcalidrawElement["id"], ExcalidrawElement["id"]>) => void;
|
|
9
8
|
export declare const handleBindTextResize: (container: NonDeletedExcalidrawElement, transformHandleType: MaybeTransformHandleType, shouldMaintainAspectRatio?: boolean) => void;
|
|
@@ -76,14 +76,6 @@ export type ExcalidrawEllipseElement = _ExcalidrawElementBase & {
|
|
|
76
76
|
};
|
|
77
77
|
export type ExcalidrawEmbeddableElement = _ExcalidrawElementBase & Readonly<{
|
|
78
78
|
type: "embeddable";
|
|
79
|
-
/**
|
|
80
|
-
* indicates whether the embeddable src (url) has been validated for rendering.
|
|
81
|
-
* null value indicates that the validation is pending. We reset the
|
|
82
|
-
* value on each restore (or url change) so that we can guarantee
|
|
83
|
-
* the validation came from a trusted source (the editor). Also because we
|
|
84
|
-
* may not have access to host-app supplied url validator during restore.
|
|
85
|
-
*/
|
|
86
|
-
validated: boolean | null;
|
|
87
79
|
scale: [number, number];
|
|
88
80
|
}>;
|
|
89
81
|
export type ExcalidrawIframeElement = _ExcalidrawElementBase & Readonly<{
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { AnimatedTrail, Trail } from "./animated-trail";
|
|
2
|
+
import { AnimationFrameHandler } from "./animation-frame-handler";
|
|
3
|
+
import type App from "./components/App";
|
|
4
|
+
export declare class LaserTrails implements Trail {
|
|
5
|
+
private animationFrameHandler;
|
|
6
|
+
private app;
|
|
7
|
+
localTrail: AnimatedTrail;
|
|
8
|
+
private collabTrails;
|
|
9
|
+
private container?;
|
|
10
|
+
constructor(animationFrameHandler: AnimationFrameHandler, app: App);
|
|
11
|
+
private getTrailOptions;
|
|
12
|
+
startPath(x: number, y: number): void;
|
|
13
|
+
addPointToPath(x: number, y: number): void;
|
|
14
|
+
endPath(): void;
|
|
15
|
+
start(container: SVGSVGElement): void;
|
|
16
|
+
stop(): void;
|
|
17
|
+
onFrame(): void;
|
|
18
|
+
private updateCollabTrails;
|
|
19
|
+
}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @param func handler taking at most single parameter (event).
|
|
3
|
+
*/
|
|
4
|
+
export declare const withBatchedUpdates: <TFunction extends ((event: any) => void) | (() => void)>(func: Parameters<TFunction>["length"] extends 0 | 1 ? TFunction : never) => TFunction;
|
|
5
|
+
/**
|
|
6
|
+
* barches React state updates and throttles the calls to a single call per
|
|
7
|
+
* animation frame
|
|
8
|
+
*/
|
|
9
|
+
export declare const withBatchedUpdatesThrottled: <TFunction extends ((event: any) => void) | (() => void)>(func: Parameters<TFunction>["length"] extends 0 | 1 ? TFunction : never) => {
|
|
10
|
+
(...args: Parameters<TFunction>): void;
|
|
11
|
+
flush(): void;
|
|
12
|
+
cancel(): void;
|
|
13
|
+
};
|
|
14
|
+
export declare const isRenderThrottlingEnabled: () => boolean;
|
|
@@ -1,8 +1,9 @@
|
|
|
1
|
-
import { ExcalidrawElement, ExcalidrawTextElement, NonDeletedExcalidrawElement, ExcalidrawFreeDrawElement } from "../element/types";
|
|
1
|
+
import { ExcalidrawElement, ExcalidrawTextElement, NonDeletedExcalidrawElement, ExcalidrawFreeDrawElement, ExcalidrawFrameLikeElement } from "../element/types";
|
|
2
2
|
import type { RoughCanvas } from "roughjs/bin/canvas";
|
|
3
3
|
import type { RoughSVG } from "roughjs/bin/svg";
|
|
4
4
|
import { SVGRenderConfig, StaticCanvasRenderConfig } from "../scene/types";
|
|
5
|
-
import { AppState, StaticCanvasAppState, BinaryFiles, InteractiveCanvasAppState } from "../types";
|
|
5
|
+
import { AppState, StaticCanvasAppState, BinaryFiles, InteractiveCanvasAppState, ElementsPendingErasure } from "../types";
|
|
6
|
+
export declare const getRenderOpacity: (element: ExcalidrawElement, containingFrame: ExcalidrawFrameLikeElement | null, elementsPendingErasure: ElementsPendingErasure) => number;
|
|
6
7
|
export interface ExcalidrawElementWithCanvas {
|
|
7
8
|
element: ExcalidrawElement | ExcalidrawTextElement;
|
|
8
9
|
canvas: HTMLCanvasElement;
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import type { Drawable, Options } from "roughjs/bin/core";
|
|
2
2
|
import type { RoughGenerator } from "roughjs/bin/generator";
|
|
3
3
|
import type { ExcalidrawElement, NonDeletedExcalidrawElement, ExcalidrawSelectionElement } from "../element/types";
|
|
4
|
+
import { EmbedsValidationStatus } from "../types";
|
|
4
5
|
export declare const generateRoughOptions: (element: ExcalidrawElement, continuousPath?: boolean) => Options;
|
|
5
6
|
/**
|
|
6
7
|
* Generates the roughjs shape for given element.
|
|
@@ -9,7 +10,8 @@ export declare const generateRoughOptions: (element: ExcalidrawElement, continuo
|
|
|
9
10
|
*
|
|
10
11
|
* @private
|
|
11
12
|
*/
|
|
12
|
-
export declare const _generateElementShape: (element: Exclude<NonDeletedExcalidrawElement, ExcalidrawSelectionElement>, generator: RoughGenerator, { isExporting, canvasBackgroundColor, }: {
|
|
13
|
+
export declare const _generateElementShape: (element: Exclude<NonDeletedExcalidrawElement, ExcalidrawSelectionElement>, generator: RoughGenerator, { isExporting, canvasBackgroundColor, embedsValidationStatus, }: {
|
|
13
14
|
isExporting: boolean;
|
|
14
15
|
canvasBackgroundColor: string;
|
|
16
|
+
embedsValidationStatus: EmbedsValidationStatus | null;
|
|
15
17
|
}) => Drawable | Drawable[] | null;
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { Drawable } from "roughjs/bin/core";
|
|
2
2
|
import { ExcalidrawElement } from "../element/types";
|
|
3
3
|
import { ElementShape, ElementShapes } from "./types";
|
|
4
|
-
import { AppState } from "../types";
|
|
4
|
+
import { AppState, EmbedsValidationStatus } from "../types";
|
|
5
5
|
export declare class ShapeCache {
|
|
6
6
|
private static rg;
|
|
7
7
|
private static cache;
|
|
@@ -20,5 +20,6 @@ export declare class ShapeCache {
|
|
|
20
20
|
static generateElementShape: <T extends import("../element/types").ExcalidrawRectangleElement | import("../element/types").ExcalidrawDiamondElement | import("../element/types").ExcalidrawEllipseElement | import("../element/types").ExcalidrawTextElement | import("../element/types").ExcalidrawLinearElement | import("../element/types").ExcalidrawFreeDrawElement | import("../element/types").ExcalidrawImageElement | import("../element/types").ExcalidrawFrameElement | import("../element/types").ExcalidrawMagicFrameElement | import("../element/types").ExcalidrawIframeElement | import("../element/types").ExcalidrawEmbeddableElement>(element: T, renderConfig: {
|
|
21
21
|
isExporting: boolean;
|
|
22
22
|
canvasBackgroundColor: AppState["viewBackgroundColor"];
|
|
23
|
+
embedsValidationStatus: EmbedsValidationStatus;
|
|
23
24
|
} | null) => ((T["type"] extends keyof ElementShapes ? ElementShapes[T["type"]] | undefined : ElementShape | undefined) & ({} | null)) | (T["type"] extends keyof ElementShapes ? ElementShapes[T["type"]] : Drawable | null);
|
|
24
25
|
}
|
|
@@ -19,6 +19,9 @@ export declare const exportToSvg: (elements: readonly NonDeletedExcalidrawElemen
|
|
|
19
19
|
frameRendering?: AppState["frameRendering"];
|
|
20
20
|
frameColor?: AppState["frameColor"];
|
|
21
21
|
}, files: BinaryFiles | null, opts?: {
|
|
22
|
+
/**
|
|
23
|
+
* if true, all embeddables passed in will be rendered when possible.
|
|
24
|
+
*/
|
|
22
25
|
renderEmbeddables?: boolean;
|
|
23
26
|
exportingFrame?: ExcalidrawFrameLikeElement | null;
|
|
24
27
|
}) => Promise<SVGSVGElement>;
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import type { RoughCanvas } from "roughjs/bin/canvas";
|
|
2
2
|
import { Drawable } from "roughjs/bin/core";
|
|
3
3
|
import { ExcalidrawTextElement, NonDeletedExcalidrawElement } from "../element/types";
|
|
4
|
-
import { AppClassProperties, AppState, InteractiveCanvasAppState, StaticCanvasAppState } from "../types";
|
|
4
|
+
import { AppClassProperties, AppState, EmbedsValidationStatus, ElementsPendingErasure, InteractiveCanvasAppState, StaticCanvasAppState } from "../types";
|
|
5
5
|
export type StaticCanvasRenderConfig = {
|
|
6
6
|
canvasBackgroundColor: AppState["viewBackgroundColor"];
|
|
7
7
|
imageCache: AppClassProperties["imageCache"];
|
|
@@ -9,6 +9,8 @@ export type StaticCanvasRenderConfig = {
|
|
|
9
9
|
/** when exporting the behavior is slightly different (e.g. we can't use
|
|
10
10
|
CSS filters), and we disable render optimizations for best output */
|
|
11
11
|
isExporting: boolean;
|
|
12
|
+
embedsValidationStatus: EmbedsValidationStatus;
|
|
13
|
+
elementsPendingErasure: ElementsPendingErasure;
|
|
12
14
|
};
|
|
13
15
|
export type SVGRenderConfig = {
|
|
14
16
|
offsetX: number;
|
|
@@ -19,6 +21,7 @@ export type SVGRenderConfig = {
|
|
|
19
21
|
frameRendering: AppState["frameRendering"];
|
|
20
22
|
canvasBackgroundColor: AppState["viewBackgroundColor"];
|
|
21
23
|
frameColor?: AppState["frameColor"];
|
|
24
|
+
embedsValidationStatus: EmbedsValidationStatus;
|
|
22
25
|
};
|
|
23
26
|
export type InteractiveCanvasRenderConfig = {
|
|
24
27
|
remoteSelectedElementIds: {
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import React from "react";
|
|
2
|
-
import { PointerType, ExcalidrawLinearElement, NonDeletedExcalidrawElement, NonDeleted, TextAlign, ExcalidrawElement, GroupId, ExcalidrawBindableElement, Arrowhead, ChartType, FontFamilyValues, ExcalidrawTextElement, FileId, ExcalidrawImageElement, Theme, StrokeRoundness, ExcalidrawEmbeddableElement, ExcalidrawMagicFrameElement, ExcalidrawFrameLikeElement, ExcalidrawElementType } from "./element/types";
|
|
2
|
+
import { PointerType, ExcalidrawLinearElement, NonDeletedExcalidrawElement, NonDeleted, TextAlign, ExcalidrawElement, GroupId, ExcalidrawBindableElement, Arrowhead, ChartType, FontFamilyValues, ExcalidrawTextElement, FileId, ExcalidrawImageElement, Theme, StrokeRoundness, ExcalidrawEmbeddableElement, ExcalidrawMagicFrameElement, ExcalidrawFrameLikeElement, ExcalidrawElementType, ExcalidrawIframeLikeElement } from "./element/types";
|
|
3
3
|
import { Action } from "./actions/types";
|
|
4
4
|
import { Point as RoughPoint } from "roughjs/bin/geometry";
|
|
5
5
|
import { LinearElementEditor } from "./element/linearElementEditor";
|
|
@@ -532,12 +532,6 @@ export type PointerDownState = Readonly<{
|
|
|
532
532
|
boxSelection: {
|
|
533
533
|
hasOccurred: boolean;
|
|
534
534
|
};
|
|
535
|
-
elementIdsToErase: {
|
|
536
|
-
[key: ExcalidrawElement["id"]]: {
|
|
537
|
-
opacity: ExcalidrawElement["opacity"];
|
|
538
|
-
erase: boolean;
|
|
539
|
-
};
|
|
540
|
-
};
|
|
541
535
|
}>;
|
|
542
536
|
export type UnsubscribeCallback = () => void;
|
|
543
537
|
export type ExcalidrawImperativeAPI = {
|
|
@@ -617,4 +611,6 @@ export type KeyboardModifiersObject = {
|
|
|
617
611
|
};
|
|
618
612
|
export type Primitive = number | string | boolean | bigint | symbol | null | undefined;
|
|
619
613
|
export type JSONValue = string | number | boolean | null | object;
|
|
614
|
+
export type EmbedsValidationStatus = Map<ExcalidrawIframeLikeElement["id"], boolean>;
|
|
615
|
+
export type ElementsPendingErasure = Set<ExcalidrawElement["id"]>;
|
|
620
616
|
export {};
|
|
@@ -141,19 +141,6 @@ export type ResolvablePromise<T> = Promise<T> & {
|
|
|
141
141
|
reject: (error: Error) => void;
|
|
142
142
|
};
|
|
143
143
|
export declare const resolvablePromise: <T>() => ResolvablePromise<T>;
|
|
144
|
-
/**
|
|
145
|
-
* @param func handler taking at most single parameter (event).
|
|
146
|
-
*/
|
|
147
|
-
export declare const withBatchedUpdates: <TFunction extends ((event: any) => void) | (() => void)>(func: Parameters<TFunction>["length"] extends 0 | 1 ? TFunction : never) => TFunction;
|
|
148
|
-
/**
|
|
149
|
-
* barches React state updates and throttles the calls to a single call per
|
|
150
|
-
* animation frame
|
|
151
|
-
*/
|
|
152
|
-
export declare const withBatchedUpdatesThrottled: <TFunction extends ((event: any) => void) | (() => void)>(func: Parameters<TFunction>["length"] extends 0 | 1 ? TFunction : never) => {
|
|
153
|
-
(...args: Parameters<TFunction>): void;
|
|
154
|
-
flush(): void;
|
|
155
|
-
cancel(): void;
|
|
156
|
-
};
|
|
157
144
|
export declare const nFormatter: (num: number, digits: number) => string;
|
|
158
145
|
export declare const getVersion: () => string;
|
|
159
146
|
export declare const supportsEmoji: () => boolean;
|
|
@@ -205,7 +192,6 @@ export declare const assertNever: (value: never, message: string | null, softAss
|
|
|
205
192
|
export declare const memoize: <T extends Record<string, any>, R extends unknown>(func: (opts: T) => R) => ((opts: T) => R) & {
|
|
206
193
|
clear: () => void;
|
|
207
194
|
};
|
|
208
|
-
export declare const isRenderThrottlingEnabled: () => boolean;
|
|
209
195
|
/** Checks if value is inside given collection. Useful for type-safety. */
|
|
210
196
|
export declare const isMemberOf: <T extends string>(collection: Set<T> | Record<T, any> | Map<T, any> | readonly T[], value: string) => value is T;
|
|
211
197
|
export declare const cloneJSON: <T>(obj: T) => T;
|
|
@@ -217,3 +203,5 @@ export declare function addEventListener<K extends keyof DocumentEventMap>(targe
|
|
|
217
203
|
export declare function addEventListener(target: Document, type: string, listener: (this: Document, ev: Event) => any, options?: boolean | AddEventListenerOptions): UnsubscribeCallback;
|
|
218
204
|
export declare function addEventListener<K extends keyof FontFaceSetEventMap>(target: FontFaceSet, type: K, listener: (this: FontFaceSet, ev: FontFaceSetEventMap[K]) => any, options?: boolean | AddEventListenerOptions): UnsubscribeCallback;
|
|
219
205
|
export declare function addEventListener<K extends keyof HTMLElementEventMap>(target: Document | (Window & typeof globalThis) | HTMLElement | undefined | null | false, type: K, listener: (this: HTMLDivElement, ev: HTMLElementEventMap[K]) => any, options?: boolean | AddEventListenerOptions): UnsubscribeCallback;
|
|
206
|
+
export declare function getSvgPathFromStroke(points: number[][], closed?: boolean): string;
|
|
207
|
+
export declare const normalizeEOL: (str: string) => string;
|