@node-projects/web-component-designer 0.0.126 → 0.0.128

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 (136) hide show
  1. package/dist/elements/helper/contextMenu/{contextmenu.d.ts → ContextMenu.d.ts} +0 -0
  2. package/dist/elements/helper/contextMenu/{contextmenu.js → ContextMenu.js} +1 -0
  3. package/dist/elements/helper/contextMenu/{IContextmenuItem.d.ts → IContextMenuItem.d.ts} +0 -0
  4. package/dist/elements/helper/contextMenu/{IContextmenuItem.js → IContextMenuItem.js} +0 -0
  5. package/dist/elements/widgets/propertyGrid/PropertyGridWithHeader.js +1 -1
  6. package/package.json +2 -2
  7. package/dist/elements/helper/KeyNameHelper.d.ts +0 -0
  8. package/dist/elements/helper/KeyNameHelper.js +0 -1
  9. package/dist/elements/helper/contextMenu/ContextMenuHelper.d.ts +0 -0
  10. package/dist/elements/helper/contextMenu/ContextMenuHelper.js +0 -245
  11. package/dist/elements/helper/contextMenu/IContextmenuItemTmp.d.ts +0 -8
  12. package/dist/elements/helper/contextMenu/IContextmenuItemTmp.js +0 -2
  13. package/dist/elements/helper/contextMenu/NewContextmenu.d.ts +0 -30
  14. package/dist/elements/helper/contextMenu/NewContextmenu.js +0 -274
  15. package/dist/elements/services/bindableObjectsService/IDragDropService.d.ts +0 -5
  16. package/dist/elements/services/bindableObjectsService/IDragDropService.js +0 -1
  17. package/dist/elements/services/elementsService/WebcomponentManifestParserService.d.ts +0 -25
  18. package/dist/elements/services/elementsService/WebcomponentManifestParserService.js +0 -94
  19. package/dist/elements/services/htmlParserService/NodeHtmlParserService copy.d.ts +0 -11
  20. package/dist/elements/services/htmlParserService/NodeHtmlParserService copy.js +0 -96
  21. package/dist/elements/services/initializationService/DefaultIntializationService.d.ts +0 -6
  22. package/dist/elements/services/initializationService/DefaultIntializationService.js +0 -22
  23. package/dist/elements/services/instanceService/IPrepareElementsForDesignerService.d.ts +0 -4
  24. package/dist/elements/services/instanceService/IPrepareElementsForDesignerService.js +0 -1
  25. package/dist/elements/services/instanceService/PrepareElementsForDesignerService.d.ts +0 -6
  26. package/dist/elements/services/instanceService/PrepareElementsForDesignerService.js +0 -32
  27. package/dist/elements/services/propertiesService/services/WebcomponentManifestParserService.d.ts +0 -25
  28. package/dist/elements/services/propertiesService/services/WebcomponentManifestParserService.js +0 -94
  29. package/dist/elements/services/undoService/transactionItems/MoveElementInDomAction.d.ts +0 -16
  30. package/dist/elements/services/undoService/transactionItems/MoveElementInDomAction.js +0 -31
  31. package/dist/elements/widgets/designerView/DesignerViewUseOverlayScollbars.d.ts +0 -7
  32. package/dist/elements/widgets/designerView/DesignerViewUseOverlayScollbars.js +0 -13
  33. package/dist/elements/widgets/designerView/designerCanvas.ts.BASE.d.ts +0 -92
  34. package/dist/elements/widgets/designerView/designerCanvas.ts.BASE.js +0 -734
  35. package/dist/elements/widgets/designerView/designerCanvas.ts.LOCAL.d.ts +0 -95
  36. package/dist/elements/widgets/designerView/designerCanvas.ts.LOCAL.js +0 -768
  37. package/dist/elements/widgets/designerView/designerCanvas.ts.REMOTE.d.ts +0 -94
  38. package/dist/elements/widgets/designerView/designerCanvas.ts.REMOTE.js +0 -745
  39. package/dist/elements/widgets/designerView/extensions/AltToEnterContainerExtension copy.d.ts +0 -12
  40. package/dist/elements/widgets/designerView/extensions/AltToEnterContainerExtension copy.js +0 -20
  41. package/dist/elements/widgets/designerView/extensions/AltToEnterContainerExtensionProvider copy.d.ts +0 -10
  42. package/dist/elements/widgets/designerView/extensions/AltToEnterContainerExtensionProvider copy.js +0 -14
  43. package/dist/elements/widgets/designerView/extensions/EditText/EditTextExtension copy.d.ts +0 -17
  44. package/dist/elements/widgets/designerView/extensions/EditText/EditTextExtension copy.js +0 -80
  45. package/dist/elements/widgets/designerView/extensions/EditText/EditTextExtensionProvider copy.d.ts +0 -9
  46. package/dist/elements/widgets/designerView/extensions/EditText/EditTextExtensionProvider copy.js +0 -11
  47. package/dist/elements/widgets/designerView/extensions/GrayOutDragOverExtension.d.ts +0 -11
  48. package/dist/elements/widgets/designerView/extensions/GrayOutDragOverExtension.js +0 -18
  49. package/dist/elements/widgets/designerView/extensions/IframeExtension.d.ts +0 -11
  50. package/dist/elements/widgets/designerView/extensions/IframeExtension.js +0 -46
  51. package/dist/elements/widgets/designerView/extensions/IframeExtensionProvider.d.ts +0 -9
  52. package/dist/elements/widgets/designerView/extensions/IframeExtensionProvider.js +0 -9
  53. package/dist/elements/widgets/designerView/extensions/PathExtension.d.ts +0 -23
  54. package/dist/elements/widgets/designerView/extensions/PathExtension.js +0 -251
  55. package/dist/elements/widgets/designerView/extensions/PathExtensionProvider.d.ts +0 -9
  56. package/dist/elements/widgets/designerView/extensions/PathExtensionProvider.js +0 -18
  57. package/dist/elements/widgets/designerView/extensions/PrimarySelectionDefaultExtension.d.ts +0 -13
  58. package/dist/elements/widgets/designerView/extensions/PrimarySelectionDefaultExtension.js +0 -21
  59. package/dist/elements/widgets/designerView/extensions/PrimarySelectionDefaultExtensionProvider.d.ts +0 -10
  60. package/dist/elements/widgets/designerView/extensions/PrimarySelectionDefaultExtensionProvider.js +0 -13
  61. package/dist/elements/widgets/designerView/extensions/contextMenu/CopyPasteContextMenu copy.d.ts +0 -8
  62. package/dist/elements/widgets/designerView/extensions/contextMenu/CopyPasteContextMenu copy.js +0 -15
  63. package/dist/elements/widgets/designerView/extensions/contextMenu/ZMoveContextMenu copy.d.ts +0 -8
  64. package/dist/elements/widgets/designerView/extensions/contextMenu/ZMoveContextMenu copy.js +0 -14
  65. package/dist/elements/widgets/designerView/toolBar/DrawElementTool.d.ts +0 -19
  66. package/dist/elements/widgets/designerView/toolBar/DrawElementTool.js +0 -79
  67. package/dist/elements/widgets/designerView/toolBar/DrawEllipsisTool.d.ts +0 -16
  68. package/dist/elements/widgets/designerView/toolBar/DrawEllipsisTool.js +0 -94
  69. package/dist/elements/widgets/designerView/toolBar/DrawLineTool.d.ts +0 -14
  70. package/dist/elements/widgets/designerView/toolBar/DrawLineTool.js +0 -79
  71. package/dist/elements/widgets/designerView/toolBar/DrawPathTool.d.ts +0 -20
  72. package/dist/elements/widgets/designerView/toolBar/DrawPathTool.js +0 -128
  73. package/dist/elements/widgets/designerView/toolBar/DrawRectTool.d.ts +0 -19
  74. package/dist/elements/widgets/designerView/toolBar/DrawRectTool.js +0 -109
  75. package/dist/elements/widgets/designerView/toolBar/ITool.d.ts +0 -9
  76. package/dist/elements/widgets/designerView/toolBar/ITool.js +0 -1
  77. package/dist/elements/widgets/designerView/toolBar/MagicWandSelectorTool.d.ts +0 -12
  78. package/dist/elements/widgets/designerView/toolBar/MagicWandSelectorTool.js +0 -64
  79. package/dist/elements/widgets/designerView/toolBar/NamedTools.d.ts +0 -15
  80. package/dist/elements/widgets/designerView/toolBar/NamedTools.js +0 -16
  81. package/dist/elements/widgets/designerView/toolBar/PanTool.d.ts +0 -10
  82. package/dist/elements/widgets/designerView/toolBar/PanTool.js +0 -26
  83. package/dist/elements/widgets/designerView/toolBar/PickColorTool.d.ts +0 -10
  84. package/dist/elements/widgets/designerView/toolBar/PickColorTool.js +0 -20
  85. package/dist/elements/widgets/designerView/toolBar/PointerTool.d.ts +0 -24
  86. package/dist/elements/widgets/designerView/toolBar/PointerTool.js +0 -283
  87. package/dist/elements/widgets/designerView/toolBar/RectangleSelectorTool.d.ts +0 -12
  88. package/dist/elements/widgets/designerView/toolBar/RectangleSelectorTool.js +0 -84
  89. package/dist/elements/widgets/designerView/toolBar/TextTool.d.ts +0 -11
  90. package/dist/elements/widgets/designerView/toolBar/TextTool.js +0 -33
  91. package/dist/elements/widgets/designerView/toolBar/ZoomTool.d.ts +0 -17
  92. package/dist/elements/widgets/designerView/toolBar/ZoomTool.js +0 -79
  93. package/dist/elements/widgets/designerView/toolBar/designerToolbarGenerics/designerToolRenderer.d.ts +0 -5
  94. package/dist/elements/widgets/designerView/toolBar/designerToolbarGenerics/designerToolRenderer.js +0 -19
  95. package/dist/elements/widgets/designerView/toolBar/designerToolbarGenerics/designerToolbarPopup.d.ts +0 -8
  96. package/dist/elements/widgets/designerView/toolBar/designerToolbarGenerics/designerToolbarPopup.js +0 -41
  97. package/dist/elements/widgets/designerView/toolBar/designerToolbarGenerics/designerToolbarPopupToolSelect.d.ts +0 -9
  98. package/dist/elements/widgets/designerView/toolBar/designerToolbarGenerics/designerToolbarPopupToolSelect.js +0 -42
  99. package/dist/elements/widgets/designerView/toolBar/designerToolbarGenerics/designerToolsButtons.d.ts +0 -36
  100. package/dist/elements/widgets/designerView/toolBar/designerToolbarGenerics/designerToolsButtons.js +0 -96
  101. package/dist/elements/widgets/designerView/toolBar/designerToolbarPopups/DrawToolPopup.d.ts +0 -5
  102. package/dist/elements/widgets/designerView/toolBar/designerToolbarPopups/DrawToolPopup.js +0 -21
  103. package/dist/elements/widgets/designerView/toolBar/designerToolbarPopups/SelectorToolsPopup.d.ts +0 -8
  104. package/dist/elements/widgets/designerView/toolBar/designerToolbarPopups/SelectorToolsPopup.js +0 -23
  105. package/dist/elements/widgets/designerView/toolBar/designerToolsDock.d.ts +0 -24
  106. package/dist/elements/widgets/designerView/toolBar/designerToolsDock.js +0 -115
  107. package/dist/elements/widgets/designerView/tools/designerToolbarGenerics/designerToolRenderer.d.ts +0 -5
  108. package/dist/elements/widgets/designerView/tools/designerToolbarGenerics/designerToolRenderer.js +0 -19
  109. package/dist/elements/widgets/designerView/tools/designerToolbarGenerics/designerToolbarPopup.d.ts +0 -8
  110. package/dist/elements/widgets/designerView/tools/designerToolbarGenerics/designerToolbarPopup.js +0 -41
  111. package/dist/elements/widgets/designerView/tools/designerToolbarGenerics/designerToolbarPopupToolSelect.d.ts +0 -9
  112. package/dist/elements/widgets/designerView/tools/designerToolbarGenerics/designerToolbarPopupToolSelect.js +0 -42
  113. package/dist/elements/widgets/designerView/tools/designerToolbarGenerics/designerToolsButtons.d.ts +0 -36
  114. package/dist/elements/widgets/designerView/tools/designerToolbarGenerics/designerToolsButtons.js +0 -87
  115. package/dist/elements/widgets/designerView/tools/designerToolbarPopups/DrawToolPopup copy.d.ts +0 -8
  116. package/dist/elements/widgets/designerView/tools/designerToolbarPopups/DrawToolPopup copy.js +0 -25
  117. package/dist/elements/widgets/designerView/tools/designerToolbarPopups/DrawToolPopup.d.ts +0 -5
  118. package/dist/elements/widgets/designerView/tools/designerToolbarPopups/DrawToolPopup.js +0 -21
  119. package/dist/elements/widgets/designerView/tools/designerToolbarPopups/SelectorToolsPopup.d.ts +0 -8
  120. package/dist/elements/widgets/designerView/tools/designerToolbarPopups/SelectorToolsPopup.js +0 -23
  121. package/dist/elements/widgets/designerView/tools/designerToolsDock.d.ts +0 -24
  122. package/dist/elements/widgets/designerView/tools/designerToolsDock.js +0 -115
  123. package/dist/elements/widgets/designerView/tools/toolBar/AbstractDesignerToolbarButton.d.ts +0 -5
  124. package/dist/elements/widgets/designerView/tools/toolBar/AbstractDesignerToolbarButton.js +0 -5
  125. package/dist/elements/widgets/designerView/tools/toolBar/IDesignViewConfigButtonsProvider.d.ts +0 -5
  126. package/dist/elements/widgets/designerView/tools/toolBar/IDesignViewConfigButtonsProvider.js +0 -1
  127. package/dist/elements/widgets/designerView/tools/toolBar/buttons/PointerToolButtonProvider copy.d.ts +0 -5
  128. package/dist/elements/widgets/designerView/tools/toolBar/buttons/PointerToolButtonProvider copy.js +0 -7
  129. package/dist/elements/widgets/designerView/tools/toolBar/buttons/SelectorToolButtonProvider copy.d.ts +0 -5
  130. package/dist/elements/widgets/designerView/tools/toolBar/buttons/SelectorToolButtonProvider copy.js +0 -10
  131. package/dist/elements/widgets/designerView/tools/toolBar/designerToolsDock.d.ts +0 -24
  132. package/dist/elements/widgets/designerView/tools/toolBar/designerToolsDock.js +0 -115
  133. package/dist/elements/widgets/designerView/tools/toolBar/popups/SelectorToolsPopup.d.ts +0 -7
  134. package/dist/elements/widgets/designerView/tools/toolBar/popups/SelectorToolsPopup.js +0 -23
  135. package/dist/elements/widgets/designerView/tools/toolBar/popups/designerToolbarPopup.d.ts +0 -8
  136. package/dist/elements/widgets/designerView/tools/toolBar/popups/designerToolbarPopup.js +0 -41
@@ -8,6 +8,7 @@ export class ContextMenu {
8
8
  transition: transform 0.1s;
9
9
  transform-origin: top left;
10
10
  padding: 0;
11
+ z-index: 2147483647;
11
12
  }
12
13
 
13
14
  .context_menu.display {
@@ -37,7 +37,7 @@ export class PropertyGridWithHeader extends BaseCustomWebComponentLazyAppend {
37
37
  height: 20px;
38
38
  }
39
39
  #pg {
40
- height: calc(100% - 45px);
40
+ height: calc(100% - 64px);
41
41
  }
42
42
  `;
43
43
  static template = html `
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "description": "A UI designer for Polymer apps",
3
3
  "name": "@node-projects/web-component-designer",
4
- "version": "0.0.126",
4
+ "version": "0.0.128",
5
5
  "type": "module",
6
6
  "main": "./dist/index.js",
7
7
  "author": "",
@@ -13,7 +13,7 @@
13
13
  "prepublishOnly": "npm run build"
14
14
  },
15
15
  "dependencies": {
16
- "@node-projects/base-custom-webcomponent": "^0.10.1",
16
+ "@node-projects/base-custom-webcomponent": "^0.10.3",
17
17
  "construct-style-sheets-polyfill": "^3.1.0"
18
18
  },
19
19
  "devDependencies": {
File without changes
@@ -1 +0,0 @@
1
- "use strict";
@@ -1,245 +0,0 @@
1
- "use strict";
2
- /*import { IContextMenuItem } from "./IContextmenuItem";
3
- import { css } from "@node-projects/base-custom-webcomponent"
4
-
5
- export class ContextMenuHelper {
6
-
7
- private static _contextMenuCss = css`
8
- .context-menu {
9
- display: none;
10
- position: absolute;
11
- z-index: 999999;
12
- padding: 0px 0;
13
- background-color: rgb(255 255 255 / 93%);
14
- border: solid 1px #dfdfdf;
15
- box-shadow: 1px 1px 2px #cfcfcf;
16
- cursor: default;
17
- user-select: none;
18
- -webkit-user-select: none;
19
- border-radius: 12px;
20
- }
21
-
22
- .context-menu hr {
23
- margin: 0 0 5px 5%;
24
- height: 1px;
25
- width: 90%;
26
- background-color: #e2e2e2;
27
- }
28
-
29
- .context-menu--active {
30
- display: block;
31
- }
32
-
33
- .context-menu__items {
34
- list-style: none;
35
- margin: 8px;
36
- padding: 0;
37
- }
38
-
39
- .context-menu__item {
40
- display: block;
41
- margin-bottom: 4px;
42
- }
43
-
44
- .context-menu__item:last-child {
45
- margin-bottom: 0;
46
- }
47
-
48
- .context-menu__link {
49
- display: block;
50
- padding: 0px 12px;
51
- color: #0066aa;
52
- text-decoration: none;
53
- }
54
-
55
- .context-menu__link:hover {
56
- color: #fff;
57
- background-color: #0066aa;
58
- }`;
59
-
60
- private _shadowRoot: ShadowRoot | Document;
61
- private _element: HTMLElement;
62
- private _closeBound: () => void;
63
- private _keyUpBound: () => void;
64
- private _closeOnDownBound: () => void;
65
- private _closeOnUpBound: () => void;
66
-
67
- static addContextMenu(element: HTMLElement, items: IContextMenuItem[]) {
68
- element.oncontextmenu = (event) => {
69
- event.preventDefault();
70
- ContextMenuHelper.showContextMenu(null, event, null, items);
71
- }
72
- }
73
-
74
- static showContextMenu(shadowRoot: ShadowRoot | Document | null, e: MouseEvent, element: HTMLElement, items: IContextMenuItem[]) {
75
- if (shadowRoot == null)
76
- shadowRoot = document;
77
-
78
- //@ts-ignore
79
- if (shadowRoot.adoptedStyleSheets.indexOf(ContextMenuHelper._contextMenuCss) < 0) {
80
- //@ts-ignore
81
- shadowRoot.adoptedStyleSheets = [...shadowRoot.adoptedStyleSheets, ContextMenuHelper._contextMenuCss];
82
- }
83
- let ctxMenu = new ContextMenuHelper();
84
- let menu = ContextMenuHelper.createMenu(ctxMenu, items);
85
- ctxMenu.init(shadowRoot, menu);
86
- ctxMenu.positionMenu(e)
87
- return ctxMenu;
88
- }
89
-
90
- private constructor() {
91
- }
92
-
93
- private init(shadowRoot: ShadowRoot | Document, element: HTMLElement) {
94
- this._shadowRoot = shadowRoot;
95
- this._element = element;
96
- if (this._shadowRoot === document)
97
- document.body.appendChild(this._element);
98
- else
99
- this._shadowRoot.appendChild(this._element);
100
-
101
- this._closeBound = this.close.bind(this);
102
- this._closeOnUpBound = this._closeOnUp.bind(this);
103
- this._closeOnDownBound = this._closeOnDown.bind(this);
104
- this._keyUpBound = this._keyUp.bind(this);
105
-
106
- window.addEventListener('keyup', this._keyUpBound);
107
- window.addEventListener('resize', this._closeBound);
108
- window.addEventListener('mousedown', this._closeOnDownBound);
109
- window.addEventListener('mouseup', this._closeOnUpBound);
110
-
111
- this._element.classList.add('context-menu--active');
112
- }
113
-
114
- public close() {
115
- requestAnimationFrame(() => {
116
- window.removeEventListener('keyup', this._keyUpBound);
117
- window.removeEventListener('resize', this._closeBound);
118
- window.removeEventListener('mousedown', this._closeOnDownBound);
119
- window.removeEventListener('mouseup', this._closeOnUpBound);
120
-
121
- if (this._element.parentElement)
122
- this._element.parentElement.removeChild(this._element);
123
- });
124
- }
125
-
126
- public show() {
127
- this._element.classList.add('context-menu--active');
128
- }
129
-
130
- public hide() {
131
- this._element.classList.remove('context-menu--active');
132
- }
133
-
134
- private _keyUp(e: KeyboardEvent) {
135
- if (e.keyCode === 27) {
136
- this.close();
137
- }
138
- }
139
-
140
- private _closeOnDown(e: MouseEvent) {
141
- const p = e.composedPath();
142
- if (p.indexOf(this._element) < 0)
143
- this.close();
144
- }
145
-
146
- private _closeOnUp(e: MouseEvent) {
147
- if (e.button == 1)
148
- this.close();
149
- }
150
-
151
- static createMenu(helper: ContextMenuHelper, items: IContextMenuItem[]) {
152
- let nav = document.createElement('nav');
153
- nav.className = 'context-menu';
154
- let ul = document.createElement('ul');
155
- ul.className = 'context-menu__items';
156
- nav.appendChild(ul);
157
-
158
- let lastWasSeperator = false;
159
- for (let i of items) {
160
- if (i.title == '-') {
161
- if (!lastWasSeperator) {
162
- let hr = document.createElement('hr');
163
- ul.appendChild(hr);
164
- lastWasSeperator = true
165
- }
166
- } else {
167
- lastWasSeperator = false;
168
- let li = document.createElement('li');
169
- li.className = 'context-menu__item';
170
- let div = document.createElement('div');
171
- div.className = 'context-menu__link';
172
- div.textContent = i.title;
173
- li.appendChild(div);
174
- ul.appendChild(li);
175
- li.onclick = (e) => {
176
- helper.close();
177
- i.action(null, e);
178
- }
179
- }
180
- }
181
- return nav;
182
- }
183
-
184
- static clickInsideElement(e, className) {
185
- let el = e.srcElement || e.target;
186
-
187
- if (el.classList.contains(className)) {
188
- return el;
189
- } else {
190
- while (el = el.parentNode) {
191
- if (el.classList && el.classList.contains(className)) {
192
- return el;
193
- }
194
- }
195
- }
196
-
197
- return false;
198
- }
199
-
200
- static getPosition(e: MouseEvent) {
201
- let posx = 0;
202
- let posy = 0;
203
-
204
- //@ts-ignore
205
- if (!e) e = window.event;
206
-
207
- if (e.pageX || e.pageY) {
208
- posx = e.pageX + 5;
209
- posy = e.pageY - 5;
210
- } else if (e.clientX || e.clientY) {
211
- posx = e.clientX + document.body.scrollLeft + document.documentElement.scrollLeft + 5;
212
- posy = e.clientY + document.body.scrollTop + document.documentElement.scrollTop - 5;
213
- }
214
-
215
- return {
216
- x: posx,
217
- y: posy
218
- }
219
- }
220
-
221
- public positionMenu(e: MouseEvent) {
222
- let clickCoords = ContextMenuHelper.getPosition(e);
223
- let clickCoordsX = clickCoords.x;
224
- let clickCoordsY = clickCoords.y;
225
-
226
- let menuWidth = this._element.offsetWidth + 4;
227
- let menuHeight = this._element.offsetHeight + 4;
228
-
229
- let windowWidth = window.innerWidth;
230
- let windowHeight = window.innerHeight;
231
-
232
- if ((windowWidth - clickCoordsX) < menuWidth) {
233
- this._element.style.left = windowWidth - menuWidth + "px";
234
- } else {
235
- this._element.style.left = clickCoordsX + "px";
236
- }
237
-
238
- if ((windowHeight - clickCoordsY) < menuHeight) {
239
- this._element.style.top = windowHeight - menuHeight + "px";
240
- } else {
241
- this._element.style.top = clickCoordsY + "px";
242
- }
243
- }
244
- }
245
- */
@@ -1,8 +0,0 @@
1
- export interface IContextMenuItem {
2
- readonly title?: string;
3
- readonly icon?: string;
4
- readonly children?: IContextMenuItem[];
5
- readonly disabled?: boolean;
6
- readonly shortCut?: string;
7
- action?: (event: MouseEvent, item: IContextMenuItem) => void;
8
- }
@@ -1,2 +0,0 @@
1
- ;
2
- export {};
@@ -1,30 +0,0 @@
1
- export interface IContextMenuItem {
2
- readonly title?: string;
3
- readonly icon?: string;
4
- readonly children?: IContextMenuItem[];
5
- readonly disabled?: boolean;
6
- readonly shortCut?: string;
7
- action?: (event: MouseEvent, item: IContextMenuItem) => void;
8
- }
9
- export interface IContextMenuOptions {
10
- closeOnResize?: boolean;
11
- closeOnClick?: boolean;
12
- defaultIcon?: string;
13
- subIcon?: string;
14
- mouseOffset?: number;
15
- shadowRoot?: ShadowRoot | Document;
16
- }
17
- export declare class ContextMenu {
18
- private static _contextMenuCss;
19
- static count: number;
20
- menu: IContextMenuItem[];
21
- options: IContextMenuOptions;
22
- private num;
23
- private _documentClickBound;
24
- constructor(menu: IContextMenuItem[], options: any);
25
- reload(): void;
26
- renderLevel(level: IContextMenuItem[]): HTMLUListElement;
27
- display(event: MouseEvent): void;
28
- close(): void;
29
- _documentClick(): void;
30
- }
@@ -1,274 +0,0 @@
1
- import { css } from "@node-projects/base-custom-webcomponent";
2
- export class ContextMenu {
3
- static _contextMenuCss = css `
4
- .context_menu {
5
- position: fixed;
6
- opacity: 0;
7
- transform: scale(0);
8
- transition: transform 0.1s;
9
- transform-origin: top left;
10
- padding: 0;
11
- }
12
-
13
- .context_menu.display {
14
- opacity: 1;
15
- transform: scale(1);
16
- }
17
-
18
- .context_menu,
19
- .context_menu * {
20
- box-sizing: border-box;
21
- }
22
-
23
- .context_menu * {
24
- position: relative;
25
- }
26
-
27
- .context_menu ul {
28
- list-style-type: none;
29
- padding: 0;
30
- margin: 0;
31
- background-color: #ccc;
32
- box-shadow: 0 0 5px #333;
33
- }
34
-
35
- .context_menu li {
36
- padding: 0;
37
- padding-right: 1.7em;
38
- cursor: pointer;
39
- white-space: nowrap;
40
- }
41
-
42
- .context_menu li:hover {
43
- background-color: #bbb;
44
- }
45
-
46
- .context_menu li .cm_icon_span {
47
- width: 1.5em;
48
- height: 1.2em;
49
- vertical-align: bottom;
50
- display: inline-block;
51
- border-right: 1px solid #aaa;
52
- margin-right: 5px;
53
- padding-right: 5px;
54
- text-align: center;
55
- }
56
-
57
- .context_menu li .cm_sub_span {
58
- width: 1em;
59
- display: inline-block;
60
- text-align: center;
61
- position: absolute;
62
- top: 50%;
63
- right: 0.5em;
64
- transform: translateY(-50%);
65
- }
66
-
67
- .context_menu li>ul {
68
- position: absolute;
69
- top: 0;
70
- left: 100%;
71
- opacity: 0;
72
- transition: opacity 0.2s;
73
- visibility: hidden;
74
- }
75
-
76
- .context_menu li:hover>ul {
77
- opacity: 1;
78
- visibility: visible;
79
- }
80
-
81
- .context_menu li.cm_divider {
82
- border-bottom: 1px solid #aaa;
83
- margin: 5px;
84
- padding: 0;
85
- cursor: default;
86
- }
87
-
88
- .context_menu li.cm_divider:hover {
89
- background-color: inherit;
90
- }
91
-
92
- .context_menu.cm_border_right>ul ul {
93
- left: unset;
94
- right: 100%;
95
- }
96
-
97
- .context_menu.cm_border_bottom>ul ul {
98
- top: unset;
99
- bottom: 0;
100
- }
101
-
102
- .context_menu li[disabled=""] {
103
- color: #777;
104
- cursor: default;
105
- }
106
-
107
- .context_menu li[disabled=""]:hover {
108
- background-color: inherit;
109
- }`;
110
- static count = 0;
111
- menu;
112
- options;
113
- num;
114
- _documentClickBound;
115
- constructor(menu, options) {
116
- console.error(this);
117
- this.num = ContextMenu.count++;
118
- this.menu = menu;
119
- this.options = options;
120
- window.addEventListener("resize", () => {
121
- if (this.options.closeOnResize ?? true) {
122
- this.close();
123
- }
124
- });
125
- this.reload();
126
- this._documentClickBound = this._documentClick.bind(this);
127
- }
128
- reload() {
129
- if (document.getElementById('cm_' + this.num) == null) {
130
- var cnt = document.createElement("div");
131
- cnt.className = "context_menu";
132
- cnt.id = "cm_" + this.num;
133
- document.body.appendChild(cnt);
134
- }
135
- var container = document.getElementById('cm_' + this.num);
136
- container.innerHTML = "";
137
- let shadowRoot = this.options?.shadowRoot ?? document;
138
- if (shadowRoot.adoptedStyleSheets.indexOf(ContextMenu._contextMenuCss) < 0) {
139
- shadowRoot.adoptedStyleSheets = [...shadowRoot.adoptedStyleSheets, ContextMenu._contextMenuCss];
140
- }
141
- container.appendChild(this.renderLevel(this.menu));
142
- }
143
- renderLevel(level) {
144
- var ul_outer = document.createElement("ul");
145
- let lastWasDivider = false;
146
- level.forEach((item) => {
147
- let li = document.createElement("li");
148
- if (item.title !== '-') {
149
- var icon_span = document.createElement("span");
150
- icon_span.className = 'cm_icon_span';
151
- if ((item.icon ?? '') != '') {
152
- icon_span.innerHTML = item.icon;
153
- }
154
- else {
155
- icon_span.innerHTML = this.options?.defaultIcon ?? '';
156
- }
157
- let text_span = document.createElement("span");
158
- text_span.className = 'cm_text';
159
- text_span.innerHTML = item.title;
160
- let sub_span = document.createElement("span");
161
- sub_span.className = 'cm_sub_span';
162
- if (item.children != null) {
163
- sub_span.innerHTML = this.options?.subIcon ?? '&#155;';
164
- }
165
- li.appendChild(icon_span);
166
- li.appendChild(text_span);
167
- li.appendChild(sub_span);
168
- if (item.disabled) {
169
- li.setAttribute("disabled", "");
170
- }
171
- else {
172
- if (item.action)
173
- li.addEventListener('click', (e) => item.action(e, item));
174
- if (typeof item.children !== "undefined") {
175
- li.appendChild(this.renderLevel(item.children));
176
- }
177
- }
178
- lastWasDivider = false;
179
- ul_outer.appendChild(li);
180
- }
181
- else {
182
- if (!lastWasDivider) {
183
- li.className = "cm_divider";
184
- lastWasDivider = true;
185
- ul_outer.appendChild(li);
186
- }
187
- }
188
- });
189
- return ul_outer;
190
- }
191
- display(event) {
192
- let menu = document.getElementById('cm_' + this.num);
193
- let clickCoords = { x: event.clientX, y: event.clientY };
194
- let clickCoordsX = clickCoords.x;
195
- let clickCoordsY = clickCoords.y;
196
- let menuWidth = menu.offsetWidth + 4;
197
- let menuHeight = menu.offsetHeight + 4;
198
- let windowWidth = window.innerWidth;
199
- let windowHeight = window.innerHeight;
200
- let mouseOffset = this.options?.mouseOffset != null ? this.options.mouseOffset : 2;
201
- if ((windowWidth - clickCoordsX) < menuWidth) {
202
- menu.style.left = windowWidth - menuWidth + "px";
203
- }
204
- else {
205
- menu.style.left = (clickCoordsX + mouseOffset) + "px";
206
- }
207
- if ((windowHeight - clickCoordsY) < menuHeight) {
208
- menu.style.top = windowHeight - menuHeight + "px";
209
- }
210
- else {
211
- menu.style.top = (clickCoordsY + mouseOffset) + "px";
212
- }
213
- let sizes = ContextUtil.getSizes(menu);
214
- if ((windowWidth - clickCoordsX) < sizes.width) {
215
- menu.classList.add("cm_border_right");
216
- }
217
- else {
218
- menu.classList.remove("cm_border_right");
219
- }
220
- if ((windowHeight - clickCoordsY) < sizes.height) {
221
- menu.classList.add("cm_border_bottom");
222
- }
223
- else {
224
- menu.classList.remove("cm_border_bottom");
225
- }
226
- menu.classList.add("display");
227
- if (this.options?.closeOnClick ?? true) {
228
- window.addEventListener("click", this._documentClickBound);
229
- }
230
- event.preventDefault();
231
- }
232
- close() {
233
- document.getElementById('cm_' + this.num).remove();
234
- window.removeEventListener("click", this._documentClickBound);
235
- }
236
- _documentClick() {
237
- this.close();
238
- }
239
- }
240
- class ContextUtil {
241
- static getSizes(obj) {
242
- let lis = obj.getElementsByTagName('li');
243
- let width_def = 0;
244
- let height_def = 0;
245
- for (let i = 0; i < lis.length; i++) {
246
- let li = lis[i];
247
- if (li.offsetWidth > width_def) {
248
- width_def = li.offsetWidth;
249
- }
250
- if (li.offsetHeight > height_def) {
251
- height_def = li.offsetHeight;
252
- }
253
- }
254
- let width = width_def;
255
- let height = height_def;
256
- for (let i = 0; i < lis.length; i++) {
257
- let li = lis[i];
258
- let ul = li.getElementsByTagName('ul');
259
- if (typeof ul[0] !== "undefined") {
260
- let ul_size = ContextUtil.getSizes(ul[0]);
261
- if (width_def + ul_size.width > width) {
262
- width = width_def + ul_size.width;
263
- }
264
- if (height_def + ul_size.height > height) {
265
- height = height_def + ul_size.height;
266
- }
267
- }
268
- }
269
- return {
270
- "width": width,
271
- "height": height
272
- };
273
- }
274
- }
@@ -1,5 +0,0 @@
1
- import { IDesignerCanvas } from "../../widgets/designerView/IDesignerCanvas.js";
2
- export interface IDragDropService {
3
- dragOver(event: DragEvent): 'none' | 'copy' | 'link' | 'move';
4
- drop(designerView: IDesignerCanvas, event: DragEvent): any;
5
- }
@@ -1,25 +0,0 @@
1
- import { BindingTarget } from "../../item/BindingTarget";
2
- import { IElementDefinition } from "../elementsService/IElementDefinition";
3
- import { IElementsService } from "../elementsService/IElementsService";
4
- import { IPropertiesService } from "../propertiesService/IPropertiesService";
5
- import { IProperty } from "../propertiesService/IProperty";
6
- import { IDesignItem } from "../../item/IDesignItem";
7
- import { UnkownElementPropertiesService } from "../propertiesService/services/UnkownElementPropertiesService";
8
- export declare class WebcomponentManifestParserService extends UnkownElementPropertiesService implements IElementsService, IPropertiesService {
9
- private _name;
10
- get name(): string;
11
- private _packageData;
12
- private _elementList;
13
- private _propertiesList;
14
- private _resolveStored;
15
- private _rejectStored;
16
- private _importPrefix;
17
- constructor(name: string, fileOrObject: string | object, importPrefix?: string);
18
- private _parseManifest;
19
- private manifestClassPropertyTypeToEditorPropertyType;
20
- getElements(): Promise<IElementDefinition[]>;
21
- isHandledElement(designItem: IDesignItem): boolean;
22
- getProperties(designItem: IDesignItem): IProperty[];
23
- getProperty(designItem: IDesignItem, name: string): IProperty;
24
- getPropertyTarget(designItem: IDesignItem, property: IProperty): BindingTarget;
25
- }