dbweb-common
Version:
用`yarn add dbweb-common`安装,不要忘记修改`angular.json`里的 `architect\build\options\assets`,加上
197 lines • 21.2 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, HostBinding, Input, ViewChild, ElementRef } from '@angular/core';
import { NodeTypeEnum } from '../../../../services/eleview/types/model';
import { Node } from '../../../../services/eleview/types/node';
import { EditLabelService } from '../edit-label.service';
export class NodeComponent {
/**
* @param {?} lblSvr
* @param {?} ref
*/
constructor(lblSvr, ref) {
this.lblSvr = lblSvr;
this.ref = ref;
this.nodeTypeCondition = NodeTypeEnum.NodeCondition;
this.nodeTypeAnd = NodeTypeEnum.NodeAnd;
this.nodeTypeOr = NodeTypeEnum.NodeOr;
this.nodeTypeUnknow = NodeTypeEnum.unknow;
this.nodeTypePlain = NodeTypeEnum.NodePlain;
this.hostClass = true;
}
/**
* @return {?}
*/
ngOnInit() { }
/**
* @return {?}
*/
svgHeight() {
return this.data.flatHeight() * 50;
}
/**
* @param {?} event
* @return {?}
*/
nodeDragover(event) {
// 判断如果是节点
if (this.data.NodeType === this.nodeTypeAnd || this.data.NodeType === this.nodeTypeOr) {
event.preventDefault();
/** @type {?} */
const rect = ((/** @type {?} */ (this.ref.nativeElement))).getBoundingClientRect();
/** @type {?} */
const offsetY = event.pageY - rect.top;
/** @type {?} */
const clientHeight = rect.height;
if (this.lblSvr.dragOverNode !== this.data && this.lblSvr.prevNodeEle) {
/** @type {?} */
const ref = (/** @type {?} */ (this.lblSvr.prevNodeEle.nativeElement));
ref.style.borderTop = '4px solid transparent';
ref.style.borderBottom = '4px solid transparent';
ref.style.backgroundColor = null;
}
// Handle drag area
/** @type {?} */
const percentageY = offsetY / clientHeight;
if (percentageY < 0.5) {
((/** @type {?} */ (this.nodeMain.nativeElement))).style.borderTop = '4px solid #67c204';
((/** @type {?} */ (this.nodeMain.nativeElement))).style.borderBottom = '4px solid transparent';
this.lblSvr.dragOverArea = 'above';
}
else if (percentageY >= 0.5) {
((/** @type {?} */ (this.nodeMain.nativeElement))).style.borderTop = '4px solid transparent';
((/** @type {?} */ (this.nodeMain.nativeElement))).style.borderBottom = '4px solid #67c204';
this.lblSvr.dragOverArea = 'below';
}
this.lblSvr.dragOverNode = this.data;
this.lblSvr.prevNodeEle = this.nodeMain;
}
event.stopPropagation();
}
// 把拖动的node放到节点上边
/**
* @param {?} event
* @return {?}
*/
dropTop(event) {
if (this.data.parent) {
this.data.addTopSibling(this.lblSvr.buildDragedNode());
if (this.lblSvr.dragData.Type === 'node') {
((/** @type {?} */ (this.lblSvr.dragData.Data))).remove();
}
}
else {
this.data.Children[0].addTopSibling(this.lblSvr.buildDragedNode());
if (this.lblSvr.dragData.Type === 'node') {
((/** @type {?} */ (this.lblSvr.dragData.Data))).remove();
}
}
}
// 把拖动的node放到节点下边
/**
* @param {?} event
* @return {?}
*/
dropBottom(event) {
this.data.addBottomSibling(this.lblSvr.buildDragedNode());
if (this.lblSvr.dragData.Type === 'node') {
((/** @type {?} */ (this.lblSvr.dragData.Data))).remove();
}
}
/**
* @param {?} event
* @return {?}
*/
nodeDrop(event) {
if (this.data.NodeType === this.nodeTypeAnd || this.data.NodeType === this.nodeTypeOr) {
switch (this.lblSvr.dragOverArea) {
case 'above':
this.dropTop(event);
break;
case 'below':
this.dropBottom(event);
break;
}
this.lblSvr.onNodeChange.emit();
this.lblSvr.dragOverNode = null;
if (this.lblSvr.prevNodeEle) {
/** @type {?} */
const ref = (/** @type {?} */ (this.lblSvr.prevNodeEle.nativeElement));
ref.style.borderTop = '4px solid transparent';
ref.style.borderBottom = '4px solid transparent';
ref.style.backgroundColor = null;
}
}
event.stopPropagation();
}
/**
* @param {?} event
* @return {?}
*/
drop(event) {
if (this.data.NodeType === this.nodeTypeUnknow) {
this.data.assign(this.lblSvr.buildDragedNode());
this.lblSvr.onNodeChange.emit();
}
}
/**
* @return {?}
*/
logicClick() {
if (this.data.NodeType === NodeTypeEnum.NodeAnd) {
this.data.NodeType = NodeTypeEnum.NodeOr;
}
else {
this.data.NodeType = NodeTypeEnum.NodeAnd;
}
this.lblSvr.onNodeChange.emit();
}
}
NodeComponent.decorators = [
{ type: Component, args: [{
selector: 'common-node',
template: "<div #nodeMain class=\"node-main\" (drop)=\"nodeDrop($event)\" onselectstart=\"return false;\">\r\n\t<ng-container *ngIf=\"data.NodeType !== nodeTypeUnknow; else else_content\">\r\n\t\t<common-condition-node\r\n\t\t\t*ngIf=\"data.NodeType === nodeTypeCondition || data.NodeType === nodeTypePlain; else parentNode\"\r\n\t\t\t[data]=\"data\">\r\n\t\t</common-condition-node>\r\n\t\t<ng-template #parentNode>\r\n\t\t\t<div class=\"main\" *ngIf=\"data.NodeType !== nodeTypeCondition\" onselectstart=\"return false;\">\r\n\t\t\t\t<div class=\"node-left\" (dragover)=\"nodeDragover($event)\">\r\n\t\t\t\t\t<div class=\"logic\" >\r\n\t\t\t\t\t\t<div class=\"\u903B\u8F91 mat-elevation-z4\" (click)=\"logicClick()\" *ngIf=\"data.NodeType === nodeTypeAnd\">\u548C\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t\t<div class=\"\u903B\u8F91 mat-elevation-z4\" (click)=\"logicClick()\" *ngIf=\"data.NodeType === nodeTypeOr\">\u6216\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t\t<div class=\"line\"></div>\r\n\t\t\t\t</div>\r\n\t\t\t\t<div class=\"child-node\">\r\n\t\t\t\t\t<common-node *ngFor=\"let node of data.Children\" [data]=\"node\"> </common-node>\r\n\t\t\t\t</div>\r\n\t\t\t</div>\r\n\t\t</ng-template>\r\n\t</ng-container>\r\n\t<ng-template #else_content>\r\n\t\t<div class=\"empty\" (drop)=\"drop($event)\" (dragover)=\"$event.preventDefault()\">\r\n\t\t\t<p>\u7A7A\u5185\u5BB9</p>\r\n\t\t</div>\r\n\t</ng-template>\r\n</div>",
styles: ["@charset \"UTF-8\";.node-main{border-top:4px solid transparent;border-bottom:4px solid transparent;margin:-2px 0}.main{display:flex;justify-content:flex-start;align-items:stretch;margin:3px 0}.node-left{display:flex;justify-content:flex-start;align-items:stretch}.child-node{display:flex;flex-direction:column}.empty{width:100%;height:100%;display:flex;justify-content:center;align-items:center}.logic{display:flex;align-items:center}.logic .\u903B\u8F91{width:24px;height:24px;border-radius:4px;font-size:14px;text-align:center;line-height:24px;color:#fff;cursor:pointer}.line{width:15px;flex-shrink:0;border-top:1px solid #ccc;border-left:1px solid #ccc;border-bottom:1px solid #ccc;margin-left:4px;box-sizing:border-box}"]
}] }
];
/** @nocollapse */
NodeComponent.ctorParameters = () => [
{ type: EditLabelService },
{ type: ElementRef }
];
NodeComponent.propDecorators = {
data: [{ type: Input }],
hostClass: [{ type: HostBinding, args: ['class.node',] }],
nodeMain: [{ type: ViewChild, args: ['nodeMain', { static: true },] }]
};
if (false) {
/** @type {?} */
NodeComponent.prototype.nodeTypeCondition;
/** @type {?} */
NodeComponent.prototype.nodeTypeAnd;
/** @type {?} */
NodeComponent.prototype.nodeTypeOr;
/** @type {?} */
NodeComponent.prototype.nodeTypeUnknow;
/** @type {?} */
NodeComponent.prototype.nodeTypePlain;
/** @type {?} */
NodeComponent.prototype.data;
/** @type {?} */
NodeComponent.prototype.hostClass;
/** @type {?} */
NodeComponent.prototype.nodeMain;
/**
* @type {?}
* @private
*/
NodeComponent.prototype.lblSvr;
/**
* @type {?}
* @private
*/
NodeComponent.prototype.ref;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node.component.js","sourceRoot":"ng://dbweb-common/","sources":["lib/components/label-manager/edit-label/node/node.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostBinding, Input, OnInit, ViewChild, ElementRef, AfterViewInit } from '@angular/core';\r\nimport { NodeTypeEnum } from '../../../../services/eleview/types/model';\r\nimport { Node } from '../../../../services/eleview/types/node';\r\nimport { EditLabelService } from '../edit-label.service';\r\n\r\n@Component({\r\n\tselector: 'common-node',\r\n\ttemplateUrl: './node.component.html',\r\n\tstyleUrls: ['./node.component.scss']\r\n})\r\nexport class NodeComponent implements OnInit {\r\n\treadonly nodeTypeCondition = NodeTypeEnum.NodeCondition;\r\n\treadonly nodeTypeAnd = NodeTypeEnum.NodeAnd;\r\n\treadonly nodeTypeOr = NodeTypeEnum.NodeOr;\r\n\treadonly nodeTypeUnknow = NodeTypeEnum.unknow;\r\n\treadonly nodeTypePlain = NodeTypeEnum.NodePlain;\r\n\t@Input() data: Node;\r\n\t@HostBinding('class.node') hostClass = true;\r\n\t@ViewChild('nodeMain', { static: true })\r\n\tnodeMain: ElementRef;\r\n\tconstructor(private lblSvr: EditLabelService, private ref: ElementRef) {}\r\n\tngOnInit() {}\r\n\tsvgHeight(): number {\r\n\t\treturn this.data.flatHeight() * 50;\r\n\t}\r\n\tnodeDragover(event: DragEvent) {\r\n\t\t// 判断如果是节点\r\n\t\tif (this.data.NodeType === this.nodeTypeAnd || this.data.NodeType === this.nodeTypeOr) {\r\n\t\t\tevent.preventDefault();\r\n\t\t\tconst rect = (this.ref.nativeElement as Element).getBoundingClientRect();\r\n\t\t\tconst offsetY = event.pageY - rect.top;\r\n\t\t\tconst clientHeight = rect.height;\r\n\t\t\tif (this.lblSvr.dragOverNode !== this.data && this.lblSvr.prevNodeEle) {\r\n\t\t\t\tconst ref = this.lblSvr.prevNodeEle.nativeElement as HTMLElement;\r\n\t\t\t\tref.style.borderTop = '4px solid transparent';\r\n\t\t\t\tref.style.borderBottom = '4px solid transparent';\r\n\t\t\t\tref.style.backgroundColor = null;\r\n\t\t\t}\r\n\t\t\t// Handle drag area\r\n\t\t\tconst percentageY = offsetY / clientHeight;\r\n\t\t\tif (percentageY < 0.5) {\r\n\t\t\t\t(this.nodeMain.nativeElement as HTMLElement).style.borderTop = '4px solid #67c204';\r\n\t\t\t\t(this.nodeMain.nativeElement as HTMLElement).style.borderBottom = '4px solid transparent';\r\n\t\t\t\tthis.lblSvr.dragOverArea = 'above';\r\n\t\t\t} else if (percentageY >= 0.5) {\r\n\t\t\t\t(this.nodeMain.nativeElement as HTMLElement).style.borderTop = '4px solid transparent';\r\n\t\t\t\t(this.nodeMain.nativeElement as HTMLElement).style.borderBottom = '4px solid #67c204';\r\n\t\t\t\tthis.lblSvr.dragOverArea = 'below';\r\n\t\t\t}\r\n\t\t\tthis.lblSvr.dragOverNode = this.data;\r\n\t\t\tthis.lblSvr.prevNodeEle = this.nodeMain;\r\n\t\t}\r\n\t\tevent.stopPropagation();\r\n\t}\r\n\t// 把拖动的node放到节点上边\r\n\tdropTop(event: DragEvent) {\r\n\t\tif (this.data.parent) {\r\n\t\t\tthis.data.addTopSibling(this.lblSvr.buildDragedNode());\r\n\t\t\tif (this.lblSvr.dragData.Type === 'node') {\r\n\t\t\t\t(this.lblSvr.dragData.Data as Node).remove();\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\tthis.data.Children[0].addTopSibling(this.lblSvr.buildDragedNode());\r\n\t\t\tif (this.lblSvr.dragData.Type === 'node') {\r\n\t\t\t\t(this.lblSvr.dragData.Data as Node).remove();\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\t// 把拖动的node放到节点下边\r\n\tdropBottom(event: DragEvent) {\r\n\t\tthis.data.addBottomSibling(this.lblSvr.buildDragedNode());\r\n\t\tif (this.lblSvr.dragData.Type === 'node') {\r\n\t\t\t(this.lblSvr.dragData.Data as Node).remove();\r\n\t\t}\r\n\t}\r\n\tnodeDrop(event: DragEvent) {\r\n\t\tif (this.data.NodeType === this.nodeTypeAnd || this.data.NodeType === this.nodeTypeOr) {\r\n\t\t\tswitch (this.lblSvr.dragOverArea) {\r\n\t\t\t\tcase 'above':\r\n\t\t\t\t\tthis.dropTop(event);\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase 'below':\r\n\t\t\t\t\tthis.dropBottom(event);\r\n\t\t\t\t\tbreak;\r\n\t\t\t}\r\n\t\t\tthis.lblSvr.onNodeChange.emit();\r\n\t\t\tthis.lblSvr.dragOverNode = null;\r\n\t\t\tif (this.lblSvr.prevNodeEle) {\r\n\t\t\t\tconst ref = this.lblSvr.prevNodeEle.nativeElement as HTMLElement;\r\n\t\t\t\tref.style.borderTop = '4px solid transparent';\r\n\t\t\t\tref.style.borderBottom = '4px solid transparent';\r\n\t\t\t\tref.style.backgroundColor = null;\r\n\t\t\t}\r\n\t\t}\r\n\t\tevent.stopPropagation();\r\n\t}\r\n\tdrop(event: DragEvent) {\r\n\t\tif (this.data.NodeType === this.nodeTypeUnknow) {\r\n\t\t\tthis.data.assign(this.lblSvr.buildDragedNode());\r\n\t\t\tthis.lblSvr.onNodeChange.emit();\r\n\t\t}\r\n\t}\r\n\tlogicClick() {\r\n\t\tif (this.data.NodeType === NodeTypeEnum.NodeAnd) {\r\n\t\t\tthis.data.NodeType = NodeTypeEnum.NodeOr;\r\n\t\t} else {\r\n\t\t\tthis.data.NodeType = NodeTypeEnum.NodeAnd;\r\n\t\t}\r\n\t\tthis.lblSvr.onNodeChange.emit();\r\n\t}\r\n}\r\n"]}