@node-projects/web-component-designer 0.0.32 → 0.0.36

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 (210) hide show
  1. package/README.md +7 -0
  2. package/assets/images/chromeDevtools/LICENSE +27 -0
  3. package/assets/images/chromeDevtools/align-content-center-icon.svg +70 -0
  4. package/assets/images/chromeDevtools/align-content-flex-end-icon.svg +1 -0
  5. package/assets/images/chromeDevtools/align-content-flex-start-icon.svg +66 -0
  6. package/assets/images/chromeDevtools/align-content-space-around-icon.svg +1 -0
  7. package/assets/images/chromeDevtools/align-content-space-between-icon.svg +1 -0
  8. package/assets/images/chromeDevtools/align-content-space-evenly-icon.svg +1 -0
  9. package/assets/images/chromeDevtools/align-content-stretch-icon.svg +53 -0
  10. package/assets/images/chromeDevtools/align-items-baseline-icon.svg +1 -0
  11. package/assets/images/chromeDevtools/align-items-center-icon.svg +1 -0
  12. package/assets/images/chromeDevtools/align-items-end-icon.svg +1 -0
  13. package/assets/images/chromeDevtools/align-items-flex-end-icon.svg +1 -0
  14. package/assets/images/chromeDevtools/align-items-flex-start-icon.svg +57 -0
  15. package/assets/images/chromeDevtools/align-items-start-icon.svg +57 -0
  16. package/assets/images/chromeDevtools/align-items-stretch-icon.svg +1 -0
  17. package/assets/images/chromeDevtools/align-self-center-icon.svg +1 -0
  18. package/assets/images/chromeDevtools/align-self-flex-end-icon.svg +1 -0
  19. package/assets/images/chromeDevtools/align-self-flex-start-icon.svg +57 -0
  20. package/assets/images/chromeDevtools/align-self-stretch-icon.svg +1 -0
  21. package/assets/images/chromeDevtools/baseline-icon.svg +1 -0
  22. package/assets/images/chromeDevtools/flex-direction-column-icon.svg +1 -0
  23. package/assets/images/chromeDevtools/flex-direction-icon.svg +1 -0
  24. package/assets/images/chromeDevtools/flex-direction-row-icon.svg +1 -0
  25. package/assets/images/chromeDevtools/flex-nowrap-icon.svg +5 -0
  26. package/assets/images/chromeDevtools/flex-wrap-icon.svg +8 -0
  27. package/assets/images/chromeDevtools/info.txt +2 -0
  28. package/assets/images/chromeDevtools/justify-content-center-icon.svg +1 -0
  29. package/assets/images/chromeDevtools/justify-content-end-icon.svg +71 -0
  30. package/assets/images/chromeDevtools/justify-content-flex-end-icon.svg +71 -0
  31. package/assets/images/chromeDevtools/justify-content-flex-start-icon.svg +1 -0
  32. package/assets/images/chromeDevtools/justify-content-space-around-icon.svg +1 -0
  33. package/assets/images/chromeDevtools/justify-content-space-between-icon.svg +1 -0
  34. package/assets/images/chromeDevtools/justify-content-space-evenly-icon.svg +1 -0
  35. package/assets/images/chromeDevtools/justify-content-start-icon.svg +1 -0
  36. package/assets/images/chromeDevtools/justify-items-center-icon.svg +1 -0
  37. package/assets/images/chromeDevtools/justify-items-end-icon.svg +57 -0
  38. package/assets/images/chromeDevtools/justify-items-start-icon.svg +1 -0
  39. package/assets/images/chromeDevtools/justify-items-stretch-icon.svg +1 -0
  40. package/dist/commandHandling/CommandType.d.ts +1 -0
  41. package/dist/commandHandling/CommandType.js +1 -0
  42. package/dist/elements/controls/DesignerTabControl.js +94 -86
  43. package/dist/elements/controls/ImageButtonListSelector copy.d.ts +17 -0
  44. package/dist/elements/controls/ImageButtonListSelector copy.js +82 -0
  45. package/dist/elements/controls/ImageButtonListSelector.d.ts +17 -0
  46. package/dist/elements/controls/ImageButtonListSelector.js +81 -0
  47. package/dist/elements/controls/ThicknessEditor.d.ts +17 -0
  48. package/dist/elements/controls/ThicknessEditor.js +80 -0
  49. package/dist/elements/documentContainer.js +20 -13
  50. package/dist/elements/helper/CssAttributeParser.js +3 -3
  51. package/dist/elements/helper/CssCombiner.js +1 -1
  52. package/dist/elements/helper/IndentedTextWriter.js +3 -5
  53. package/dist/elements/helper/Screenshot.js +4 -0
  54. package/dist/elements/helper/contextMenu/ContextMenuHelper.js +59 -53
  55. package/dist/elements/helper/w3color.js +15 -17
  56. package/dist/elements/item/DesignItem.js +21 -15
  57. package/dist/elements/services/BaseServiceContainer.js +1 -3
  58. package/dist/elements/services/DefaultServiceBootstrap.js +2 -0
  59. package/dist/elements/services/GlobalContext.js +8 -6
  60. package/dist/elements/services/InstanceServiceContainer.js +1 -4
  61. package/dist/elements/services/ServiceContainer.d.ts +3 -0
  62. package/dist/elements/services/ServiceContainer.js +11 -10
  63. package/dist/elements/services/bindingsService/BaseCustomWebcomponentBindingsService.js +1 -1
  64. package/dist/elements/services/bindingsService/SpecialTagsBindingService.js +5 -5
  65. package/dist/elements/services/contentService/ContentService.js +2 -1
  66. package/dist/elements/services/copyPasteService/CopyPasteService.d.ts +8 -0
  67. package/dist/elements/services/copyPasteService/CopyPasteService.js +12 -0
  68. package/dist/elements/services/copyPasteService/ICopyPasteService copy.d.ts +0 -0
  69. package/dist/elements/services/copyPasteService/ICopyPasteService copy.js +1 -0
  70. package/dist/elements/services/copyPasteService/ICopyPasteService.d.ts +7 -0
  71. package/dist/elements/services/copyPasteService/ICopyPasteService.js +1 -0
  72. package/dist/elements/services/elementsService/JsonFileElementsService.js +14 -10
  73. package/dist/elements/services/elementsService/PreDefinedElementsService.js +6 -4
  74. package/dist/elements/services/htmlParserService/NodeHtmlParserService.js +2 -1
  75. package/dist/elements/services/htmlWriterService/IHtmlWriterOptions.js +3 -0
  76. package/dist/elements/services/placementService/DefaultPlacementService.d.ts +3 -4
  77. package/dist/elements/services/placementService/DefaultPlacementService.js +10 -10
  78. package/dist/elements/services/placementService/FlexBoxPlacementService.d.ts +3 -4
  79. package/dist/elements/services/placementService/FlexBoxPlacementService.js +3 -3
  80. package/dist/elements/services/placementService/GridPlacementService.d.ts +3 -4
  81. package/dist/elements/services/placementService/GridPlacementService.js +3 -3
  82. package/dist/elements/services/placementService/IPlacementService.d.ts +3 -4
  83. package/dist/elements/services/popupService/PopupService.js +3 -1
  84. package/dist/elements/services/propertiesService/DefaultEditorTypesService.js +10 -0
  85. package/dist/elements/services/propertiesService/propertyEditors/BasePropertyEditor.js +4 -1
  86. package/dist/elements/services/propertiesService/propertyEditors/ImageButtonListPropertyEditor copy.d.ts +8 -0
  87. package/dist/elements/services/propertiesService/propertyEditors/ImageButtonListPropertyEditor copy.js +40 -0
  88. package/dist/elements/services/propertiesService/propertyEditors/ImageButtonListPropertyEditor.d.ts +8 -0
  89. package/dist/elements/services/propertiesService/propertyEditors/ImageButtonListPropertyEditor.js +40 -0
  90. package/dist/elements/services/propertiesService/propertyEditors/JsonPropertyEditor.js +7 -6
  91. package/dist/elements/services/propertiesService/propertyEditors/JsonPropertyPopupEditor.js +6 -6
  92. package/dist/elements/services/propertiesService/propertyEditors/TextPropertyEditor.js +1 -2
  93. package/dist/elements/services/propertiesService/propertyEditors/ThicknessPropertyEditor.d.ts +8 -0
  94. package/dist/elements/services/propertiesService/propertyEditors/ThicknessPropertyEditor.js +14 -0
  95. package/dist/elements/services/propertiesService/services/AttributesPropertiesService.js +1 -3
  96. package/dist/elements/services/propertiesService/services/BaseCustomWebComponentPropertiesService.js +1 -4
  97. package/dist/elements/services/propertiesService/services/CommonPropertiesService.js +21 -23
  98. package/dist/elements/services/propertiesService/services/CssPropertiesService.d.ts +3 -2
  99. package/dist/elements/services/propertiesService/services/CssPropertiesService.js +194 -184
  100. package/dist/elements/services/propertiesService/services/ListPropertiesService.js +2 -2
  101. package/dist/elements/services/propertiesService/services/Lit2PropertiesService.js +1 -4
  102. package/dist/elements/services/propertiesService/services/LitElementPropertiesService.js +1 -4
  103. package/dist/elements/services/propertiesService/services/NativeElementsPropertiesService.js +72 -75
  104. package/dist/elements/services/propertiesService/services/PolymerPropertiesService.js +1 -4
  105. package/dist/elements/services/propertiesService/services/UnkownElementPropertiesService.js +1 -3
  106. package/dist/elements/services/selectionService/SelectionService.js +3 -4
  107. package/dist/elements/services/undoService/ChangeGroup.js +6 -2
  108. package/dist/elements/services/undoService/UndoService.js +3 -5
  109. package/dist/elements/services/undoService/transactionItems/AttributeChangeAction.js +5 -0
  110. package/dist/elements/services/undoService/transactionItems/CssStyleChangeAction.js +5 -0
  111. package/dist/elements/services/undoService/transactionItems/DeleteAction.js +5 -0
  112. package/dist/elements/services/undoService/transactionItems/InsertAction.js +4 -0
  113. package/dist/elements/services/undoService/transactionItems/MoveElementInDomAction.js +7 -0
  114. package/dist/elements/services/undoService/transactionItems/PropertyChangeAction.js +5 -0
  115. package/dist/elements/widgets/bindableObjectsBrowser/bindable-objects-browser.js +27 -24
  116. package/dist/elements/widgets/bindings/BindingsEditor.js +6 -6
  117. package/dist/elements/widgets/codeView/code-view-ace.js +12 -7
  118. package/dist/elements/widgets/codeView/code-view-code-mirror.js +18 -13
  119. package/dist/elements/widgets/codeView/code-view-monaco.js +16 -11
  120. package/dist/elements/widgets/demoView/demoView.js +24 -22
  121. package/dist/elements/widgets/designerView/DesignContext.js +1 -3
  122. package/dist/elements/widgets/designerView/IDesignerCanvas.d.ts +2 -2
  123. package/dist/elements/widgets/designerView/Snaplines.js +8 -5
  124. package/dist/elements/widgets/designerView/designerCanvas.d.ts +5 -4
  125. package/dist/elements/widgets/designerView/designerCanvas.js +131 -113
  126. package/dist/elements/widgets/designerView/designerView.d.ts +1 -0
  127. package/dist/elements/widgets/designerView/designerView.js +117 -81
  128. package/dist/elements/widgets/designerView/extensions/AbstractExtension.js +5 -1
  129. package/dist/elements/widgets/designerView/extensions/AltToEnterContainerExtension.js +2 -0
  130. package/dist/elements/widgets/designerView/extensions/AltToEnterContainerExtensionProvider.js +4 -6
  131. package/dist/elements/widgets/designerView/extensions/CanvasExtension copy.d.ts +10 -0
  132. package/dist/elements/widgets/designerView/extensions/CanvasExtension copy.js +29 -0
  133. package/dist/elements/widgets/designerView/extensions/CanvasExtensionProvider copy.d.ts +10 -0
  134. package/dist/elements/widgets/designerView/extensions/CanvasExtensionProvider copy.js +15 -0
  135. package/dist/elements/widgets/designerView/extensions/CanvasExtensionProvider.js +3 -5
  136. package/dist/elements/widgets/designerView/extensions/EditText/EditTextExtension.js +11 -8
  137. package/dist/elements/widgets/designerView/extensions/ExtensionManager.js +1 -0
  138. package/dist/elements/widgets/designerView/extensions/GrayOutExtension.js +1 -0
  139. package/dist/elements/widgets/designerView/extensions/GrayOutExtensionProvider.js +3 -5
  140. package/dist/elements/widgets/designerView/extensions/GridExtensionProvider.js +5 -7
  141. package/dist/elements/widgets/designerView/extensions/InvisibleDivExtension.js +1 -0
  142. package/dist/elements/widgets/designerView/extensions/InvisibleDivExtensionProvider.js +3 -5
  143. package/dist/elements/widgets/designerView/extensions/MouseOverExtension.js +1 -0
  144. package/dist/elements/widgets/designerView/extensions/MouseOverExtensionProvider.js +3 -5
  145. package/dist/elements/widgets/designerView/extensions/PathExtension.js +4 -0
  146. package/dist/elements/widgets/designerView/extensions/PermamentCursorExtension.d.ts +10 -0
  147. package/dist/elements/widgets/designerView/extensions/PermamentCursorExtension.js +29 -0
  148. package/dist/elements/widgets/designerView/extensions/PermamentCursorExtensionProvider copy.d.ts +10 -0
  149. package/dist/elements/widgets/designerView/extensions/PermamentCursorExtensionProvider copy.js +15 -0
  150. package/dist/elements/widgets/designerView/extensions/PermamentCursorExtensionProvider.d.ts +10 -0
  151. package/dist/elements/widgets/designerView/extensions/PermamentCursorExtensionProvider.js +15 -0
  152. package/dist/elements/widgets/designerView/extensions/PositionExtension.js +4 -0
  153. package/dist/elements/widgets/designerView/extensions/PrimarySelectionDefaultExtension.js +2 -0
  154. package/dist/elements/widgets/designerView/extensions/ResizeExtension.js +14 -4
  155. package/dist/elements/widgets/designerView/extensions/ResizeExtensionProvider.js +1 -0
  156. package/dist/elements/widgets/designerView/extensions/RotateExtensionProvider.js +3 -5
  157. package/dist/elements/widgets/designerView/extensions/SelectionDefaultExtension.js +1 -0
  158. package/dist/elements/widgets/designerView/extensions/SelectionDefaultExtensionProvider.js +3 -5
  159. package/dist/elements/widgets/designerView/extensions/TransformOriginExtension.js +3 -0
  160. package/dist/elements/widgets/designerView/extensions/TransformOriginExtensionProvider.js +3 -5
  161. package/dist/elements/widgets/designerView/extensions/contextMenu/MultipleItemsSelectedContextMenu.js +1 -3
  162. package/dist/elements/widgets/designerView/extensions/pointerExtensions/AbstractDesignerPointerExtension.d.ts +22 -0
  163. package/dist/elements/widgets/designerView/extensions/pointerExtensions/AbstractDesignerPointerExtension.js +82 -0
  164. package/dist/elements/widgets/designerView/extensions/pointerExtensions/AbstractExtension.d.ts +22 -0
  165. package/dist/elements/widgets/designerView/extensions/pointerExtensions/AbstractExtension.js +78 -0
  166. package/dist/elements/widgets/designerView/extensions/pointerExtensions/CursorRectangleExtension.d.ts +7 -0
  167. package/dist/elements/widgets/designerView/extensions/pointerExtensions/CursorRectangleExtension.js +20 -0
  168. package/dist/elements/widgets/designerView/extensions/pointerExtensions/CursorRectanglePointerExtension copy.d.ts +7 -0
  169. package/dist/elements/widgets/designerView/extensions/pointerExtensions/CursorRectanglePointerExtension copy.js +20 -0
  170. package/dist/elements/widgets/designerView/extensions/pointerExtensions/CursorRectanglePointerExtension.d.ts +7 -0
  171. package/dist/elements/widgets/designerView/extensions/pointerExtensions/CursorRectanglePointerExtension.js +20 -0
  172. package/dist/elements/widgets/designerView/extensions/pointerExtensions/IDesignerExtension.d.ts +5 -0
  173. package/dist/elements/widgets/designerView/extensions/pointerExtensions/IDesignerExtension.js +1 -0
  174. package/dist/elements/widgets/designerView/extensions/pointerExtensions/IDesignerExtensionProvider.d.ts +9 -0
  175. package/dist/elements/widgets/designerView/extensions/pointerExtensions/IDesignerExtensionProvider.js +1 -0
  176. package/dist/elements/widgets/designerView/extensions/pointerExtensions/IDesignerPointerExtension.d.ts +5 -0
  177. package/dist/elements/widgets/designerView/extensions/pointerExtensions/IDesignerPointerExtension.js +1 -0
  178. package/dist/elements/widgets/designerView/extensions/pointerExtensions/IDesignerPointerExtensionProvider.d.ts +9 -0
  179. package/dist/elements/widgets/designerView/extensions/pointerExtensions/IDesignerPointerExtensionProvider.js +1 -0
  180. package/dist/elements/widgets/designerView/extensions/pointerExtensions/RulerExtension.d.ts +7 -0
  181. package/dist/elements/widgets/designerView/extensions/pointerExtensions/RulerExtension.js +20 -0
  182. package/dist/elements/widgets/designerView/extensions/pointerExtensions/RulerPointerExtension.d.ts +7 -0
  183. package/dist/elements/widgets/designerView/extensions/pointerExtensions/RulerPointerExtension.js +20 -0
  184. package/dist/elements/widgets/designerView/overlay/EditTextOverlay.js +3 -3
  185. package/dist/elements/widgets/designerView/overlayLayerView.js +28 -24
  186. package/dist/elements/widgets/designerView/tools/DrawElementTool.js +5 -1
  187. package/dist/elements/widgets/designerView/tools/DrawPathTool.d.ts +0 -1
  188. package/dist/elements/widgets/designerView/tools/DrawPathTool.js +4 -3
  189. package/dist/elements/widgets/designerView/tools/MagicWandSelectorTool.d.ts +0 -1
  190. package/dist/elements/widgets/designerView/tools/MagicWandSelectorTool.js +4 -5
  191. package/dist/elements/widgets/designerView/tools/PanTool.js +1 -3
  192. package/dist/elements/widgets/designerView/tools/PickColorTool.js +1 -3
  193. package/dist/elements/widgets/designerView/tools/PointerTool.d.ts +2 -1
  194. package/dist/elements/widgets/designerView/tools/PointerTool.js +75 -63
  195. package/dist/elements/widgets/designerView/tools/RectangleSelectorTool.js +10 -9
  196. package/dist/elements/widgets/designerView/tools/TextTool.js +1 -1
  197. package/dist/elements/widgets/designerView/tools/ZoomTool.js +1 -3
  198. package/dist/elements/widgets/miniatureView/html-2-canvas-miniature-view.js +5 -4
  199. package/dist/elements/widgets/paletteView/paletteElements.js +45 -45
  200. package/dist/elements/widgets/paletteView/paletteTreeView.js +53 -51
  201. package/dist/elements/widgets/paletteView/paletteView.js +9 -8
  202. package/dist/elements/widgets/propertyGrid/PropertyGrid.js +37 -18
  203. package/dist/elements/widgets/propertyGrid/PropertyGridPropertyList.js +14 -10
  204. package/dist/elements/widgets/treeView/treeView.js +102 -96
  205. package/dist/elements/widgets/treeView/treeViewExtended.js +72 -70
  206. package/dist/index.d.ts +2 -1
  207. package/dist/index.js +1 -0
  208. package/dist/interfaces/IDesignerMousePoint.d.ts +2 -0
  209. package/package.json +1 -1
  210. package/tsconfig.json +1 -1
@@ -0,0 +1,78 @@
1
+ export class AbstractExtension {
2
+ overlays = [];
3
+ overlayLayerView;
4
+ extensionManager;
5
+ designerView;
6
+ extendedItem;
7
+ constructor(extensionManager, designerView, extendedItem) {
8
+ this.extensionManager = extensionManager;
9
+ this.designerView = designerView;
10
+ this.extendedItem = extendedItem;
11
+ this.overlayLayerView = designerView.overlayLayer;
12
+ }
13
+ _removeAllOverlays() {
14
+ for (let o of this.overlays) {
15
+ try {
16
+ this.overlayLayerView.removeOverlay(o);
17
+ }
18
+ catch (err) {
19
+ console.error(err);
20
+ }
21
+ }
22
+ this.overlays = [];
23
+ }
24
+ _drawLineOverlay(x1, y1, x2, y2, className, line, overlayLayer) {
25
+ if (!line) {
26
+ line = document.createElementNS("http://www.w3.org/2000/svg", "line");
27
+ this.overlayLayerView.addOverlay(line, overlayLayer);
28
+ this.overlays.push(line);
29
+ }
30
+ line.setAttribute('x1', x1);
31
+ line.setAttribute('y1', y1);
32
+ line.setAttribute('x2', x2);
33
+ line.setAttribute('y2', y2);
34
+ if (className)
35
+ line.setAttribute('class', className);
36
+ return line;
37
+ }
38
+ _drawCircleOverlay(x, y, radius, className, circle, overlayLayer) {
39
+ if (!circle) {
40
+ circle = document.createElementNS("http://www.w3.org/2000/svg", "circle");
41
+ this.overlayLayerView.addOverlay(circle, overlayLayer);
42
+ this.overlays.push(circle);
43
+ }
44
+ circle.setAttribute('cx', x);
45
+ circle.setAttribute('cy', y);
46
+ circle.setAttribute('r', radius);
47
+ if (className)
48
+ circle.setAttribute('class', className);
49
+ return circle;
50
+ }
51
+ _drawRect(x, y, w, h, className, rect, overlayLayer) {
52
+ if (!rect) {
53
+ rect = document.createElementNS("http://www.w3.org/2000/svg", "rect");
54
+ this.overlayLayerView.addOverlay(rect, overlayLayer);
55
+ this.overlays.push(rect);
56
+ }
57
+ rect.setAttribute('x', x);
58
+ rect.setAttribute('y', y);
59
+ rect.setAttribute('width', w);
60
+ rect.setAttribute('height', h);
61
+ if (className)
62
+ rect.setAttribute('class', className);
63
+ return rect;
64
+ }
65
+ _drawText(text, x, y, className, textEl, overlayLayer) {
66
+ if (!textEl) {
67
+ textEl = document.createElementNS("http://www.w3.org/2000/svg", "text");
68
+ this.overlayLayerView.addOverlay(textEl, overlayLayer);
69
+ this.overlays.push(textEl);
70
+ }
71
+ textEl.setAttribute('x', x);
72
+ textEl.setAttribute('y', y);
73
+ textEl.textContent = text;
74
+ if (className)
75
+ textEl.setAttribute('class', className);
76
+ return textEl;
77
+ }
78
+ }
@@ -0,0 +1,7 @@
1
+ import { AbstractDesignerPointerExtension } from './AbstractDesignerPointerExtension';
2
+ export declare class CursorRectangleExtension extends AbstractDesignerPointerExtension {
3
+ private _rect;
4
+ extend(event: PointerEvent): void;
5
+ refresh(event: PointerEvent): void;
6
+ dispose(): void;
7
+ }
@@ -0,0 +1,20 @@
1
+ import { OverlayLayer } from '../OverlayLayer.js';
2
+ import { AbstractDesignerPointerExtension } from './AbstractDesignerPointerExtension';
3
+ export class CursorRectangleExtension extends AbstractDesignerPointerExtension {
4
+ _rect;
5
+ extend(event) {
6
+ this._rect = document.createElementNS("http://www.w3.org/2000/svg", "rect");
7
+ this.overlayLayerView.addOverlay(this._rect, OverlayLayer.Foregorund);
8
+ }
9
+ refresh(event) {
10
+ let mp = this.designerView.getNormalizedEventCoordinates(event);
11
+ this._rect.setAttribute('class', 'svg-selector');
12
+ this._rect.setAttribute('x', (mp.x - 5));
13
+ this._rect.setAttribute('y', (mp.y - 5));
14
+ this._rect.setAttribute('width', (10));
15
+ this._rect.setAttribute('height', (10));
16
+ }
17
+ dispose() {
18
+ super._removeAllOverlays();
19
+ }
20
+ }
@@ -0,0 +1,7 @@
1
+ import { AbstractDesignerPointerExtension } from './AbstractDesignerPointerExtension';
2
+ export declare class CursorRectanglePointerExtension extends AbstractDesignerPointerExtension {
3
+ private _rect;
4
+ extend(event: PointerEvent): void;
5
+ refresh(event: PointerEvent): void;
6
+ dispose(): void;
7
+ }
@@ -0,0 +1,20 @@
1
+ import { OverlayLayer } from '../OverlayLayer.js';
2
+ import { AbstractDesignerPointerExtension } from './AbstractDesignerPointerExtension';
3
+ export class CursorRectanglePointerExtension extends AbstractDesignerPointerExtension {
4
+ _rect;
5
+ extend(event) {
6
+ this._rect = document.createElementNS("http://www.w3.org/2000/svg", "rect");
7
+ this.overlayLayerView.addOverlay(this._rect, OverlayLayer.Foregorund);
8
+ }
9
+ refresh(event) {
10
+ let mp = this.designerView.getNormalizedEventCoordinates(event);
11
+ this._rect.setAttribute('class', 'svg-selector');
12
+ this._rect.setAttribute('x', (mp.x - 5));
13
+ this._rect.setAttribute('y', (mp.y - 5));
14
+ this._rect.setAttribute('width', (10));
15
+ this._rect.setAttribute('height', (10));
16
+ }
17
+ dispose() {
18
+ super._removeAllOverlays();
19
+ }
20
+ }
@@ -0,0 +1,7 @@
1
+ import { AbstractDesignerPointerExtension } from './AbstractDesignerPointerExtension';
2
+ export declare class CursorRectanglePointerExtension extends AbstractDesignerPointerExtension {
3
+ private _rect;
4
+ extend(event: PointerEvent): void;
5
+ refresh(event: PointerEvent): void;
6
+ dispose(): void;
7
+ }
@@ -0,0 +1,20 @@
1
+ import { OverlayLayer } from '../OverlayLayer.js';
2
+ import { AbstractDesignerPointerExtension } from './AbstractDesignerPointerExtension';
3
+ export class CursorRectanglePointerExtension extends AbstractDesignerPointerExtension {
4
+ _rect;
5
+ extend(event) {
6
+ this._rect = document.createElementNS("http://www.w3.org/2000/svg", "rect");
7
+ this.overlayLayerView.addOverlay(this._rect, OverlayLayer.Foregorund);
8
+ }
9
+ refresh(event) {
10
+ let mp = this.designerView.getNormalizedEventCoordinates(event);
11
+ this._rect.setAttribute('class', 'svg-selector');
12
+ this._rect.setAttribute('x', (mp.x - 5));
13
+ this._rect.setAttribute('y', (mp.y - 5));
14
+ this._rect.setAttribute('width', (10));
15
+ this._rect.setAttribute('height', (10));
16
+ }
17
+ dispose() {
18
+ super._removeAllOverlays();
19
+ }
20
+ }
@@ -0,0 +1,5 @@
1
+ import { IDisposable } from "../../../../interfaces/IDisposable";
2
+ export interface IDesignerPointerExtension extends IDisposable {
3
+ extend(event: PointerEvent): any;
4
+ refresh(event: PointerEvent): any;
5
+ }
@@ -0,0 +1,9 @@
1
+ import { IDesignItem } from "../../../item/IDesignItem";
2
+ import { IDesignerCanvas } from "../IDesignerCanvas";
3
+ import { IDesignerExtension } from "./IDesignerExtension";
4
+ import { IExtensionManager } from "./IExtensionManger";
5
+ export interface IDesignerExtensionProvider {
6
+ shouldExtend(extensionManager: IExtensionManager, designerView: IDesignerCanvas, designItem: IDesignItem): boolean;
7
+ getExtension(extensionManager: IExtensionManager, designerView: IDesignerCanvas, designItem: IDesignItem): IDesignerExtension;
8
+ style?: CSSStyleSheet;
9
+ }
@@ -0,0 +1,5 @@
1
+ import { IDisposable } from "../../../../../interfaces/IDisposable.js";
2
+ export interface IDesignerPointerExtension extends IDisposable {
3
+ extend(event: PointerEvent): any;
4
+ refresh(event: PointerEvent): any;
5
+ }
@@ -0,0 +1,9 @@
1
+ import { IDesignItem } from "../../../../item/IDesignItem.js";
2
+ import { IDesignerCanvas } from "../../IDesignerCanvas.js";
3
+ import { IExtensionManager } from "../IExtensionManger.js";
4
+ import { IDesignerPointerExtension } from "./IDesignerPointerExtension.js";
5
+ export interface IDesignerPointerExtensionProvider {
6
+ shouldExtend(extensionManager: IExtensionManager, designerView: IDesignerCanvas, designItem: IDesignItem): boolean;
7
+ getExtension(extensionManager: IExtensionManager, designerView: IDesignerCanvas, designItem: IDesignItem): IDesignerPointerExtension;
8
+ style?: CSSStyleSheet;
9
+ }
@@ -0,0 +1,7 @@
1
+ import { AbstractDesignerPointerExtension } from './AbstractDesignerPointerExtension';
2
+ export declare class CursorRectanglePointerExtension extends AbstractDesignerPointerExtension {
3
+ private _rect;
4
+ extend(event: PointerEvent): void;
5
+ refresh(event: PointerEvent): void;
6
+ dispose(): void;
7
+ }
@@ -0,0 +1,20 @@
1
+ import { OverlayLayer } from '../OverlayLayer.js';
2
+ import { AbstractDesignerPointerExtension } from './AbstractDesignerPointerExtension';
3
+ export class CursorRectanglePointerExtension extends AbstractDesignerPointerExtension {
4
+ _rect;
5
+ extend(event) {
6
+ this._rect = document.createElementNS("http://www.w3.org/2000/svg", "rect");
7
+ this.overlayLayerView.addOverlay(this._rect, OverlayLayer.Foregorund);
8
+ }
9
+ refresh(event) {
10
+ let mp = this.designerView.getNormalizedEventCoordinates(event);
11
+ this._rect.setAttribute('class', 'svg-selector');
12
+ this._rect.setAttribute('x', (mp.x - 5));
13
+ this._rect.setAttribute('y', (mp.y - 5));
14
+ this._rect.setAttribute('width', (10));
15
+ this._rect.setAttribute('height', (10));
16
+ }
17
+ dispose() {
18
+ super._removeAllOverlays();
19
+ }
20
+ }
@@ -0,0 +1,7 @@
1
+ import { AbstractDesignerPointerExtension } from './AbstractDesignerPointerExtension';
2
+ export declare class RulerPointerExtension extends AbstractDesignerPointerExtension {
3
+ private _rect;
4
+ extend(event: PointerEvent): void;
5
+ refresh(event: PointerEvent): void;
6
+ dispose(): void;
7
+ }
@@ -0,0 +1,20 @@
1
+ import { OverlayLayer } from '../OverlayLayer.js';
2
+ import { AbstractDesignerPointerExtension } from './AbstractDesignerPointerExtension';
3
+ export class RulerPointerExtension extends AbstractDesignerPointerExtension {
4
+ _rect;
5
+ extend(event) {
6
+ this._rect = document.createElementNS("http://www.w3.org/2000/svg", "rect");
7
+ this.overlayLayerView.addOverlay(this._rect, OverlayLayer.Foregorund);
8
+ }
9
+ refresh(event) {
10
+ let mp = this.designerView.getNormalizedEventCoordinates(event);
11
+ this._rect.setAttribute('class', 'svg-selector');
12
+ this._rect.setAttribute('x', (mp.x - 5));
13
+ this._rect.setAttribute('y', (mp.y - 5));
14
+ this._rect.setAttribute('width', (10));
15
+ this._rect.setAttribute('height', (10));
16
+ }
17
+ dispose() {
18
+ super._removeAllOverlays();
19
+ }
20
+ }
@@ -1,9 +1,9 @@
1
1
  import { BaseCustomWebComponentConstructorAppend, css, html } from '@node-projects/base-custom-webcomponent';
2
2
  export class EditTextOverlay extends BaseCustomWebComponentConstructorAppend {
3
- }
4
- EditTextOverlay.style = css ``;
5
- EditTextOverlay.template = html `
3
+ static style = css ``;
4
+ static template = html `
6
5
  <div>
7
6
  <input type="text">
8
7
  </div>
9
8
  `;
9
+ }
@@ -1,6 +1,34 @@
1
1
  import { css, html, BaseCustomWebComponentConstructorAppend } from '@node-projects/base-custom-webcomponent';
2
2
  import { OverlayLayer } from './extensions/OverlayLayer.js';
3
3
  export class OverlayLayerView extends BaseCustomWebComponentConstructorAppend {
4
+ static template = html `
5
+ <svg id="svg" style="pointer-events: none;">
6
+ <g id="background"></g>
7
+ <g id="normal"></g>
8
+ <g id="foreground"></g>
9
+ </svg>`;
10
+ static style = css `
11
+ svg {
12
+ width: 100%;
13
+ height: 100%;
14
+ overflow: visible;
15
+ }
16
+
17
+ .svg-snapline { stroke: purple; stroke-dasharray: 4; fill: transparent; }
18
+ .svg-selector { stroke: black; fill: #3899ec55; stroke-width: 1; stroke-dasharray: 2; }
19
+ .svg-primary-selection-move { stroke: #3899ec; fill: #3899ec; cursor: move; pointer-events: all }
20
+ .svg-text { stroke: none; fill: white; stroke-width: 1; font-size: 10px; font-family: monospace; }
21
+ .svg-primary-resizer { stroke: #3899ec; fill: white; pointer-events: all }
22
+ .svg-position { stroke: black; stroke-dasharray: 2; }
23
+ .svg-path { stroke: #3899ec; fill: orange; pointer-events: all }
24
+ .svg-path-line { stroke: #3899ec; stroke-dasharray: 2; }
25
+ .svg-draw-new-element { stroke: black; fill: transparent; stroke-width: 1; }`;
26
+ static is = 'node-projects-overlay-layer-view';
27
+ _serviceContainer;
28
+ _svg;
29
+ _gBackground;
30
+ _gNormal;
31
+ _gForeground;
4
32
  constructor(serviceContainer) {
5
33
  super();
6
34
  this._serviceContainer = serviceContainer;
@@ -52,28 +80,4 @@ export class OverlayLayerView extends BaseCustomWebComponentConstructorAppend {
52
80
  return this.shadowRoot.elementFromPoint(x, y);
53
81
  }
54
82
  }
55
- OverlayLayerView.template = html `
56
- <svg id="svg" style="pointer-events: none;">
57
- <g id="background"></g>
58
- <g id="normal"></g>
59
- <g id="foreground"></g>
60
- </svg>`;
61
- OverlayLayerView.style = css `
62
- svg {
63
- width: 100%;
64
- height: 100%;
65
- overflow: visible;
66
- }
67
-
68
- .svg-snapline { stroke: purple; stroke-dasharray: 4; fill: transparent; }
69
- /*.svg-selection { stroke: #3899ec; fill: transparent; stroke-width: 2; }*/
70
- .svg-selector { stroke: black; fill: transparent; stroke-width: 1; stroke-dasharray: 2; }
71
- .svg-primary-selection-move { stroke: #3899ec; fill: #3899ec; cursor: move; pointer-events: all }
72
- .svg-text { stroke: none; fill: white; stroke-width: 1; font-size: 10px; font-family: monospace; }
73
- .svg-primary-resizer { stroke: #3899ec; fill: white; pointer-events: all }
74
- .svg-position { stroke: black; stroke-dasharray: 2; }
75
- .svg-path { stroke: #3899ec; fill: orange; pointer-events: all }
76
- .svg-path-line { stroke: #3899ec; stroke-dasharray: 2; }
77
- .svg-draw-new-element { stroke: black; fill: transparent; stroke-width: 1; }`;
78
- OverlayLayerView.is = 'node-projects-overlay-layer-view';
79
83
  customElements.define(OverlayLayerView.is, OverlayLayerView);
@@ -2,8 +2,12 @@ import { EventNames } from '../../../../enums/EventNames';
2
2
  import { InsertAction } from '../../../services/undoService/transactionItems/InsertAction';
3
3
  import { OverlayLayer } from '../extensions/OverlayLayer.js';
4
4
  export class DrawElementTool {
5
+ _elementDefinition;
6
+ _createdItem;
7
+ _startPosition;
8
+ cursor = 'crosshair';
9
+ _rect;
5
10
  constructor(elementDefinition) {
6
- this.cursor = 'crosshair';
7
11
  this._elementDefinition = elementDefinition;
8
12
  }
9
13
  activated(serviceContainer) {
@@ -5,7 +5,6 @@ export declare class DrawPathTool implements ITool {
5
5
  readonly cursor = "crosshair";
6
6
  private _pathD;
7
7
  private _path;
8
- private _initialPoint;
9
8
  constructor();
10
9
  activated(serviceContainer: ServiceContainer): void;
11
10
  dispose(): void;
@@ -4,20 +4,21 @@ import { InsertAction } from '../../../services/undoService/transactionItems/Ins
4
4
  import { DesignItem } from '../../../item/DesignItem';
5
5
  import { OverlayLayer } from '../extensions/OverlayLayer.js';
6
6
  export class DrawPathTool {
7
+ cursor = 'crosshair';
8
+ _pathD;
9
+ _path;
7
10
  constructor() {
8
- this.cursor = 'crosshair';
9
11
  }
10
12
  activated(serviceContainer) {
11
13
  }
12
14
  dispose() {
13
15
  }
14
16
  pointerEventHandler(designerCanvas, event, currentElement) {
15
- const currentPoint = designerCanvas.getDesignerMousepoint(event, currentElement, event.type === 'pointerdown' ? null : this._initialPoint);
17
+ const currentPoint = designerCanvas.getNormalizedEventCoordinates(event);
16
18
  const offset = 50;
17
19
  switch (event.type) {
18
20
  case EventNames.PointerDown:
19
21
  event.target.setPointerCapture(event.pointerId);
20
- this._initialPoint = currentPoint;
21
22
  this._path = document.createElementNS("http://www.w3.org/2000/svg", "path");
22
23
  this._pathD = "M" + currentPoint.x + " " + currentPoint.y;
23
24
  this._path.setAttribute("D", this._pathD);
@@ -5,7 +5,6 @@ export declare class MagicWandSelectorTool implements ITool {
5
5
  cursor: string;
6
6
  private _pathD;
7
7
  private _path;
8
- private _initialPoint;
9
8
  pointerEventHandler(designerCanvas: IDesignerCanvas, event: PointerEvent, currentElement: Element): void;
10
9
  activated(serviceContainer: ServiceContainer): void;
11
10
  dispose(): void;
@@ -2,15 +2,14 @@ import { EventNames } from '../../../../enums/EventNames';
2
2
  import { DesignItem } from '../../../item/DesignItem';
3
3
  import { OverlayLayer } from '../extensions/OverlayLayer.js';
4
4
  export class MagicWandSelectorTool {
5
- constructor() {
6
- this.cursor = 'progress';
7
- }
5
+ cursor = 'progress';
6
+ _pathD;
7
+ _path;
8
8
  pointerEventHandler(designerCanvas, event, currentElement) {
9
- const currentPoint = designerCanvas.getDesignerMousepoint(event, currentElement, event.type === 'pointerdown' ? null : this._initialPoint);
9
+ const currentPoint = designerCanvas.getNormalizedEventCoordinates(event);
10
10
  switch (event.type) {
11
11
  case EventNames.PointerDown:
12
12
  event.target.setPointerCapture(event.pointerId);
13
- this._initialPoint = currentPoint;
14
13
  this._path = document.createElementNS("http://www.w3.org/2000/svg", "path");
15
14
  this._path.setAttribute('class', 'svg-selector');
16
15
  this._pathD = "M" + currentPoint.x + " " + currentPoint.y;
@@ -1,7 +1,5 @@
1
1
  export class PanTool {
2
- constructor() {
3
- this.cursor = 'grab';
4
- }
2
+ cursor = 'grab';
5
3
  pointerEventHandler(designerCanvas, event, currentElement) {
6
4
  }
7
5
  activated(serviceContainer) {
@@ -1,7 +1,5 @@
1
1
  export class PickColorTool {
2
- constructor() {
3
- this.cursor = 'crosshair';
4
- }
2
+ cursor = 'crosshair';
5
3
  async activated(serviceContainer) {
6
4
  try {
7
5
  //@ts-ignore
@@ -12,10 +12,11 @@ export declare class PointerTool implements ITool {
12
12
  private _dragOverExtensionItem;
13
13
  private _dragExtensionItem;
14
14
  private _moveItemsOffset;
15
+ private _initialOffset;
15
16
  constructor();
16
17
  activated(serviceContainer: ServiceContainer): void;
17
18
  dispose(): void;
18
- pointerEventHandler(designerView: IDesignerCanvas, event: PointerEvent, currentElement: Element): void;
19
+ pointerEventHandler(designerCanvas: IDesignerCanvas, event: PointerEvent, currentElement: Element): void;
19
20
  private _pointerActionTypeDrawSelection;
20
21
  private _resetPointerEventsForClickThrough;
21
22
  private _pointerActionTypeDragOrSelect;