@veloceapps/sdk 6.0.0-40 → 6.0.0-42

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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@veloceapps/sdk",
3
- "version": "6.0.0-40",
3
+ "version": "6.0.0-42",
4
4
  "private": false,
5
5
  "peerDependencies": {
6
6
  "@angular/animations": "^12.2.0",
@@ -1,32 +0,0 @@
1
- import { OnDestroy } from '@angular/core';
2
- import { ElementComponent } from '../components/element.component';
3
- import { PluginComponent } from '../components/plugin.component';
4
- import * as i0 from "@angular/core";
5
- export declare class ElementHoverPlugin implements PluginComponent, OnDestroy {
6
- host: ElementComponent;
7
- private readonly hoverClassName;
8
- private readonly color;
9
- private el;
10
- private metadata;
11
- private document;
12
- private runtimeEditorService;
13
- private overlayEl?;
14
- private highlighted;
15
- private destroyed$;
16
- private mouseOverListenerBound;
17
- private mouseLeaveListenerBound;
18
- constructor(host: ElementComponent);
19
- ngOnDestroy(): void;
20
- private attachListeners;
21
- private detachListeners;
22
- private mouseOverListener;
23
- private mouseLeaveListener;
24
- private addHighlight;
25
- private removeHighlight;
26
- private createContainer;
27
- private addRemoveButton;
28
- private addElementName;
29
- private deleteRemoveButton;
30
- static ɵfac: i0.ɵɵFactoryDeclaration<ElementHoverPlugin, never>;
31
- static ɵdir: i0.ɵɵDirectiveDeclaration<ElementHoverPlugin, never, never, {}, {}, never>;
32
- }
@@ -1,157 +0,0 @@
1
- import { DOCUMENT } from '@angular/common';
2
- import { Directive, ElementRef } from '@angular/core';
3
- import { merge } from 'lodash';
4
- import { Subject, takeUntil } from 'rxjs';
5
- import { ELEMENT_METADATA } from '../injection-tokens';
6
- import { RuntimeEditorService } from '../modules/runtime/services/runtime-editor.service';
7
- import * as i0 from "@angular/core";
8
- import * as i1 from "../components/element.component";
9
- export class ElementHoverPlugin {
10
- constructor(host) {
11
- this.host = host;
12
- this.hoverClassName = 'element-hover';
13
- this.color = 'red';
14
- this.highlighted = false;
15
- this.destroyed$ = new Subject();
16
- this.el = this.host.injector.get(ElementRef);
17
- this.metadata = this.host.injector.get(ELEMENT_METADATA);
18
- this.document = this.host.injector.get(DOCUMENT);
19
- this.runtimeEditorService = this.host.injector.get(RuntimeEditorService);
20
- this.mouseOverListenerBound = this.mouseOverListener.bind(this);
21
- this.mouseLeaveListenerBound = this.mouseLeaveListener.bind(this);
22
- this.runtimeEditorService.editorMode$.pipe(takeUntil(this.destroyed$)).subscribe(editorMode => {
23
- if (editorMode) {
24
- this.attachListeners();
25
- }
26
- else {
27
- this.detachListeners();
28
- }
29
- });
30
- }
31
- ngOnDestroy() {
32
- this.destroyed$.next();
33
- this.destroyed$.complete();
34
- this.detachListeners();
35
- }
36
- attachListeners() {
37
- this.el.nativeElement.addEventListener('mouseover', this.mouseOverListenerBound);
38
- this.el.nativeElement.addEventListener('mouseleave', this.mouseLeaveListenerBound);
39
- }
40
- detachListeners() {
41
- this.el.nativeElement.removeEventListener('mouseover', this.mouseOverListenerBound);
42
- this.el.nativeElement.removeEventListener('mouseleave', this.mouseLeaveListenerBound);
43
- }
44
- mouseOverListener(e) {
45
- const path = e.composedPath();
46
- const innerPath = path.slice(0, path.indexOf(this.el.nativeElement));
47
- const hasChildHovered = innerPath.some(target => {
48
- const t = target;
49
- return t.tagName === 'VL-ELEMENT' && t.classList.contains(this.hoverClassName);
50
- });
51
- if (hasChildHovered) {
52
- this.removeHighlight();
53
- }
54
- else {
55
- this.addHighlight();
56
- }
57
- }
58
- mouseLeaveListener() {
59
- this.removeHighlight();
60
- }
61
- addHighlight() {
62
- if (this.highlighted) {
63
- return;
64
- }
65
- this.highlighted = true;
66
- this.el.nativeElement.classList.add(this.hoverClassName);
67
- const overlay = this.createContainer();
68
- this.addRemoveButton(overlay);
69
- this.addElementName(overlay);
70
- this.el.nativeElement.appendChild(overlay);
71
- this.overlayEl = overlay;
72
- }
73
- removeHighlight() {
74
- if (!this.highlighted) {
75
- return;
76
- }
77
- this.highlighted = false;
78
- this.el.nativeElement.style.boxShadow = '';
79
- this.el.nativeElement.classList.remove(this.hoverClassName);
80
- this.deleteRemoveButton();
81
- }
82
- createContainer() {
83
- const hostRect = this.el.nativeElement.getBoundingClientRect();
84
- const div = this.document.createElement('div');
85
- merge(div.style, {
86
- position: 'fixed',
87
- display: 'block',
88
- pointerEvents: 'none',
89
- left: '0',
90
- top: '0',
91
- fontSize: '10px',
92
- lineHeight: `12px`,
93
- fontWeight: '400',
94
- color: '#fff',
95
- width: `${hostRect.width}px`,
96
- height: `${hostRect.height}px`,
97
- transform: `translate(${hostRect.left}px, ${hostRect.top}px)`,
98
- boxSizing: 'border-box',
99
- boxShadow: `inset 0 0 0 1px ${this.color}`,
100
- });
101
- return div;
102
- }
103
- addRemoveButton(container) {
104
- if (this.metadata.type === 'LAYOUT_REGION') {
105
- return;
106
- }
107
- const buttonEl = this.document.createElement('div');
108
- const buttonSize = 12;
109
- merge(buttonEl.style, {
110
- bottom: '100%',
111
- right: '0',
112
- width: `${buttonSize}px`,
113
- height: `${buttonSize}px`,
114
- padding: '1px',
115
- textAlign: 'center',
116
- backgroundColor: this.color,
117
- position: 'absolute',
118
- cursor: 'pointer',
119
- display: 'block',
120
- pointerEvents: 'all',
121
- });
122
- buttonEl.innerHTML = '&#10005;';
123
- buttonEl.addEventListener('click', () => {
124
- if (this.metadata.path) {
125
- this.runtimeEditorService.elementDeleted$.next({ path: this.metadata.path });
126
- }
127
- });
128
- container.appendChild(buttonEl);
129
- }
130
- addElementName(container) {
131
- const nameEl = this.document.createElement('div');
132
- merge(nameEl.style, {
133
- bottom: '100%',
134
- left: '0',
135
- height: `12px`,
136
- backgroundColor: this.color,
137
- position: 'absolute',
138
- padding: '1px 2px',
139
- display: 'block',
140
- pointerEvents: 'all',
141
- });
142
- nameEl.innerHTML = this.metadata.name;
143
- container.appendChild(nameEl);
144
- }
145
- deleteRemoveButton() {
146
- if (this.overlayEl) {
147
- this.el.nativeElement.removeChild(this.overlayEl);
148
- this.overlayEl = undefined;
149
- }
150
- }
151
- }
152
- ElementHoverPlugin.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: ElementHoverPlugin, deps: [{ token: i1.ElementComponent }], target: i0.ɵɵFactoryTarget.Directive });
153
- ElementHoverPlugin.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.17", type: ElementHoverPlugin, ngImport: i0 });
154
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: ElementHoverPlugin, decorators: [{
155
- type: Directive
156
- }], ctorParameters: function () { return [{ type: i1.ElementComponent }]; } });
157
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"element-hover.plugin.js","sourceRoot":"","sources":["../../../../../../libs/sdk/cms/plugins/element-hover.plugin.ts"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT } from '@angular/common';\nimport { Directive, ElementRef, OnDestroy } from '@angular/core';\nimport { merge } from 'lodash';\nimport { Subject, takeUntil } from 'rxjs';\nimport { ElementComponent } from '../components/element.component';\nimport { PluginComponent } from '../components/plugin.component';\nimport { ELEMENT_METADATA } from '../injection-tokens';\nimport { RuntimeEditorService } from '../modules/runtime/services/runtime-editor.service';\nimport { ElementMetadata } from '../types';\n\n@Directive()\nexport class ElementHoverPlugin implements PluginComponent, OnDestroy {\n  private readonly hoverClassName = 'element-hover';\n  private readonly color = 'red';\n\n  private el: ElementRef<HTMLElement>;\n  private metadata: ElementMetadata;\n  private document: Document;\n  private runtimeEditorService: RuntimeEditorService;\n  private overlayEl?: HTMLElement;\n  private highlighted = false;\n  private destroyed$ = new Subject<void>();\n\n  private mouseOverListenerBound: (e: MouseEvent) => void;\n  private mouseLeaveListenerBound: (e: MouseEvent) => void;\n\n  constructor(public host: ElementComponent) {\n    this.el = this.host.injector.get(ElementRef);\n    this.metadata = this.host.injector.get(ELEMENT_METADATA);\n    this.document = this.host.injector.get(DOCUMENT);\n    this.runtimeEditorService = this.host.injector.get(RuntimeEditorService);\n\n    this.mouseOverListenerBound = this.mouseOverListener.bind(this);\n    this.mouseLeaveListenerBound = this.mouseLeaveListener.bind(this);\n\n    this.runtimeEditorService.editorMode$.pipe(takeUntil(this.destroyed$)).subscribe(editorMode => {\n      if (editorMode) {\n        this.attachListeners();\n      } else {\n        this.detachListeners();\n      }\n    });\n  }\n\n  public ngOnDestroy(): void {\n    this.destroyed$.next();\n    this.destroyed$.complete();\n    this.detachListeners();\n  }\n\n  private attachListeners(): void {\n    this.el.nativeElement.addEventListener('mouseover', this.mouseOverListenerBound);\n    this.el.nativeElement.addEventListener('mouseleave', this.mouseLeaveListenerBound);\n  }\n\n  private detachListeners(): void {\n    this.el.nativeElement.removeEventListener('mouseover', this.mouseOverListenerBound);\n    this.el.nativeElement.removeEventListener('mouseleave', this.mouseLeaveListenerBound);\n  }\n\n  private mouseOverListener(e: MouseEvent): void {\n    const path = e.composedPath();\n    const innerPath = path.slice(0, path.indexOf(this.el.nativeElement));\n    const hasChildHovered = innerPath.some(target => {\n      const t = target as HTMLElement;\n      return t.tagName === 'VL-ELEMENT' && t.classList.contains(this.hoverClassName);\n    });\n\n    if (hasChildHovered) {\n      this.removeHighlight();\n    } else {\n      this.addHighlight();\n    }\n  }\n\n  private mouseLeaveListener(): void {\n    this.removeHighlight();\n  }\n\n  private addHighlight(): void {\n    if (this.highlighted) {\n      return;\n    }\n\n    this.highlighted = true;\n    this.el.nativeElement.classList.add(this.hoverClassName);\n\n    const overlay = this.createContainer();\n    this.addRemoveButton(overlay);\n    this.addElementName(overlay);\n    this.el.nativeElement.appendChild(overlay);\n    this.overlayEl = overlay;\n  }\n\n  private removeHighlight(): void {\n    if (!this.highlighted) {\n      return;\n    }\n\n    this.highlighted = false;\n    this.el.nativeElement.style.boxShadow = '';\n    this.el.nativeElement.classList.remove(this.hoverClassName);\n    this.deleteRemoveButton();\n  }\n\n  private createContainer(): HTMLElement {\n    const hostRect = this.el.nativeElement.getBoundingClientRect();\n    const div = this.document.createElement('div');\n\n    merge(div.style, <CSSStyleDeclaration>{\n      position: 'fixed',\n      display: 'block',\n      pointerEvents: 'none',\n      left: '0',\n      top: '0',\n      fontSize: '10px',\n      lineHeight: `12px`,\n      fontWeight: '400',\n      color: '#fff',\n      width: `${hostRect.width}px`,\n      height: `${hostRect.height}px`,\n      transform: `translate(${hostRect.left}px, ${hostRect.top}px)`,\n      boxSizing: 'border-box',\n      boxShadow: `inset 0 0 0 1px ${this.color}`,\n    });\n\n    return div;\n  }\n\n  private addRemoveButton(container: HTMLElement): void {\n    if (this.metadata.type === 'LAYOUT_REGION') {\n      return;\n    }\n\n    const buttonEl = this.document.createElement('div');\n    const buttonSize = 12;\n    merge(buttonEl.style, <CSSStyleDeclaration>{\n      bottom: '100%',\n      right: '0',\n      width: `${buttonSize}px`,\n      height: `${buttonSize}px`,\n      padding: '1px',\n      textAlign: 'center',\n      backgroundColor: this.color,\n      position: 'absolute',\n      cursor: 'pointer',\n      display: 'block',\n      pointerEvents: 'all',\n    });\n    buttonEl.innerHTML = '&#10005;';\n    buttonEl.addEventListener('click', () => {\n      if (this.metadata.path) {\n        this.runtimeEditorService.elementDeleted$.next({ path: this.metadata.path });\n      }\n    });\n\n    container.appendChild(buttonEl);\n  }\n\n  private addElementName(container: HTMLElement): void {\n    const nameEl = this.document.createElement('div');\n    merge(nameEl.style, <CSSStyleDeclaration>{\n      bottom: '100%',\n      left: '0',\n      height: `12px`,\n      backgroundColor: this.color,\n      position: 'absolute',\n      padding: '1px 2px',\n      display: 'block',\n      pointerEvents: 'all',\n    });\n\n    nameEl.innerHTML = this.metadata.name;\n\n    container.appendChild(nameEl);\n  }\n\n  private deleteRemoveButton(): void {\n    if (this.overlayEl) {\n      this.el.nativeElement.removeChild(this.overlayEl);\n      this.overlayEl = undefined;\n    }\n  }\n}\n"]}