js-draw 1.9.1 → 1.11.0
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/Editor.css +48 -1
- package/dist/bundle.js +2 -2
- package/dist/bundledStyles.js +1 -1
- package/dist/cjs/Editor.d.ts +41 -0
- package/dist/cjs/Editor.js +9 -0
- package/dist/cjs/Pointer.js +1 -1
- package/dist/cjs/commands/Erase.d.ts +22 -2
- package/dist/cjs/commands/Erase.js +22 -2
- package/dist/cjs/commands/invertCommand.js +5 -0
- package/dist/cjs/commands/uniteCommands.d.ts +36 -0
- package/dist/cjs/commands/uniteCommands.js +36 -0
- package/dist/cjs/components/AbstractComponent.d.ts +8 -0
- package/dist/cjs/components/AbstractComponent.js +28 -8
- package/dist/cjs/components/ImageComponent.d.ts +12 -0
- package/dist/cjs/components/ImageComponent.js +16 -9
- package/dist/cjs/components/Stroke.d.ts +16 -2
- package/dist/cjs/components/Stroke.js +17 -1
- package/dist/cjs/components/builders/ArrowBuilder.js +3 -3
- package/dist/cjs/components/builders/CircleBuilder.js +3 -3
- package/dist/cjs/components/builders/FreehandLineBuilder.js +3 -3
- package/dist/cjs/components/builders/LineBuilder.js +3 -3
- package/dist/cjs/components/builders/PressureSensitiveFreehandLineBuilder.js +3 -3
- package/dist/cjs/components/builders/RectangleBuilder.js +5 -6
- package/dist/cjs/components/builders/autocorrect/makeShapeFitAutocorrect.d.ts +3 -0
- package/dist/cjs/components/builders/autocorrect/makeShapeFitAutocorrect.js +168 -0
- package/dist/cjs/components/builders/autocorrect/makeSnapToGridAutocorrect.d.ts +3 -0
- package/dist/cjs/components/builders/autocorrect/makeSnapToGridAutocorrect.js +46 -0
- package/dist/cjs/components/builders/types.d.ts +12 -0
- package/dist/cjs/image/EditorImage.d.ts +32 -1
- package/dist/cjs/image/EditorImage.js +32 -1
- package/dist/cjs/rendering/RenderablePathSpec.d.ts +5 -1
- package/dist/cjs/rendering/RenderablePathSpec.js +4 -0
- package/dist/cjs/toolbar/AbstractToolbar.d.ts +18 -2
- package/dist/cjs/toolbar/AbstractToolbar.js +46 -30
- package/dist/cjs/toolbar/IconProvider.d.ts +2 -0
- package/dist/cjs/toolbar/IconProvider.js +17 -0
- package/dist/cjs/toolbar/localization.d.ts +3 -0
- package/dist/cjs/toolbar/localization.js +4 -1
- package/dist/cjs/toolbar/widgets/BaseWidget.js +1 -1
- package/dist/cjs/toolbar/widgets/ExitActionWidget.d.ts +12 -0
- package/dist/cjs/toolbar/widgets/ExitActionWidget.js +32 -0
- package/dist/cjs/toolbar/widgets/HandToolWidget.d.ts +4 -3
- package/dist/cjs/toolbar/widgets/HandToolWidget.js +24 -13
- package/dist/cjs/toolbar/widgets/InsertImageWidget.d.ts +2 -1
- package/dist/cjs/toolbar/widgets/InsertImageWidget.js +102 -22
- package/dist/cjs/toolbar/widgets/PenToolWidget.d.ts +1 -2
- package/dist/cjs/toolbar/widgets/PenToolWidget.js +50 -20
- package/dist/cjs/toolbar/widgets/keybindings.d.ts +1 -0
- package/dist/cjs/toolbar/widgets/keybindings.js +4 -1
- package/dist/cjs/toolbar/widgets/layout/types.d.ts +1 -1
- package/dist/cjs/tools/Pen.d.ts +9 -0
- package/dist/cjs/tools/Pen.js +82 -3
- package/dist/cjs/tools/SelectionTool/Selection.d.ts +4 -0
- package/dist/cjs/tools/SelectionTool/Selection.js +56 -12
- package/dist/cjs/tools/SelectionTool/SelectionTool.d.ts +1 -0
- package/dist/cjs/tools/SelectionTool/SelectionTool.js +19 -1
- package/dist/cjs/tools/TextTool.js +5 -1
- package/dist/cjs/tools/ToolSwitcherShortcut.d.ts +0 -1
- package/dist/cjs/tools/ToolSwitcherShortcut.js +0 -1
- package/dist/cjs/tools/keybindings.d.ts +1 -0
- package/dist/cjs/tools/keybindings.js +3 -1
- package/dist/cjs/tools/util/StationaryPenDetector.d.ts +22 -0
- package/dist/cjs/tools/util/StationaryPenDetector.js +95 -0
- package/dist/cjs/util/ReactiveValue.d.ts +2 -0
- package/dist/cjs/util/ReactiveValue.js +2 -0
- package/dist/cjs/util/lib.d.ts +1 -0
- package/dist/cjs/util/lib.js +4 -1
- package/dist/cjs/util/waitForImageLoaded.d.ts +2 -0
- package/dist/cjs/util/waitForImageLoaded.js +12 -0
- package/dist/cjs/version.js +1 -1
- package/dist/mjs/Editor.d.ts +41 -0
- package/dist/mjs/Editor.mjs +9 -0
- package/dist/mjs/Pointer.mjs +1 -1
- package/dist/mjs/commands/Erase.d.ts +22 -2
- package/dist/mjs/commands/Erase.mjs +22 -2
- package/dist/mjs/commands/invertCommand.mjs +5 -0
- package/dist/mjs/commands/uniteCommands.d.ts +36 -0
- package/dist/mjs/commands/uniteCommands.mjs +36 -0
- package/dist/mjs/components/AbstractComponent.d.ts +8 -0
- package/dist/mjs/components/AbstractComponent.mjs +28 -8
- package/dist/mjs/components/ImageComponent.d.ts +12 -0
- package/dist/mjs/components/ImageComponent.mjs +16 -9
- package/dist/mjs/components/Stroke.d.ts +16 -2
- package/dist/mjs/components/Stroke.mjs +17 -1
- package/dist/mjs/components/builders/ArrowBuilder.mjs +3 -2
- package/dist/mjs/components/builders/CircleBuilder.mjs +3 -2
- package/dist/mjs/components/builders/FreehandLineBuilder.mjs +3 -2
- package/dist/mjs/components/builders/LineBuilder.mjs +3 -2
- package/dist/mjs/components/builders/PressureSensitiveFreehandLineBuilder.mjs +3 -2
- package/dist/mjs/components/builders/RectangleBuilder.mjs +5 -4
- package/dist/mjs/components/builders/autocorrect/makeShapeFitAutocorrect.d.ts +3 -0
- package/dist/mjs/components/builders/autocorrect/makeShapeFitAutocorrect.mjs +166 -0
- package/dist/mjs/components/builders/autocorrect/makeSnapToGridAutocorrect.d.ts +3 -0
- package/dist/mjs/components/builders/autocorrect/makeSnapToGridAutocorrect.mjs +44 -0
- package/dist/mjs/components/builders/types.d.ts +12 -0
- package/dist/mjs/image/EditorImage.d.ts +32 -1
- package/dist/mjs/image/EditorImage.mjs +32 -1
- package/dist/mjs/rendering/RenderablePathSpec.d.ts +5 -1
- package/dist/mjs/rendering/RenderablePathSpec.mjs +4 -0
- package/dist/mjs/toolbar/AbstractToolbar.d.ts +18 -2
- package/dist/mjs/toolbar/AbstractToolbar.mjs +46 -30
- package/dist/mjs/toolbar/IconProvider.d.ts +2 -0
- package/dist/mjs/toolbar/IconProvider.mjs +17 -0
- package/dist/mjs/toolbar/localization.d.ts +3 -0
- package/dist/mjs/toolbar/localization.mjs +4 -1
- package/dist/mjs/toolbar/widgets/BaseWidget.mjs +1 -1
- package/dist/mjs/toolbar/widgets/ExitActionWidget.d.ts +12 -0
- package/dist/mjs/toolbar/widgets/ExitActionWidget.mjs +27 -0
- package/dist/mjs/toolbar/widgets/HandToolWidget.d.ts +4 -3
- package/dist/mjs/toolbar/widgets/HandToolWidget.mjs +24 -13
- package/dist/mjs/toolbar/widgets/InsertImageWidget.d.ts +2 -1
- package/dist/mjs/toolbar/widgets/InsertImageWidget.mjs +102 -22
- package/dist/mjs/toolbar/widgets/PenToolWidget.d.ts +1 -2
- package/dist/mjs/toolbar/widgets/PenToolWidget.mjs +50 -20
- package/dist/mjs/toolbar/widgets/keybindings.d.ts +1 -0
- package/dist/mjs/toolbar/widgets/keybindings.mjs +3 -0
- package/dist/mjs/toolbar/widgets/layout/types.d.ts +1 -1
- package/dist/mjs/tools/Pen.d.ts +9 -0
- package/dist/mjs/tools/Pen.mjs +82 -3
- package/dist/mjs/tools/SelectionTool/Selection.d.ts +4 -0
- package/dist/mjs/tools/SelectionTool/Selection.mjs +56 -12
- package/dist/mjs/tools/SelectionTool/SelectionTool.d.ts +1 -0
- package/dist/mjs/tools/SelectionTool/SelectionTool.mjs +20 -2
- package/dist/mjs/tools/TextTool.mjs +5 -1
- package/dist/mjs/tools/ToolSwitcherShortcut.d.ts +0 -1
- package/dist/mjs/tools/ToolSwitcherShortcut.mjs +0 -1
- package/dist/mjs/tools/keybindings.d.ts +1 -0
- package/dist/mjs/tools/keybindings.mjs +2 -0
- package/dist/mjs/tools/util/StationaryPenDetector.d.ts +22 -0
- package/dist/mjs/tools/util/StationaryPenDetector.mjs +92 -0
- package/dist/mjs/util/ReactiveValue.d.ts +2 -0
- package/dist/mjs/util/ReactiveValue.mjs +2 -0
- package/dist/mjs/util/lib.d.ts +1 -0
- package/dist/mjs/util/lib.mjs +1 -0
- package/dist/mjs/util/waitForImageLoaded.d.ts +2 -0
- package/dist/mjs/util/waitForImageLoaded.mjs +10 -0
- package/dist/mjs/version.mjs +1 -1
- package/package.json +3 -3
- package/src/Editor.scss +7 -0
- package/src/toolbar/AbstractToolbar.scss +20 -0
- package/src/toolbar/toolbar.scss +1 -1
- package/src/toolbar/widgets/InsertImageWidget.scss +6 -1
- package/src/toolbar/widgets/PenToolWidget.scss +33 -0
- package/src/tools/SelectionTool/SelectionTool.scss +6 -0
- package/src/toolbar/widgets/PenToolWidget.css +0 -2
package/src/Editor.scss
CHANGED
@@ -74,6 +74,13 @@
|
|
74
74
|
min-height: 220px;
|
75
75
|
min-width: 100px;
|
76
76
|
|
77
|
+
// A vertical writing mode breaks assumptions about how toolbars/overlays
|
78
|
+
// are aligned, resulting in unusable toolbars/text.
|
79
|
+
//
|
80
|
+
// TODO: Fix this.
|
81
|
+
//
|
82
|
+
writing-mode: horizontal-tb;
|
83
|
+
|
77
84
|
box-sizing: border-box;
|
78
85
|
|
79
86
|
display: flex;
|
@@ -217,6 +217,26 @@
|
|
217
217
|
justify-content: center;
|
218
218
|
}
|
219
219
|
|
220
|
+
.toolbar-element .toolbar--toggle-button {
|
221
|
+
color: var(--foreground-color-1);
|
222
|
+
font-weight: normal;
|
223
|
+
|
224
|
+
&[aria-checked=true] {
|
225
|
+
background: var(--selection-background-color);
|
226
|
+
color: var(--selection-foreground-color);
|
227
|
+
}
|
228
|
+
|
229
|
+
> .icon {
|
230
|
+
width: 25px;
|
231
|
+
height: 25px;
|
232
|
+
margin: 0 5px;
|
233
|
+
}
|
234
|
+
|
235
|
+
> * {
|
236
|
+
vertical-align: middle;
|
237
|
+
}
|
238
|
+
}
|
239
|
+
|
220
240
|
.toolbar-closeColorPickerOverlay {
|
221
241
|
display: none;
|
222
242
|
position: fixed;
|
package/src/toolbar/toolbar.scss
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
@use "./widgets/InsertImageWidget.scss";
|
2
2
|
@use "./widgets/OverflowWidget.css";
|
3
|
-
@use "./widgets/PenToolWidget.
|
3
|
+
@use "./widgets/PenToolWidget.scss";
|
4
4
|
@use "./widgets/HandToolWidget.scss";
|
5
5
|
@use "./widgets/SelectionToolWidget.scss";
|
6
6
|
@use "./widgets/DocumentPropertiesWidget.scss";
|
@@ -12,7 +12,7 @@ $image-widget-selector: '.insert-image-widget-dropdown-content';
|
|
12
12
|
|
13
13
|
img {
|
14
14
|
max-width: min(50vw, 75%);
|
15
|
-
max-height: 50vh;
|
15
|
+
max-height: min(300px, 50vh);
|
16
16
|
|
17
17
|
/* Center */
|
18
18
|
display: block;
|
@@ -20,6 +20,11 @@ $image-widget-selector: '.insert-image-widget-dropdown-content';
|
|
20
20
|
margin-right: auto;
|
21
21
|
}
|
22
22
|
|
23
|
+
.insert-image-image-status-view {
|
24
|
+
display: flex;
|
25
|
+
justify-content: space-between;
|
26
|
+
}
|
27
|
+
|
23
28
|
.action-button-row {
|
24
29
|
margin-top: 4px;
|
25
30
|
display: flex;
|
@@ -0,0 +1,33 @@
|
|
1
|
+
|
2
|
+
|
3
|
+
// Repeat selector for extra specificity
|
4
|
+
:root .toolbar--pen-tool-toggle-buttons.toolbar--pen-tool-toggle-buttons {
|
5
|
+
display: flex;
|
6
|
+
justify-content: stretch;
|
7
|
+
padding-top: 0;
|
8
|
+
padding-bottom: 5px;
|
9
|
+
|
10
|
+
// Some styles rely on left being start.
|
11
|
+
direction: ltr;
|
12
|
+
|
13
|
+
& > * {
|
14
|
+
flex-grow: 1;
|
15
|
+
text-align: start;
|
16
|
+
margin-inline-end: 5px;
|
17
|
+
|
18
|
+
.icon {
|
19
|
+
margin: 0;
|
20
|
+
margin-inline-start: 4px;
|
21
|
+
margin-inline-end: 10px;
|
22
|
+
}
|
23
|
+
}
|
24
|
+
|
25
|
+
& > :nth-child(1) {
|
26
|
+
direction: ltr;
|
27
|
+
}
|
28
|
+
|
29
|
+
& > :last-child {
|
30
|
+
// Reverse the last (show icon on the right)
|
31
|
+
direction: rtl;
|
32
|
+
}
|
33
|
+
}
|
@@ -83,6 +83,12 @@
|
|
83
83
|
.overlay.handleOverlay {
|
84
84
|
touch-action: none;
|
85
85
|
|
86
|
+
// The selection tool makes some assumptions about margin-left, margin-top,
|
87
|
+
// and the initial (unmodified) position of the selection.
|
88
|
+
//
|
89
|
+
// For now, as we're not showing text in the selection box, force LTR.
|
90
|
+
direction: ltr;
|
91
|
+
|
86
92
|
// When expanding a selection with shift+click&drag, multiple selection boxes
|
87
93
|
// can be present in the same handleOverlay. As such, so that other overlayed
|
88
94
|
// selection boxes are in the correct place, the outer container needs to have
|