@node-projects/web-component-designer 0.1.156 → 0.1.158
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/elements/helper/CssUnitConverter.d.ts +2 -0
- package/dist/elements/helper/CssUnitConverter.js +31 -0
- package/dist/elements/services/DefaultServiceBootstrap.js +2 -2
- package/dist/elements/services/elementAtPointService/ElementAtPointService.d.ts +1 -1
- package/dist/elements/services/elementAtPointService/ElementAtPointService.js +2 -2
- package/dist/elements/services/propertiesService/services/NativeElementsPropertiesService.js +6 -0
- package/dist/elements/widgets/designerView/extensions/ElementDragTitleExtension.d.ts +1 -0
- package/dist/elements/widgets/designerView/extensions/ElementDragTitleExtension.js +14 -4
- package/dist/elements/widgets/designerView/extensions/ExtensionManager.d.ts +3 -4
- package/dist/elements/widgets/designerView/extensions/ExtensionManager.js +4 -3
- package/dist/elements/widgets/designerView/extensions/PreviousElementSelectExtension.d.ts +1 -0
- package/dist/elements/widgets/designerView/extensions/PreviousElementSelectExtension.js +8 -2
- package/dist/elements/widgets/designerView/extensions/grid/EditGridColumnRowSizesExtension.js +3 -4
- package/dist/elements/widgets/designerView/extensions/grid/GridToolbarExtension.js +4 -4
- package/dist/elements/widgets/designerView/overlayLayerView.js +3 -2
- package/package.json +1 -1
|
@@ -1,3 +1,5 @@
|
|
|
1
1
|
export declare function convertCssUnitToPixel(cssValue: string, target: HTMLElement, percentTarget: 'width' | 'height'): number;
|
|
2
2
|
export declare function getCssUnit(cssValue: string): string;
|
|
3
3
|
export declare function convertCssUnit(cssValue: string | number, target: HTMLElement, percentTarget: 'width' | 'height', unit: string): string;
|
|
4
|
+
export declare function splitCssGridColumnSizes(sizes: String): string[];
|
|
5
|
+
export declare function getExpandedCssGridColumnSizes(sizes: String): string[];
|
|
@@ -102,3 +102,34 @@ export function convertCssUnit(cssValue, target, percentTarget, unit) {
|
|
|
102
102
|
function getOriginalSizeBeforeTransformation(element) {
|
|
103
103
|
return { width: element.offsetWidth, height: element.offsetHeight };
|
|
104
104
|
}
|
|
105
|
+
export function splitCssGridColumnSizes(sizes) {
|
|
106
|
+
const parts = sizes.split(' ');
|
|
107
|
+
const ret = [];
|
|
108
|
+
for (let i = 0; i < parts.length; i++) {
|
|
109
|
+
let p = parts[i];
|
|
110
|
+
if (p.startsWith('repeat(')) {
|
|
111
|
+
while (!p.includes(")")) {
|
|
112
|
+
i++;
|
|
113
|
+
if (!parts[i])
|
|
114
|
+
continue;
|
|
115
|
+
p += parts[i];
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
ret.push(p);
|
|
119
|
+
}
|
|
120
|
+
return ret;
|
|
121
|
+
}
|
|
122
|
+
export function getExpandedCssGridColumnSizes(sizes) {
|
|
123
|
+
const parts = splitCssGridColumnSizes(sizes);
|
|
124
|
+
const ret = [];
|
|
125
|
+
for (let p of parts) {
|
|
126
|
+
if (p.startsWith('repeat(')) {
|
|
127
|
+
const prt = p.split(',');
|
|
128
|
+
for (let i = 0; i < parseInt(prt[0].substring(7)); i++)
|
|
129
|
+
ret.push(prt[1].substring(0, prt[1].length - 1));
|
|
130
|
+
}
|
|
131
|
+
else
|
|
132
|
+
ret.push(p);
|
|
133
|
+
}
|
|
134
|
+
return ret.map(x => getCssUnit(x));
|
|
135
|
+
}
|
|
@@ -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(
|
|
5
|
+
getElementAtPoint(designerCanvas: IDesignerCanvas, point: IPoint): any;
|
|
6
6
|
}
|
package/dist/elements/services/propertiesService/services/NativeElementsPropertiesService.js
CHANGED
|
@@ -149,6 +149,12 @@ export class NativeElementsPropertiesService extends AbstractPropertiesService {
|
|
|
149
149
|
type: "string",
|
|
150
150
|
service: this,
|
|
151
151
|
propertyType: PropertyType.propertyAndAttribute
|
|
152
|
+
},
|
|
153
|
+
{
|
|
154
|
+
name: "alt",
|
|
155
|
+
type: "string",
|
|
156
|
+
service: this,
|
|
157
|
+
propertyType: PropertyType.propertyAndAttribute
|
|
152
158
|
}
|
|
153
159
|
];
|
|
154
160
|
iframeProperties = [
|
|
@@ -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
|
|
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.
|
|
27
|
-
this.
|
|
28
|
-
this.
|
|
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<
|
|
13
|
-
_shouldAppliedDesignerExtensions: WeakMap<
|
|
14
|
-
_lastApplyEventPerType: WeakMap<
|
|
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 &&
|
|
90
|
-
this.
|
|
91
|
-
|
|
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[
|
|
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.
|
|
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
|
}
|
package/dist/elements/widgets/designerView/extensions/grid/EditGridColumnRowSizesExtension.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { EventNames } from "../../../../../enums/EventNames.js";
|
|
2
|
-
import { convertCssUnit, convertCssUnitToPixel, getCssUnit } from "../../../../helper/CssUnitConverter.js";
|
|
2
|
+
import { convertCssUnit, convertCssUnitToPixel, getCssUnit, getExpandedCssGridColumnSizes } from "../../../../helper/CssUnitConverter.js";
|
|
3
3
|
import { calculateGridInformation } from "../../../../helper/GridHelper.js";
|
|
4
4
|
import { getElementCombinedTransform } from "../../../../helper/TransformHelper.js";
|
|
5
5
|
import { AbstractExtension } from '../AbstractExtension.js';
|
|
@@ -75,9 +75,8 @@ export class EditGridColumnRowSizesExtension extends AbstractExtension {
|
|
|
75
75
|
this._hasChanged = false;
|
|
76
76
|
const realStyle = this.extendedItem.getStyleFromSheetOrLocalOrComputed(templatePropertyName);
|
|
77
77
|
const initialParts = this._initialSizes.split(' ');
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
if (parts.length != initialParts.length) {
|
|
78
|
+
let units = getExpandedCssGridColumnSizes(realStyle);
|
|
79
|
+
if (units.length != initialParts.length) {
|
|
81
80
|
units = initialParts.map(x => getCssUnit(x));
|
|
82
81
|
}
|
|
83
82
|
this.extendedItem.element.style[templatePropertyName] = '';
|
|
@@ -65,15 +65,15 @@ export class GridToolbarExtension extends BasicStackedToolbarExtension {
|
|
|
65
65
|
if (!rows)
|
|
66
66
|
return;
|
|
67
67
|
const cg = this.extendedItem.openGroup('change grid type');
|
|
68
|
-
await this.extendedItem.updateStyleInSheetOrLocalAsync('grid-template-columns', '
|
|
69
|
-
await this.extendedItem.updateStyleInSheetOrLocalAsync('grid-template-rows', '
|
|
68
|
+
await this.extendedItem.updateStyleInSheetOrLocalAsync('grid-template-columns', 'repeat(' + columns + ', 1fr)');
|
|
69
|
+
await this.extendedItem.updateStyleInSheetOrLocalAsync('grid-template-rows', 'repeat(' + rows + ', 1fr)');
|
|
70
70
|
cg.commit();
|
|
71
71
|
}
|
|
72
72
|
else {
|
|
73
73
|
const parts = gridTypeEl.value.split('x');
|
|
74
74
|
const cg = this.extendedItem.openGroup('change grid type');
|
|
75
|
-
await this.extendedItem.updateStyleInSheetOrLocalAsync('grid-template-columns', '
|
|
76
|
-
await this.extendedItem.updateStyleInSheetOrLocalAsync('grid-template-rows', '
|
|
75
|
+
await this.extendedItem.updateStyleInSheetOrLocalAsync('grid-template-columns', 'repeat(' + parts[0] + ', 1fr)');
|
|
76
|
+
await this.extendedItem.updateStyleInSheetOrLocalAsync('grid-template-rows', 'repeat(' + parts[1] + ', 1fr)');
|
|
77
77
|
cg.commit();
|
|
78
78
|
}
|
|
79
79
|
};
|
|
@@ -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