dbweb-common
Version:
用`yarn add dbweb-common`安装,不要忘记修改`angular.json`里的 `architect\build\options\assets`,加上
230 lines • 24.7 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, ElementRef, HostBinding, Input, ViewChild } from '@angular/core';
import { NodeTypeEnum } from '../../../../../services/eleview/types/model';
import { Node } from '../../../../../services/eleview/types/node';
import { Operates } from '../../../../../services/eleview/types/operate';
import { EditLabelService } from '../../edit-label.service';
var ConditionNodeComponent = /** @class */ (function () {
function ConditionNodeComponent(lblSvr, ref) {
this.lblSvr = lblSvr;
this.ref = ref;
this.Operates = Operates;
this.nodeTypeCondition = NodeTypeEnum.NodeCondition;
this.hostClass = true;
}
/**
* @return {?}
*/
ConditionNodeComponent.prototype.ngAfterViewInit = /**
* @return {?}
*/
function () {
var _this = this;
this.dvMain.nativeElement.ondragover = (/**
* @param {?} event
* @return {?}
*/
function (event) {
// 不能自己拖到自己
if (_this.lblSvr.dragData &&
_this.lblSvr.dragData.Type === 'node' &&
((/** @type {?} */ (_this.lblSvr.dragData.Data))) === _this.data) {
return;
}
event.preventDefault();
/** @type {?} */
var rect = ((/** @type {?} */ (_this.ref.nativeElement))).getBoundingClientRect();
/** @type {?} */
var offsetY = event.pageY - rect.top;
// const clientHeight = rect.height;
if (_this.lblSvr.dragOverNode !== _this.data && _this.lblSvr.prevNodeEle) {
/** @type {?} */
var 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
if (offsetY < 4) {
((/** @type {?} */ (_this.dvMain.nativeElement))).style.borderTop = '4px solid #67c204';
((/** @type {?} */ (_this.dvMain.nativeElement))).style.borderBottom = '4px solid transparent';
((/** @type {?} */ (_this.dvMain.nativeElement.childNodes[0]))).style.backgroundColor = null;
_this.lblSvr.dragOverArea = 'above';
}
else if (offsetY > 40) {
((/** @type {?} */ (_this.dvMain.nativeElement))).style.borderTop = '4px solid transparent';
((/** @type {?} */ (_this.dvMain.nativeElement.childNodes[0]))).style.backgroundColor = null;
((/** @type {?} */ (_this.dvMain.nativeElement))).style.borderBottom = '4px solid #67c204';
_this.lblSvr.dragOverArea = 'below';
}
else {
((/** @type {?} */ (_this.dvMain.nativeElement))).style.borderTop = '4px solid transparent';
((/** @type {?} */ (_this.dvMain.nativeElement))).style.borderBottom = '4px solid transparent';
((/** @type {?} */ (_this.dvMain.nativeElement.childNodes[0]))).style.backgroundColor = '#67c204';
_this.lblSvr.dragOverArea = 'center';
}
_this.lblSvr.dragOverNode = _this.data;
_this.lblSvr.prevNodeEle = _this.dvMain;
event.stopPropagation();
});
};
/**
* @return {?}
*/
ConditionNodeComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () { };
/**
* @param {?} event
* @return {?}
*/
ConditionNodeComponent.prototype.dropTop = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.data.addTopSibling(this.lblSvr.buildDragedNode());
if (this.lblSvr.dragData.Type === 'node') {
((/** @type {?} */ (this.lblSvr.dragData.Data))).remove();
}
};
/**
* @param {?} event
* @return {?}
*/
ConditionNodeComponent.prototype.dropBottom = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.data.addBottomSibling(this.lblSvr.buildDragedNode());
if (this.lblSvr.dragData.Type === 'node') {
((/** @type {?} */ (this.lblSvr.dragData.Data))).remove();
}
};
/**
* @param {?} event
* @return {?}
*/
ConditionNodeComponent.prototype.dropRight = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.data.addChildSibling(this.lblSvr.buildDragedNode());
if (this.lblSvr.dragData.Type === 'node') {
((/** @type {?} */ (this.lblSvr.dragData.Data))).remove();
}
};
/**
* @param {?} event
* @return {?}
*/
ConditionNodeComponent.prototype.drop = /**
* @param {?} event
* @return {?}
*/
function (event) {
switch (this.lblSvr.dragOverArea) {
case 'above':
this.dropTop(event);
break;
case 'below':
this.dropBottom(event);
break;
case 'center':
this.dropRight(event);
break;
}
this.lblSvr.onNodeChange.emit();
this.lblSvr.dragOverNode = null;
if (this.lblSvr.prevNodeEle) {
/** @type {?} */
var 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 {?}
*/
ConditionNodeComponent.prototype.dragStart = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.lblSvr.dragData = { Type: 'node', Data: this.data };
};
/**
* @param {?} event
* @return {?}
*/
ConditionNodeComponent.prototype.dragover = /**
* @param {?} event
* @return {?}
*/
function (event) {
// console.log('dragend');
this.dvMain.nativeElement.style.borderTop = '4px solid transparent';
this.dvMain.nativeElement.style.borderBottom = '4px solid transparent';
this.dvMain.nativeElement.childNodes[0].style.backgroundColor = null;
};
/**
* @param {?} event
* @return {?}
*/
ConditionNodeComponent.prototype.delete = /**
* @param {?} event
* @return {?}
*/
function (event) {
this.data.remove();
this.lblSvr.onNodeChange.emit();
};
ConditionNodeComponent.decorators = [
{ type: Component, args: [{
selector: 'common-condition-node',
template: "<div class=\"condition-main\" #main (drop)=\"drop($event)\" (dragstart)=\"dragStart($event)\" (dragleave)=\"dragover($event)\">\r\n\t<div class=\"main\" draggable=\"true\">\r\n\t\t<ng-container *ngIf=\"data.NodeType === nodeTypeCondition; else plaintext\">\r\n\t\t\t<div class=\"field\">\r\n\t\t\t\t{{ data.Field }}\r\n\t\t\t</div>\r\n\t\t\t<mat-form-field class=\"operate\" appearance=\"outline\">\r\n\t\t\t\t<mat-select [(value)]=\"data.Operate\" (valueChange)=\"lblSvr.onNodeChange.emit()\">\r\n\t\t\t\t\t<mat-option *ngFor=\"let ope of Operates\" [value]=\"ope.Name\">\r\n\t\t\t\t\t\t{{ ope.Label }}\r\n\t\t\t\t\t</mat-option>\r\n\t\t\t\t</mat-select>\r\n\t\t\t</mat-form-field>\r\n\t\t\t<mat-form-field class=\"value\" appearance=\"outline\">\r\n\t\t\t\t<input matInput placeholder=\"value\" [(ngModel)]=\"data.Value\" (change)=\"lblSvr.onNodeChange.emit()\" />\r\n\t\t\t</mat-form-field>\r\n\t\t\t<button class=\"\u5220\u9664\" mat-icon-button (click)=\"delete($event)\">\r\n\t\t\t\t<mat-icon svgIcon=\"outlined:delete\"></mat-icon>\r\n\t\t\t</button>\r\n\t\t</ng-container>\r\n\t\t<ng-template #plaintext>\r\n\t\t\t<mat-form-field class=\"plaintext\" appearance=\"outline\">\r\n\t\t\t\t<textarea matInput placeholder=\"plaintext\" (change)=\"lblSvr.onNodeChange.emit()\"\r\n\t\t\t\t\t[(ngModel)]=\"data.PlainText\">\r\n\t\t\t</textarea>\r\n\t\t\t</mat-form-field>\r\n\t\t</ng-template>\r\n\t</div>\r\n</div>",
styles: ["@charset \"UTF-8\";.condition-main{width:440px;border-top:4px solid transparent;border-bottom:4px solid transparent;margin:-4px 0}.main{display:flex;width:408px;height:40px;border-radius:4px;box-shadow:0 2px 2px 0 rgba(0,0,0,.14),0 3px 1px -2px rgba(0,0,0,.12),0 1px 5px 0 rgba(0,0,0,.2);margin:4px 32px 4px 4px}.main .\u5220\u9664{width:32px;height:40px;line-height:40px;text-align:left;display:none}.main:hover{width:440px;margin:4px 0 4px 4px}.main:hover .\u5220\u9664{display:block}.field{width:152px;height:40px;line-height:40px;box-sizing:border-box;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 8px}.operate,.plaintext,.value{font-size:14px}.operate ::ng-deep .mat-form-field-wrapper,.plaintext ::ng-deep .mat-form-field-wrapper,.value ::ng-deep .mat-form-field-wrapper{padding:0}.operate ::ng-deep .mat-form-field-infix,.plaintext ::ng-deep .mat-form-field-infix,.value ::ng-deep .mat-form-field-infix{border:0;padding:11px 0}.operate ::ng-deep .mat-select-arrow-wrapper,.plaintext ::ng-deep .mat-select-arrow-wrapper,.value ::ng-deep .mat-select-arrow-wrapper{-webkit-transform:translateY(0);transform:translateY(0)}.operate{width:96px}.value{width:160px;margin:0 8px}.plaintext{width:100%}.drop-above{border-top:1px solid red}.drop-below{border-bottom:1px solid red}.drop-center{background-color:#ddd}"]
}] }
];
/** @nocollapse */
ConditionNodeComponent.ctorParameters = function () { return [
{ type: EditLabelService },
{ type: ElementRef }
]; };
ConditionNodeComponent.propDecorators = {
dvMain: [{ type: ViewChild, args: ['main', { static: false },] }],
data: [{ type: Input }],
hostClass: [{ type: HostBinding, args: ['class.condition-node',] }]
};
return ConditionNodeComponent;
}());
export { ConditionNodeComponent };
if (false) {
/** @type {?} */
ConditionNodeComponent.prototype.Operates;
/** @type {?} */
ConditionNodeComponent.prototype.nodeTypeCondition;
/** @type {?} */
ConditionNodeComponent.prototype.dvMain;
/** @type {?} */
ConditionNodeComponent.prototype.data;
/** @type {?} */
ConditionNodeComponent.prototype.hostClass;
/** @type {?} */
ConditionNodeComponent.prototype.lblSvr;
/**
* @type {?}
* @private
*/
ConditionNodeComponent.prototype.ref;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"condition-node.component.js","sourceRoot":"ng://dbweb-common/","sources":["lib/components/label-manager/edit-label/node/condition-node/condition-node.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, HostBinding, Input, OnInit, ViewChild } from '@angular/core';\r\nimport { NodeTypeEnum } from '../../../../../services/eleview/types/model';\r\nimport { Node } from '../../../../../services/eleview/types/node';\r\nimport { Operates } from '../../../../../services/eleview/types/operate';\r\nimport { EditLabelService } from '../../edit-label.service';\r\n\r\n@Component({\r\n\tselector: 'common-condition-node',\r\n\ttemplateUrl: './condition-node.component.html',\r\n\tstyleUrls: ['./condition-node.component.scss']\r\n})\r\nexport class ConditionNodeComponent implements OnInit, AfterViewInit {\r\n\treadonly Operates = Operates;\r\n\treadonly nodeTypeCondition = NodeTypeEnum.NodeCondition;\r\n\t@ViewChild('main', { static: false })\r\n\tdvMain: ElementRef;\r\n\t@Input() data: Node;\r\n\t@HostBinding('class.condition-node') hostClass = true;\r\n\tconstructor(public lblSvr: EditLabelService, private ref: ElementRef) {}\r\n\tngAfterViewInit() {\r\n\t\tthis.dvMain.nativeElement.ondragover = (event: DragEvent) => {\r\n\t\t\t// 不能自己拖到自己\r\n\t\t\tif (\r\n\t\t\t\tthis.lblSvr.dragData &&\r\n\t\t\t\tthis.lblSvr.dragData.Type === 'node' &&\r\n\t\t\t\t(this.lblSvr.dragData.Data as Node) === this.data\r\n\t\t\t) {\r\n\t\t\t\treturn;\r\n\t\t\t}\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\t// const 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\tif (offsetY < 4) {\r\n\t\t\t\t(this.dvMain.nativeElement as HTMLElement).style.borderTop = '4px solid #67c204';\r\n\t\t\t\t(this.dvMain.nativeElement as HTMLElement).style.borderBottom = '4px solid transparent';\r\n\t\t\t\t(this.dvMain.nativeElement.childNodes[0] as HTMLElement).style.backgroundColor = null;\r\n\t\t\t\tthis.lblSvr.dragOverArea = 'above';\r\n\t\t\t} else if (offsetY > 40) {\r\n\t\t\t\t(this.dvMain.nativeElement as HTMLElement).style.borderTop = '4px solid transparent';\r\n\t\t\t\t(this.dvMain.nativeElement.childNodes[0] as HTMLElement).style.backgroundColor = null;\r\n\t\t\t\t(this.dvMain.nativeElement as HTMLElement).style.borderBottom = '4px solid #67c204';\r\n\t\t\t\tthis.lblSvr.dragOverArea = 'below';\r\n\t\t\t} else {\r\n\t\t\t\t(this.dvMain.nativeElement as HTMLElement).style.borderTop = '4px solid transparent';\r\n\t\t\t\t(this.dvMain.nativeElement as HTMLElement).style.borderBottom = '4px solid transparent';\r\n\t\t\t\t(this.dvMain.nativeElement.childNodes[0] as HTMLElement).style.backgroundColor = '#67c204';\r\n\t\t\t\tthis.lblSvr.dragOverArea = 'center';\r\n\t\t\t}\r\n\t\t\tthis.lblSvr.dragOverNode = this.data;\r\n\t\t\tthis.lblSvr.prevNodeEle = this.dvMain;\r\n\t\t\tevent.stopPropagation();\r\n\t\t};\r\n\t}\r\n\tngOnInit() {}\r\n\tdropTop(event: DragEvent) {\r\n\t\tthis.data.addTopSibling(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\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\tdropRight(event: DragEvent) {\r\n\t\tthis.data.addChildSibling(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\tdrop(event: DragEvent) {\r\n\t\tswitch (this.lblSvr.dragOverArea) {\r\n\t\t\tcase 'above':\r\n\t\t\t\tthis.dropTop(event);\r\n\t\t\t\tbreak;\r\n\t\t\tcase 'below':\r\n\t\t\t\tthis.dropBottom(event);\r\n\t\t\t\tbreak;\r\n\t\t\tcase 'center':\r\n\t\t\t\tthis.dropRight(event);\r\n\t\t\t\tbreak;\r\n\t\t}\r\n\t\tthis.lblSvr.onNodeChange.emit();\r\n\t\tthis.lblSvr.dragOverNode = null;\r\n\t\tif (this.lblSvr.prevNodeEle) {\r\n\t\t\tconst ref = this.lblSvr.prevNodeEle.nativeElement as HTMLElement;\r\n\t\t\tref.style.borderTop = '4px solid transparent';\r\n\t\t\tref.style.borderBottom = '4px solid transparent';\r\n\t\t\tref.style.backgroundColor = null;\r\n\t\t}\r\n\t\tevent.stopPropagation();\r\n\t}\r\n\tdragStart(event: DragEvent) {\r\n\t\tthis.lblSvr.dragData = { Type: 'node', Data: this.data };\r\n\t}\r\n\tdragover(event: DragEvent) {\r\n\t\t// console.log('dragend');\r\n\t\tthis.dvMain.nativeElement.style.borderTop = '4px solid transparent';\r\n\t\tthis.dvMain.nativeElement.style.borderBottom = '4px solid transparent';\r\n\t\tthis.dvMain.nativeElement.childNodes[0].style.backgroundColor = null;\r\n\t}\r\n\tdelete(event: MouseEvent) {\r\n\t\tthis.data.remove();\r\n\t\tthis.lblSvr.onNodeChange.emit();\r\n\t}\r\n}\r\n"]}