@node-projects/web-component-designer 0.1.155 → 0.1.157

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.
@@ -163,8 +163,8 @@ export function createDefaultServiceContainer() {
163
163
  ]);
164
164
  serviceContainer.designerExtensions.set(ExtensionType.MouseOver, [
165
165
  new HighlightElementExtensionProvider(),
166
- new ElementDragTitleExtensionProvider(),
167
- new PreviousElementSelectExtensionProvider()
166
+ new ConditionExtensionProvider(new ElementDragTitleExtensionProvider(), item => item.instanceServiceContainer.selectionService.primarySelection !== item && !(item.node instanceof SVGElement) || item.node instanceof SVGSVGElement),
167
+ new ConditionExtensionProvider(new PreviousElementSelectExtensionProvider(), item => item.instanceServiceContainer.selectionService.primarySelection !== item && !(item.node instanceof SVGElement) || item.node instanceof SVGSVGElement),
168
168
  ]);
169
169
  serviceContainer.designerExtensions.set(ExtensionType.Placement, [
170
170
  new PlacementExtensionProvider()
@@ -2,5 +2,5 @@ import { IElementAtPointService } from './IElementAtPointService.js';
2
2
  import { IPoint } from '../../../interfaces/IPoint.js';
3
3
  import { IDesignerCanvas } from '../../widgets/designerView/IDesignerCanvas.js';
4
4
  export declare class ElementAtPointService implements IElementAtPointService {
5
- getElementAtPoint(designerView: IDesignerCanvas, point: IPoint): any;
5
+ getElementAtPoint(designerCanvas: IDesignerCanvas, point: IPoint): any;
6
6
  }
@@ -1,5 +1,5 @@
1
1
  export class ElementAtPointService {
2
- getElementAtPoint(designerView, point) {
3
- return designerView.getElementAtPoint(point);
2
+ getElementAtPoint(designerCanvas, point) {
3
+ return designerCanvas.getElementAtPoint(point);
4
4
  }
5
5
  }
@@ -4,6 +4,7 @@ import { AbstractExtension } from './AbstractExtension.js';
4
4
  import { IExtensionManager } from './IExtensionManger.js';
5
5
  export declare class ElementDragTitleExtension extends AbstractExtension {
6
6
  private _rect;
7
+ private _clickRect;
7
8
  private _text;
8
9
  private _width;
9
10
  constructor(extensionManager: IExtensionManager, designerView: IDesignerCanvas, extendedItem: IDesignItem);
@@ -5,6 +5,7 @@ import { AbstractExtension } from './AbstractExtension.js';
5
5
  const extensionWidth = 60;
6
6
  export class ElementDragTitleExtension extends AbstractExtension {
7
7
  _rect;
8
+ _clickRect;
8
9
  _text;
9
10
  _width;
10
11
  constructor(extensionManager, designerView, extendedItem) {
@@ -20,12 +21,14 @@ export class ElementDragTitleExtension extends AbstractExtension {
20
21
  if (this.extendedItem.id)
21
22
  text = '#' + this.extendedItem.id;
22
23
  this._width = Math.max(Math.min(elementWidth, w), extensionWidth);
23
- this._rect = this._drawRect(transformedCornerPoints[0].x, transformedCornerPoints[0].y - 16, this._width, 15, 'svg-primary-selection-move', this._rect);
24
+ this._rect = this._drawRect(transformedCornerPoints[0].x, transformedCornerPoints[0].y, this._width, 15, 'svg-primary-selection-move', this._rect);
25
+ this._clickRect = this._drawRect(transformedCornerPoints[0].x, transformedCornerPoints[0].y, this._width, 18, 'svg-invisible', this._clickRect);
26
+ this._clickRect.style.background = 'transparent';
24
27
  this._text = this._drawHTML('<div style="position:relative"><span style="width: 100%; position: absolute; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; transform-origin: 0 0; padding-left: 2px;">' + text + '</span></div>', (boundRect.x - this.designerCanvas.containerBoundingRect.x) / this.designerCanvas.scaleFactor, transformedCornerPoints[0].y - 16, this._width, 15, 'svg-text-primary', this._text);
25
28
  this._text.style.overflow = 'visible';
26
- this._rect.addEventListener('pointerdown', (e) => this._pointerEvent(e));
27
- this._rect.addEventListener('pointermove', (e) => this._pointerEvent(e));
28
- this._rect.addEventListener('pointerup', (e) => this._pointerEvent(e));
29
+ this._clickRect.addEventListener('pointerdown', (e) => this._pointerEvent(e));
30
+ this._clickRect.addEventListener('pointermove', (e) => this._pointerEvent(e));
31
+ this._clickRect.addEventListener('pointerup', (e) => this._pointerEvent(e));
29
32
  this.refresh(cache, event);
30
33
  }
31
34
  }
@@ -45,6 +48,13 @@ export class ElementDragTitleExtension extends AbstractExtension {
45
48
  this._rect.setAttribute('height', '' + h);
46
49
  this._rect.setAttribute('width', '' + w);
47
50
  this._rect.style.strokeWidth = (1 / this.designerCanvas.scaleFactor).toString();
51
+ this._clickRect.setAttribute('x', '' + transformedCornerPoints[0].x);
52
+ this._clickRect.setAttribute('y', '' + transformedCornerPoints[0].y);
53
+ this._clickRect.style.rotate = angle + 'deg';
54
+ this._clickRect.style.transformBox = 'fill-box';
55
+ this._clickRect.setAttribute('height', '' + (h + 3));
56
+ this._clickRect.setAttribute('width', '' + w);
57
+ this._clickRect.style.strokeWidth = (1 / this.designerCanvas.scaleFactor).toString();
48
58
  this._text.setAttribute('x', '' + transformedCornerPoints[0].x);
49
59
  this._text.setAttribute('y', '' + transformedCornerPoints[0].y);
50
60
  this._text.style.fontSize = (10 / this.designerCanvas.scaleFactor) + 'px';
@@ -1,4 +1,3 @@
1
- import { DesignItem } from '../../../item/DesignItem.js';
2
1
  import { IDesignItem } from '../../../item/IDesignItem.js';
3
2
  import { IDesignerCanvas } from '../IDesignerCanvas.js';
4
3
  import { ExtensionType } from './ExtensionType.js';
@@ -9,9 +8,9 @@ export declare class ExtensionManager implements IExtensionManager {
9
8
  designerCanvas: IDesignerCanvas;
10
9
  designItemsWithExtentions: Set<IDesignItem>;
11
10
  _timeout: ReturnType<typeof setTimeout>;
12
- _appliedDesignerExtensions: WeakMap<DesignItem, Map<ExtensionType, IDesignerExtension[]>>;
13
- _shouldAppliedDesignerExtensions: WeakMap<DesignItem, Map<ExtensionType, IDesignerExtensionProvider[]>>;
14
- _lastApplyEventPerType: WeakMap<DesignItem, Map<ExtensionType, Event>>;
11
+ _appliedDesignerExtensions: WeakMap<IDesignItem, Map<ExtensionType, IDesignerExtension[]>>;
12
+ _shouldAppliedDesignerExtensions: WeakMap<IDesignItem, Map<ExtensionType, IDesignerExtensionProvider[]>>;
13
+ _lastApplyEventPerType: WeakMap<IDesignItem, Map<ExtensionType, Event>>;
15
14
  _lastPrimarySelectionRefreshItem: WeakRef<IDesignItem>;
16
15
  constructor(designerCanvas: IDesignerCanvas);
17
16
  connected(): void;
@@ -86,10 +86,11 @@ export class ExtensionManager {
86
86
  }
87
87
  _selectedElementsRefresh(selectionChangedEvent) {
88
88
  this.refreshAllAppliedExtentions(selectionChangedEvent.event);
89
- if (selectionChangedEvent.selectedElements && selectionChangedEvent.selectedElements.length && (!this._lastPrimarySelectionRefreshItem || this._lastPrimarySelectionRefreshItem.deref() !== selectionChangedEvent.selectedElements[0])) {
90
- this.applyExtension(selectionChangedEvent.selectedElements[0], ExtensionType.PrimarySelectionRefreshed, selectionChangedEvent.event);
91
- this._lastPrimarySelectionRefreshItem = new WeakRef(selectionChangedEvent.selectedElements[0]);
89
+ if (selectionChangedEvent.selectedElements && selectionChangedEvent.selectedElements.length && this._lastPrimarySelectionRefreshItem?.deref() === selectionChangedEvent.selectedElements[0]) {
90
+ if (!this._appliedDesignerExtensions.get(selectionChangedEvent.selectedElements[0])?.get(ExtensionType.PrimarySelectionRefreshed))
91
+ this.applyExtension(selectionChangedEvent.selectedElements[0], ExtensionType.PrimarySelectionRefreshed, selectionChangedEvent.event);
92
92
  }
93
+ this._lastPrimarySelectionRefreshItem = new WeakRef(selectionChangedEvent.selectedElements[0]);
93
94
  }
94
95
  applyExtension(designItem, extensionType, event, recursive = false) {
95
96
  if (designItem && designItem.nodeType == NodeType.Element) {
@@ -5,6 +5,7 @@ import { IExtensionManager } from './IExtensionManger.js';
5
5
  export declare class PreviousElementSelectExtension extends AbstractExtension {
6
6
  constructor(extensionManager: IExtensionManager, designerView: IDesignerCanvas, extendedItem: IDesignItem);
7
7
  private _rect;
8
+ private _clickRect;
8
9
  private _g;
9
10
  extend(cache: Record<string | symbol, any>, event?: Event): void;
10
11
  refresh(cache: Record<string | symbol, any>, event?: Event): void;
@@ -5,6 +5,7 @@ export class PreviousElementSelectExtension extends AbstractExtension {
5
5
  super(extensionManager, designerView, extendedItem);
6
6
  }
7
7
  _rect;
8
+ _clickRect;
8
9
  _g;
9
10
  extend(cache, event) {
10
11
  this.refresh(cache, event);
@@ -12,9 +13,10 @@ export class PreviousElementSelectExtension extends AbstractExtension {
12
13
  refresh(cache, event) {
13
14
  const transformedCornerPoints = getDesignerCanvasNormalizedTransformedCornerDOMPoints(this.extendedItem.element, null, this.designerCanvas, cache);
14
15
  if (!isNaN(transformedCornerPoints[1].x)) {
15
- if (this._valuesHaveChanges(transformedCornerPoints[0].x, transformedCornerPoints[0].y, this.designerCanvas.scaleFactor)) {
16
+ if (this._valuesHaveChanges(transformedCornerPoints[1].x, transformedCornerPoints[1].y, this.designerCanvas.scaleFactor)) {
16
17
  const h = (16 / this.designerCanvas.scaleFactor);
17
18
  this._rect = this._drawRect(transformedCornerPoints[1].x - (15 / this.designerCanvas.scaleFactor), transformedCornerPoints[1].y - (16.5 / this.designerCanvas.scaleFactor), h, h, 'svg-previous-select', this._rect);
19
+ this._clickRect = this._drawRect(transformedCornerPoints[1].x - (15 / this.designerCanvas.scaleFactor), transformedCornerPoints[1].y - (16.5 / this.designerCanvas.scaleFactor), h, h + 3, 'svg-invisible', this._clickRect);
18
20
  if (!this._g) {
19
21
  this._g = document.createElementNS("http://www.w3.org/2000/svg", "g");
20
22
  this._g.setAttribute('class', 'svg-previous-select');
@@ -22,11 +24,15 @@ export class PreviousElementSelectExtension extends AbstractExtension {
22
24
  path.setAttribute('d', 'm4 12 1.41 1.41L11 7.83V20h2V7.83l5.58 5.59L20 12l-8-8-8 8z');
23
25
  this._g.appendChild(path);
24
26
  this._addOverlay(this._g);
25
- this._rect.onpointerdown = (e) => {
27
+ this._clickRect.onpointerdown = (e) => {
26
28
  e.preventDefault();
27
29
  e.stopPropagation();
28
30
  this.extendedItem.instanceServiceContainer.selectionService.setSelectedElements([this.extendedItem.parent]);
29
31
  };
32
+ this._clickRect.onpointermove = (e) => {
33
+ e.preventDefault();
34
+ e.stopPropagation();
35
+ };
30
36
  }
31
37
  this._g.setAttribute('transform', 'translate(' + (transformedCornerPoints[1].x - (14.5 / this.designerCanvas.scaleFactor)) + ',' + (transformedCornerPoints[1].y - (15.5 / this.designerCanvas.scaleFactor)) + ') scale(' + 0.6 / this.designerCanvas.scaleFactor + ')');
32
38
  }
@@ -9,6 +9,7 @@ export declare class EditGridColumnRowSizesExtension extends AbstractExtension {
9
9
  private _initalPos;
10
10
  private _initialSizes;
11
11
  private _group;
12
+ private _hasChanged;
12
13
  constructor(extensionManager: IExtensionManager, designerView: IDesignerCanvas, extendedItem: IDesignItem);
13
14
  extend(cache: Record<string | symbol, any>, event?: Event): void;
14
15
  refresh(cache: Record<string | symbol, any>, event?: Event): void;
@@ -10,6 +10,7 @@ export class EditGridColumnRowSizesExtension extends AbstractExtension {
10
10
  _initalPos;
11
11
  _initialSizes;
12
12
  _group;
13
+ _hasChanged;
13
14
  constructor(extensionManager, designerView, extendedItem) {
14
15
  super(extensionManager, designerView, extendedItem);
15
16
  }
@@ -57,29 +58,35 @@ export class EditGridColumnRowSizesExtension extends AbstractExtension {
57
58
  case EventNames.PointerMove:
58
59
  if (this._initialSizes) {
59
60
  const diff = this._initalPos - pos;
60
- let parts = this._initialSizes.split(' ');
61
- parts[index] = (parseFloat(parts[index]) - diff) + 'px';
62
- parts[index + 1] = (parseFloat(parts[index + 1]) + diff) + 'px';
63
- this.extendedItem.element.style[templatePropertyName] = parts.join(' ');
64
- this.extensionManager.refreshExtensions([this.extendedItem], null, event);
61
+ if (Math.abs(diff) > 5 || this._hasChanged) {
62
+ this._hasChanged = true;
63
+ let parts = this._initialSizes.split(' ');
64
+ parts[index] = (parseFloat(parts[index]) - diff) + 'px';
65
+ parts[index + 1] = (parseFloat(parts[index + 1]) + diff) + 'px';
66
+ this.extendedItem.element.style[templatePropertyName] = parts.join(' ');
67
+ this.extensionManager.refreshExtensions([this.extendedItem], null, event);
68
+ }
65
69
  }
66
70
  break;
67
71
  case EventNames.PointerUp:
68
72
  rect.releasePointerCapture(event.pointerId);
69
73
  const diff = this._initalPos - pos;
70
- const realStyle = this.extendedItem.getStyleFromSheetOrLocalOrComputed(templatePropertyName);
71
- const initialParts = this._initialSizes.split(' ');
72
- const parts = realStyle.split(' ');
73
- let units = parts.map(x => getCssUnit(x));
74
- if (parts.length != initialParts.length) {
75
- units = initialParts.map(x => getCssUnit(x));
74
+ if (this._hasChanged) {
75
+ this._hasChanged = false;
76
+ const realStyle = this.extendedItem.getStyleFromSheetOrLocalOrComputed(templatePropertyName);
77
+ const initialParts = this._initialSizes.split(' ');
78
+ const parts = realStyle.split(' ');
79
+ let units = parts.map(x => getCssUnit(x));
80
+ if (parts.length != initialParts.length) {
81
+ units = initialParts.map(x => getCssUnit(x));
82
+ }
83
+ this.extendedItem.element.style[templatePropertyName] = '';
84
+ const targetPixelSizes = initialParts.map(x => parseFloat(x));
85
+ targetPixelSizes[index] -= diff;
86
+ targetPixelSizes[index + 1] += diff;
87
+ const newSizes = this._convertCssUnits(targetPixelSizes, units, this.extendedItem.element, sizeType);
88
+ this.extendedItem.updateStyleInSheetOrLocal(templatePropertyName, newSizes.join(' '), null, true);
76
89
  }
77
- this.extendedItem.element.style[templatePropertyName] = '';
78
- const targetPixelSizes = initialParts.map(x => parseFloat(x));
79
- targetPixelSizes[index] -= diff;
80
- targetPixelSizes[index + 1] += diff;
81
- const newSizes = this._convertCssUnits(targetPixelSizes, units, this.extendedItem.element, sizeType);
82
- this.extendedItem.updateStyleInSheetOrLocal(templatePropertyName, newSizes.join(' '), null, true);
83
90
  this._initalPos = null;
84
91
  this._initialSizes = null;
85
92
  this.extensionManager.refreshExtensions([this.extendedItem]);
@@ -15,11 +15,12 @@ export class OverlayLayerView extends BaseCustomWebComponentConstructorAppend {
15
15
  overflow: visible;
16
16
  }
17
17
 
18
+ .svg-invisible { stroke: transparent; fill: transparent; pointer-events: all; }
18
19
  .svg-snapline { stroke: purple; stroke-dasharray: 4; fill: transparent; }
19
20
  .svg-selector { stroke: black; fill: #3899ec55; stroke-width: 1; stroke-dasharray: 2; }
20
- .svg-primary-selection-move { stroke: #3899ec; fill: #3899ec; cursor: move; pointer-events: all }
21
+ .svg-primary-selection-move { stroke: #3899ec; fill: #3899ec; cursor: move; pointer-events: all; }
21
22
  .svg-position { stroke: black; stroke-dasharray: 2; }
22
- .svg-path { stroke: #3899ec; fill: orange; pointer-events: all }
23
+ .svg-path { stroke: #3899ec; fill: orange; pointer-events: all; }
23
24
  .svg-path-line { stroke: #3899ec; stroke-dasharray: 2; }
24
25
  .svg-draw-new-element { stroke: black; fill: transparent; stroke-width: 1; }
25
26
  .svg-toolbar-container { overflow: visible }
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "description": "A WYSIWYG designer webcomponent for html components",
3
3
  "name": "@node-projects/web-component-designer",
4
- "version": "0.1.155",
4
+ "version": "0.1.157",
5
5
  "type": "module",
6
6
  "main": "./dist/index.js",
7
7
  "author": "jochen.kuehner@gmx.de",