js-draw 1.0.0 → 1.0.1
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/README.md +20 -6
- package/dist/bundle.js +1 -1
- package/dist/cjs/Editor.js +1 -1
- package/dist/cjs/Editor.loadFrom.test.d.ts +1 -0
- package/dist/cjs/Editor.test.d.ts +1 -0
- package/dist/cjs/Editor.toSVG.test.d.ts +1 -0
- package/dist/cjs/EditorImage.test.d.ts +1 -0
- package/dist/cjs/EventDispatcher.test.d.ts +1 -0
- package/dist/cjs/SVGLoader.test.d.ts +1 -0
- package/dist/cjs/UndoRedoHistory.test.d.ts +1 -0
- package/dist/cjs/commands/uniteCommands.test.d.ts +1 -0
- package/dist/cjs/components/AbstractComponent.transformBy.test.d.ts +1 -0
- package/dist/cjs/components/BackgroundComponent.test.d.ts +1 -0
- package/dist/cjs/components/Stroke.test.d.ts +1 -0
- package/dist/cjs/components/TextComponent.test.d.ts +1 -0
- package/dist/cjs/components/UnknownSVGObject.test.d.ts +1 -0
- package/dist/cjs/components/builders/FreehandLineBuilder.test.d.ts +1 -0
- package/dist/cjs/localizations/getLocalizationTable.test.d.ts +1 -0
- package/dist/cjs/rendering/RenderingStyle.test.d.ts +1 -0
- package/dist/cjs/rendering/caching/CacheRecord.test.d.ts +1 -0
- package/dist/cjs/rendering/caching/RenderingCache.test.d.ts +1 -0
- package/dist/cjs/rendering/renderers/DummyRenderer.test.d.ts +1 -0
- package/dist/cjs/rendering/renderers/TextOnlyRenderer.test.d.ts +1 -0
- package/dist/cjs/shortcuts/KeyBinding.test.d.ts +1 -0
- package/dist/cjs/shortcuts/KeyboardShortcutManager.test.d.ts +1 -0
- package/dist/cjs/toolbar/EdgeToolbar.test.d.ts +1 -0
- package/dist/cjs/tools/Eraser.test.d.ts +1 -0
- package/dist/cjs/tools/FindTool.test.d.ts +1 -0
- package/dist/cjs/tools/InputFilter/InputPipeline.test.d.ts +1 -0
- package/dist/cjs/tools/PanZoom.test.d.ts +1 -0
- package/dist/cjs/tools/Pen.test.d.ts +1 -0
- package/dist/cjs/tools/SelectionTool/SelectionTool.test.d.ts +1 -0
- package/dist/cjs/tools/UndoRedoShortcut.test.d.ts +1 -0
- package/dist/cjs/util/ReactiveValue.test.d.ts +1 -0
- package/dist/cjs/version.js +1 -1
- package/dist/cjs/version.test.d.ts +1 -0
- package/dist/mjs/Editor.loadFrom.test.d.ts +1 -0
- package/dist/mjs/Editor.mjs +1 -1
- package/dist/mjs/Editor.test.d.ts +1 -0
- package/dist/mjs/Editor.toSVG.test.d.ts +1 -0
- package/dist/mjs/EditorImage.test.d.ts +1 -0
- package/dist/mjs/EventDispatcher.test.d.ts +1 -0
- package/dist/mjs/SVGLoader.test.d.ts +1 -0
- package/dist/mjs/UndoRedoHistory.test.d.ts +1 -0
- package/dist/mjs/commands/uniteCommands.test.d.ts +1 -0
- package/dist/mjs/components/AbstractComponent.transformBy.test.d.ts +1 -0
- package/dist/mjs/components/BackgroundComponent.test.d.ts +1 -0
- package/dist/mjs/components/Stroke.test.d.ts +1 -0
- package/dist/mjs/components/TextComponent.test.d.ts +1 -0
- package/dist/mjs/components/UnknownSVGObject.test.d.ts +1 -0
- package/dist/mjs/components/builders/FreehandLineBuilder.test.d.ts +1 -0
- package/dist/mjs/localizations/getLocalizationTable.test.d.ts +1 -0
- package/dist/mjs/rendering/RenderingStyle.test.d.ts +1 -0
- package/dist/mjs/rendering/caching/CacheRecord.test.d.ts +1 -0
- package/dist/mjs/rendering/caching/RenderingCache.test.d.ts +1 -0
- package/dist/mjs/rendering/renderers/DummyRenderer.test.d.ts +1 -0
- package/dist/mjs/rendering/renderers/TextOnlyRenderer.test.d.ts +1 -0
- package/dist/mjs/shortcuts/KeyBinding.test.d.ts +1 -0
- package/dist/mjs/shortcuts/KeyboardShortcutManager.test.d.ts +1 -0
- package/dist/mjs/toolbar/EdgeToolbar.test.d.ts +1 -0
- package/dist/mjs/tools/Eraser.test.d.ts +1 -0
- package/dist/mjs/tools/FindTool.test.d.ts +1 -0
- package/dist/mjs/tools/InputFilter/InputPipeline.test.d.ts +1 -0
- package/dist/mjs/tools/PanZoom.test.d.ts +1 -0
- package/dist/mjs/tools/Pen.test.d.ts +1 -0
- package/dist/mjs/tools/SelectionTool/SelectionTool.test.d.ts +1 -0
- package/dist/mjs/tools/UndoRedoShortcut.test.d.ts +1 -0
- package/dist/mjs/util/ReactiveValue.test.d.ts +1 -0
- package/dist/mjs/version.mjs +1 -1
- package/dist/mjs/version.test.d.ts +1 -0
- package/dist-test/test_imports/package-lock.json +13 -0
- package/dist-test/test_imports/package.json +12 -0
- package/dist-test/test_imports/test-imports.js +11 -0
- package/dist-test/test_imports/test-require.cjs +14 -0
- package/package.json +2 -2
- package/src/Editor.loadFrom.test.ts +24 -0
- package/src/Editor.test.ts +107 -0
- package/src/Editor.toSVG.test.ts +294 -0
- package/src/Editor.ts +1443 -0
- package/src/EditorImage.test.ts +117 -0
- package/src/EditorImage.ts +609 -0
- package/src/EventDispatcher.test.ts +123 -0
- package/src/EventDispatcher.ts +72 -0
- package/src/Pointer.ts +183 -0
- package/src/SVGLoader.test.ts +114 -0
- package/src/SVGLoader.ts +672 -0
- package/src/UndoRedoHistory.test.ts +34 -0
- package/src/UndoRedoHistory.ts +102 -0
- package/src/Viewport.ts +322 -0
- package/src/bundle/bundled.ts +7 -0
- package/src/commands/Command.ts +45 -0
- package/src/commands/Duplicate.ts +75 -0
- package/src/commands/Erase.ts +95 -0
- package/src/commands/SerializableCommand.ts +49 -0
- package/src/commands/UnresolvedCommand.ts +37 -0
- package/src/commands/invertCommand.ts +58 -0
- package/src/commands/lib.ts +16 -0
- package/src/commands/localization.ts +47 -0
- package/src/commands/uniteCommands.test.ts +23 -0
- package/src/commands/uniteCommands.ts +140 -0
- package/src/components/AbstractComponent.transformBy.test.ts +23 -0
- package/src/components/AbstractComponent.ts +383 -0
- package/src/components/BackgroundComponent.test.ts +44 -0
- package/src/components/BackgroundComponent.ts +348 -0
- package/src/components/ImageComponent.ts +176 -0
- package/src/components/RestylableComponent.ts +161 -0
- package/src/components/SVGGlobalAttributesObject.ts +79 -0
- package/src/components/Stroke.test.ts +137 -0
- package/src/components/Stroke.ts +294 -0
- package/src/components/TextComponent.test.ts +202 -0
- package/src/components/TextComponent.ts +429 -0
- package/src/components/UnknownSVGObject.test.ts +10 -0
- package/src/components/UnknownSVGObject.ts +60 -0
- package/src/components/builders/ArrowBuilder.ts +106 -0
- package/src/components/builders/CircleBuilder.ts +100 -0
- package/src/components/builders/FreehandLineBuilder.test.ts +24 -0
- package/src/components/builders/FreehandLineBuilder.ts +210 -0
- package/src/components/builders/LineBuilder.ts +77 -0
- package/src/components/builders/PressureSensitiveFreehandLineBuilder.ts +453 -0
- package/src/components/builders/RectangleBuilder.ts +73 -0
- package/src/components/builders/types.ts +15 -0
- package/src/components/lib.ts +31 -0
- package/src/components/localization.ts +24 -0
- package/src/components/util/StrokeSmoother.ts +302 -0
- package/src/components/util/describeComponentList.ts +18 -0
- package/src/dialogs/makeAboutDialog.ts +82 -0
- package/src/inputEvents.ts +143 -0
- package/src/lib.ts +91 -0
- package/src/localization.ts +34 -0
- package/src/localizations/de.ts +146 -0
- package/src/localizations/en.ts +8 -0
- package/src/localizations/es.ts +74 -0
- package/src/localizations/getLocalizationTable.test.ts +27 -0
- package/src/localizations/getLocalizationTable.ts +74 -0
- package/src/rendering/Display.ts +247 -0
- package/src/rendering/RenderablePathSpec.ts +88 -0
- package/src/rendering/RenderingStyle.test.ts +68 -0
- package/src/rendering/RenderingStyle.ts +55 -0
- package/src/rendering/TextRenderingStyle.ts +55 -0
- package/src/rendering/caching/CacheRecord.test.ts +48 -0
- package/src/rendering/caching/CacheRecord.ts +76 -0
- package/src/rendering/caching/CacheRecordManager.ts +71 -0
- package/src/rendering/caching/RenderingCache.test.ts +43 -0
- package/src/rendering/caching/RenderingCache.ts +66 -0
- package/src/rendering/caching/RenderingCacheNode.ts +404 -0
- package/src/rendering/caching/testUtils.ts +35 -0
- package/src/rendering/caching/types.ts +34 -0
- package/src/rendering/lib.ts +8 -0
- package/src/rendering/localization.ts +20 -0
- package/src/rendering/renderers/AbstractRenderer.ts +232 -0
- package/src/rendering/renderers/CanvasRenderer.ts +312 -0
- package/src/rendering/renderers/DummyRenderer.test.ts +41 -0
- package/src/rendering/renderers/DummyRenderer.ts +142 -0
- package/src/rendering/renderers/SVGRenderer.ts +434 -0
- package/src/rendering/renderers/TextOnlyRenderer.test.ts +34 -0
- package/src/rendering/renderers/TextOnlyRenderer.ts +68 -0
- package/src/shortcuts/KeyBinding.test.ts +61 -0
- package/src/shortcuts/KeyBinding.ts +257 -0
- package/src/shortcuts/KeyboardShortcutManager.test.ts +95 -0
- package/src/shortcuts/KeyboardShortcutManager.ts +163 -0
- package/src/shortcuts/lib.ts +3 -0
- package/src/testing/createEditor.ts +11 -0
- package/src/testing/getUniquePointerId.ts +18 -0
- package/src/testing/lib.ts +3 -0
- package/src/testing/sendPenEvent.ts +36 -0
- package/src/testing/sendTouchEvent.ts +71 -0
- package/src/toolbar/AbstractToolbar.ts +542 -0
- package/src/toolbar/DropdownToolbar.ts +220 -0
- package/src/toolbar/EdgeToolbar.test.ts +54 -0
- package/src/toolbar/EdgeToolbar.ts +543 -0
- package/src/toolbar/IconProvider.ts +861 -0
- package/src/toolbar/constants.ts +1 -0
- package/src/toolbar/lib.ts +6 -0
- package/src/toolbar/localization.ts +136 -0
- package/src/toolbar/types.ts +13 -0
- package/src/toolbar/widgets/ActionButtonWidget.ts +39 -0
- package/src/toolbar/widgets/BaseToolWidget.ts +81 -0
- package/src/toolbar/widgets/BaseWidget.ts +495 -0
- package/src/toolbar/widgets/DocumentPropertiesWidget.ts +250 -0
- package/src/toolbar/widgets/EraserToolWidget.ts +84 -0
- package/src/toolbar/widgets/HandToolWidget.ts +239 -0
- package/src/toolbar/widgets/InsertImageWidget.ts +248 -0
- package/src/toolbar/widgets/OverflowWidget.ts +92 -0
- package/src/toolbar/widgets/PenToolWidget.ts +369 -0
- package/src/toolbar/widgets/SelectionToolWidget.ts +195 -0
- package/src/toolbar/widgets/TextToolWidget.ts +149 -0
- package/src/toolbar/widgets/components/makeColorInput.ts +184 -0
- package/src/toolbar/widgets/components/makeFileInput.ts +128 -0
- package/src/toolbar/widgets/components/makeGridSelector.ts +179 -0
- package/src/toolbar/widgets/components/makeSeparator.ts +17 -0
- package/src/toolbar/widgets/components/makeThicknessSlider.ts +62 -0
- package/src/toolbar/widgets/keybindings.ts +19 -0
- package/src/toolbar/widgets/layout/DropdownLayoutManager.ts +262 -0
- package/src/toolbar/widgets/layout/EdgeToolbarLayoutManager.ts +71 -0
- package/src/toolbar/widgets/layout/types.ts +74 -0
- package/src/toolbar/widgets/lib.ts +13 -0
- package/src/tools/BaseTool.ts +169 -0
- package/src/tools/Eraser.test.ts +103 -0
- package/src/tools/Eraser.ts +173 -0
- package/src/tools/FindTool.test.ts +67 -0
- package/src/tools/FindTool.ts +153 -0
- package/src/tools/InputFilter/FunctionMapper.ts +17 -0
- package/src/tools/InputFilter/InputMapper.ts +41 -0
- package/src/tools/InputFilter/InputPipeline.test.ts +41 -0
- package/src/tools/InputFilter/InputPipeline.ts +34 -0
- package/src/tools/InputFilter/InputStabilizer.ts +254 -0
- package/src/tools/InputFilter/StrokeKeyboardControl.ts +104 -0
- package/src/tools/PanZoom.test.ts +339 -0
- package/src/tools/PanZoom.ts +525 -0
- package/src/tools/PasteHandler.ts +94 -0
- package/src/tools/Pen.test.ts +260 -0
- package/src/tools/Pen.ts +284 -0
- package/src/tools/PipetteTool.ts +84 -0
- package/src/tools/SelectionTool/SelectAllShortcutHandler.ts +29 -0
- package/src/tools/SelectionTool/Selection.ts +647 -0
- package/src/tools/SelectionTool/SelectionHandle.ts +142 -0
- package/src/tools/SelectionTool/SelectionTool.test.ts +370 -0
- package/src/tools/SelectionTool/SelectionTool.ts +510 -0
- package/src/tools/SelectionTool/TransformMode.ts +112 -0
- package/src/tools/SelectionTool/types.ts +11 -0
- package/src/tools/SoundUITool.ts +221 -0
- package/src/tools/TextTool.ts +339 -0
- package/src/tools/ToolController.ts +224 -0
- package/src/tools/ToolEnabledGroup.ts +14 -0
- package/src/tools/ToolSwitcherShortcut.ts +39 -0
- package/src/tools/ToolbarShortcutHandler.ts +39 -0
- package/src/tools/UndoRedoShortcut.test.ts +62 -0
- package/src/tools/UndoRedoShortcut.ts +24 -0
- package/src/tools/keybindings.ts +85 -0
- package/src/tools/lib.ts +22 -0
- package/src/tools/localization.ts +76 -0
- package/src/types.ts +151 -0
- package/src/util/ReactiveValue.test.ts +168 -0
- package/src/util/ReactiveValue.ts +241 -0
- package/src/util/assertions.ts +55 -0
- package/src/util/fileToBase64.ts +18 -0
- package/src/util/guessKeyCodeFromKey.ts +36 -0
- package/src/util/listPrefixMatch.ts +19 -0
- package/src/util/stopPropagationOfScrollingWheelEvents.ts +20 -0
- package/src/util/untilNextAnimationFrame.ts +9 -0
- package/src/util/waitForAll.ts +18 -0
- package/src/util/waitForTimeout.ts +9 -0
- package/src/version.test.ts +12 -0
- package/src/version.ts +3 -0
@@ -0,0 +1 @@
|
|
1
|
+
export const toolbarCSSPrefix = 'toolbar-';
|
@@ -0,0 +1,6 @@
|
|
1
|
+
|
2
|
+
export * from './widgets/lib';
|
3
|
+
export * from './widgets/components/makeColorInput';
|
4
|
+
export { default as IconProvider, IconElemType } from './IconProvider';
|
5
|
+
export { makeDropdownToolbar } from './DropdownToolbar';
|
6
|
+
export { makeEdgeToolbar } from './EdgeToolbar';
|
@@ -0,0 +1,136 @@
|
|
1
|
+
|
2
|
+
|
3
|
+
export interface ToolbarLocalization {
|
4
|
+
fontLabel: string;
|
5
|
+
textSize: string;
|
6
|
+
touchPanning: string;
|
7
|
+
lockRotation: string;
|
8
|
+
outlinedRectanglePen: string;
|
9
|
+
outlinedCirclePen: string,
|
10
|
+
filledRectanglePen: string;
|
11
|
+
linePen: string;
|
12
|
+
arrowPen: string;
|
13
|
+
image: string;
|
14
|
+
inputAltText: string;
|
15
|
+
chooseFile: string;
|
16
|
+
dragAndDropHereOrBrowse: string; // Uses {{curly braces}} to bold text
|
17
|
+
cancel: string;
|
18
|
+
submit: string;
|
19
|
+
roundedTipPen: string;
|
20
|
+
flatTipPen: string;
|
21
|
+
selectPenTip: string;
|
22
|
+
selectShape: string;
|
23
|
+
colorLabel: string;
|
24
|
+
pen: string;
|
25
|
+
eraser: string;
|
26
|
+
select: string;
|
27
|
+
handTool: string;
|
28
|
+
thicknessLabel: string;
|
29
|
+
resizeImageToSelection: string;
|
30
|
+
deleteSelection: string;
|
31
|
+
duplicateSelection: string;
|
32
|
+
|
33
|
+
pickColorFromScreen: string;
|
34
|
+
clickToPickColorAnnouncement: string;
|
35
|
+
colorSelectionCanceledAnnouncement: string;
|
36
|
+
|
37
|
+
undo: string;
|
38
|
+
redo: string;
|
39
|
+
exit: string;
|
40
|
+
save: string;
|
41
|
+
|
42
|
+
zoom: string;
|
43
|
+
resetView: string;
|
44
|
+
reformatSelection: string;
|
45
|
+
selectionToolKeyboardShortcuts: string;
|
46
|
+
paste: string;
|
47
|
+
documentProperties: string;
|
48
|
+
backgroundColor: string;
|
49
|
+
imageWidthOption: string;
|
50
|
+
imageHeightOption: string;
|
51
|
+
useGridOption: string;
|
52
|
+
toggleOverflow: string,
|
53
|
+
|
54
|
+
about: string;
|
55
|
+
inputStabilization: string;
|
56
|
+
|
57
|
+
errorImageHasZeroSize: string;
|
58
|
+
|
59
|
+
// closeSidebar is used for accessibility in a button label.
|
60
|
+
closeSidebar: (toolName: string)=>string;
|
61
|
+
dropdownShown: (toolName: string)=> string;
|
62
|
+
dropdownHidden: (toolName: string)=> string;
|
63
|
+
|
64
|
+
zoomLevel: (zoomPercentage: number)=> string;
|
65
|
+
colorChangedAnnouncement: (color: string)=> string;
|
66
|
+
imageSize: (size: number, units: string)=> string;
|
67
|
+
imageLoadError: (message: string)=> string;
|
68
|
+
}
|
69
|
+
|
70
|
+
export const defaultToolbarLocalization: ToolbarLocalization = {
|
71
|
+
pen: 'Pen',
|
72
|
+
eraser: 'Eraser',
|
73
|
+
select: 'Select',
|
74
|
+
handTool: 'Pan',
|
75
|
+
zoom: 'Zoom',
|
76
|
+
image: 'Image',
|
77
|
+
reformatSelection: 'Format selection',
|
78
|
+
inputAltText: 'Alt text',
|
79
|
+
chooseFile: 'Choose file',
|
80
|
+
dragAndDropHereOrBrowse: 'Drag and drop here\nor\n{{browse}}',
|
81
|
+
submit: 'Submit',
|
82
|
+
cancel: 'Cancel',
|
83
|
+
resetView: 'Reset view',
|
84
|
+
thicknessLabel: 'Thickness',
|
85
|
+
colorLabel: 'Color',
|
86
|
+
fontLabel: 'Font',
|
87
|
+
textSize: 'Size',
|
88
|
+
resizeImageToSelection: 'Resize image to selection',
|
89
|
+
deleteSelection: 'Delete selection',
|
90
|
+
duplicateSelection: 'Duplicate selection',
|
91
|
+
|
92
|
+
exit: 'Exit',
|
93
|
+
save: 'Save',
|
94
|
+
undo: 'Undo',
|
95
|
+
redo: 'Redo',
|
96
|
+
|
97
|
+
selectPenTip: 'Pen tip',
|
98
|
+
selectShape: 'Shape',
|
99
|
+
pickColorFromScreen: 'Pick color from screen',
|
100
|
+
clickToPickColorAnnouncement: 'Click on the screen to pick a color',
|
101
|
+
colorSelectionCanceledAnnouncement: 'Color selection canceled',
|
102
|
+
selectionToolKeyboardShortcuts: 'Selection tool: Use arrow keys to move selected items, lowercase/uppercase ‘i’ and ‘o’ to resize.',
|
103
|
+
documentProperties: 'Page',
|
104
|
+
backgroundColor: 'Background color',
|
105
|
+
imageWidthOption: 'Width',
|
106
|
+
imageHeightOption: 'Height',
|
107
|
+
useGridOption: 'Grid',
|
108
|
+
toggleOverflow: 'More',
|
109
|
+
about: 'About',
|
110
|
+
inputStabilization: 'Input stabilization',
|
111
|
+
|
112
|
+
touchPanning: 'Touchscreen panning',
|
113
|
+
|
114
|
+
roundedTipPen: 'Round',
|
115
|
+
flatTipPen: 'Flat',
|
116
|
+
arrowPen: 'Arrow',
|
117
|
+
linePen: 'Line',
|
118
|
+
outlinedRectanglePen: 'Outlined rectangle',
|
119
|
+
filledRectanglePen: 'Filled rectangle',
|
120
|
+
outlinedCirclePen: 'Outlined circle',
|
121
|
+
lockRotation: 'Lock rotation',
|
122
|
+
|
123
|
+
paste: 'Paste',
|
124
|
+
|
125
|
+
|
126
|
+
closeSidebar: (toolName: string) => `Close sidebar for ${toolName}`,
|
127
|
+
dropdownShown: (toolName) => `Menu for ${toolName} shown`,
|
128
|
+
dropdownHidden: (toolName) => `Menu for ${toolName} hidden`,
|
129
|
+
|
130
|
+
zoomLevel: (zoomPercent: number) => `Zoom: ${zoomPercent}%`,
|
131
|
+
colorChangedAnnouncement: (color: string) => `Color changed to ${color}`,
|
132
|
+
imageSize: (size: number, units: string) => `Image size: ${size} ${units}`,
|
133
|
+
|
134
|
+
errorImageHasZeroSize: 'Error: Image has zero size',
|
135
|
+
imageLoadError: (message: string)=> `Error loading image: ${message}`,
|
136
|
+
};
|
@@ -0,0 +1,13 @@
|
|
1
|
+
import IconProvider from './IconProvider';
|
2
|
+
import type { ToolbarLocalization } from './localization';
|
3
|
+
|
4
|
+
export interface ActionButtonIcon {
|
5
|
+
icon: Element;
|
6
|
+
label: string;
|
7
|
+
}
|
8
|
+
|
9
|
+
export interface ToolbarContext {
|
10
|
+
announceForAccessibility(text: string): void;
|
11
|
+
localization: ToolbarLocalization;
|
12
|
+
icons: IconProvider;
|
13
|
+
}
|
@@ -0,0 +1,39 @@
|
|
1
|
+
import Editor from '../../Editor';
|
2
|
+
import { ToolbarLocalization } from '../localization';
|
3
|
+
import BaseWidget from './BaseWidget';
|
4
|
+
|
5
|
+
export default class ActionButtonWidget extends BaseWidget {
|
6
|
+
public constructor(
|
7
|
+
editor: Editor,
|
8
|
+
id: string,
|
9
|
+
|
10
|
+
protected makeIcon: ()=> Element|null,
|
11
|
+
protected title: string,
|
12
|
+
protected clickAction: ()=>void,
|
13
|
+
|
14
|
+
localizationTable?: ToolbarLocalization,
|
15
|
+
protected mustBeToplevel: boolean = false,
|
16
|
+
) {
|
17
|
+
super(editor, id, localizationTable);
|
18
|
+
}
|
19
|
+
|
20
|
+
protected handleClick() {
|
21
|
+
this.clickAction();
|
22
|
+
}
|
23
|
+
|
24
|
+
protected getTitle(): string {
|
25
|
+
return this.title;
|
26
|
+
}
|
27
|
+
|
28
|
+
protected createIcon(): Element|null {
|
29
|
+
return this.makeIcon();
|
30
|
+
}
|
31
|
+
|
32
|
+
protected override fillDropdown(_dropdown: HTMLElement): boolean {
|
33
|
+
return false;
|
34
|
+
}
|
35
|
+
|
36
|
+
public override mustBeInToplevelMenu(): boolean {
|
37
|
+
return this.mustBeToplevel;
|
38
|
+
}
|
39
|
+
}
|
@@ -0,0 +1,81 @@
|
|
1
|
+
import Editor from '../../Editor';
|
2
|
+
import BaseTool from '../../tools/BaseTool';
|
3
|
+
import { EditorEventType } from '../../types';
|
4
|
+
import { KeyPressEvent } from '../../inputEvents';
|
5
|
+
import { ToolbarLocalization } from '../localization';
|
6
|
+
import BaseWidget from './BaseWidget';
|
7
|
+
import { toolbarCSSPrefix } from '../constants';
|
8
|
+
|
9
|
+
const isToolWidgetFocused = () => {
|
10
|
+
const currentFocus = [...document.querySelectorAll('*:focus')];
|
11
|
+
return currentFocus.length && currentFocus.some(elem => elem.classList.contains(`${toolbarCSSPrefix}button`));
|
12
|
+
};
|
13
|
+
|
14
|
+
export default abstract class BaseToolWidget extends BaseWidget {
|
15
|
+
public constructor(
|
16
|
+
editor: Editor,
|
17
|
+
protected targetTool: BaseTool,
|
18
|
+
id: string,
|
19
|
+
localizationTable?: ToolbarLocalization,
|
20
|
+
) {
|
21
|
+
super(editor, id, localizationTable);
|
22
|
+
|
23
|
+
editor.notifier.on(EditorEventType.ToolEnabled, toolEvt => {
|
24
|
+
if (toolEvt.kind !== EditorEventType.ToolEnabled) {
|
25
|
+
throw new Error('Incorrect event type! (Expected ToolEnabled)');
|
26
|
+
}
|
27
|
+
|
28
|
+
if (toolEvt.tool === targetTool) {
|
29
|
+
this.setSelected(true);
|
30
|
+
|
31
|
+
// Transfer focus to the current button, only if another toolbar button is
|
32
|
+
// focused.
|
33
|
+
// This prevents pressing "space" from triggering a different action when
|
34
|
+
// the current is selected.
|
35
|
+
if (isToolWidgetFocused()) {
|
36
|
+
this.focus();
|
37
|
+
}
|
38
|
+
}
|
39
|
+
});
|
40
|
+
|
41
|
+
editor.notifier.on(EditorEventType.ToolDisabled, toolEvt => {
|
42
|
+
if (toolEvt.kind !== EditorEventType.ToolDisabled) {
|
43
|
+
throw new Error('Incorrect event type! (Expected ToolDisabled)');
|
44
|
+
}
|
45
|
+
|
46
|
+
if (toolEvt.tool === targetTool) {
|
47
|
+
this.setSelected(false);
|
48
|
+
this.setDropdownVisible(false);
|
49
|
+
}
|
50
|
+
});
|
51
|
+
}
|
52
|
+
|
53
|
+
protected handleClick() {
|
54
|
+
if (this.hasDropdown) {
|
55
|
+
if (!this.targetTool.isEnabled()) {
|
56
|
+
this.targetTool.setEnabled(true);
|
57
|
+
this.activateDropdown();
|
58
|
+
} else {
|
59
|
+
this.setDropdownVisible(!this.isDropdownVisible());
|
60
|
+
}
|
61
|
+
} else {
|
62
|
+
this.targetTool.setEnabled(!this.targetTool.isEnabled());
|
63
|
+
}
|
64
|
+
}
|
65
|
+
|
66
|
+
protected override onKeyPress(event: KeyPressEvent): boolean {
|
67
|
+
if (this.isSelected() && event.key === ' ' && this.hasDropdown) {
|
68
|
+
this.handleClick();
|
69
|
+
return true;
|
70
|
+
}
|
71
|
+
|
72
|
+
return false;
|
73
|
+
}
|
74
|
+
|
75
|
+
public override addTo(parent: HTMLElement) {
|
76
|
+
const result = super.addTo(parent);
|
77
|
+
this.setSelected(this.targetTool.isEnabled());
|
78
|
+
|
79
|
+
return result;
|
80
|
+
}
|
81
|
+
}
|