dbweb-common
Version:
用`yarn add dbweb-common`安装,不要忘记修改`angular.json`里的 `architect\build\options\assets`,加上
392 lines • 38.8 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { CdkDropList, CdkDropListGroup } from '@angular/cdk/drag-drop';
import { ViewportRuler } from '@angular/cdk/overlay';
import { HttpErrorResponse } from '@angular/common/http';
import { ChangeDetectorRef, Component, HostBinding, Input, ViewChild } from '@angular/core';
import { MatDialog, MatSnackBar } from '@angular/material';
import { IsDuplicatePKError } from 'dbweb-core';
import { ConfirmDialogComponent } from '../../../components/confirm-dialog/confirm-dialog.component';
import { Category } from '../../../services/eleview/types/category';
import { EditCategoryDialogComponent } from '../edit-category-dialog/edit-category-dialog.component';
import { EditLabelComponent } from '../edit-label/edit-label.component';
import { LabelManagerService } from '../service/label-manager.service';
/**
* @record
*/
function Item() { }
if (false) {
/** @type {?} */
Item.prototype.CategoryID;
/** @type {?} */
Item.prototype.ID;
/** @type {?} */
Item.prototype.Name;
}
export class CategoryComponent {
/**
* @param {?} svr
* @param {?} dialog
* @param {?} snackBar
* @param {?} viewportRuler
* @param {?} cd
*/
constructor(svr, dialog, snackBar, viewportRuler, cd) {
this.svr = svr;
this.dialog = dialog;
this.snackBar = snackBar;
this.viewportRuler = viewportRuler;
this.cd = cd;
this.hostClass = true;
this.source = null;
this.dropListEnterPredicate = (/**
* @param {?} drag
* @param {?} drop
* @return {?}
*/
(drag, drop) => {
if (drop === this.placeholder) {
return true;
}
if (drop !== this.activeContainer) {
return false;
}
/** @type {?} */
const phElement = this.placeholder.element.nativeElement;
/** @type {?} */
const sourceElement = drag.dropContainer.element.nativeElement;
/** @type {?} */
const dropElement = drop.element.nativeElement;
/** @type {?} */
const dragIndex = this.indexOfNum(dropElement.parentElement.children, this.source ? phElement : sourceElement);
/** @type {?} */
const dropIndex = this.indexOfNum(dropElement.parentElement.children, dropElement);
if (!this.source) {
this.sourceIndex = dragIndex;
this.source = drag.dropContainer;
phElement.style.width = sourceElement.clientWidth + 'px';
phElement.style.height = sourceElement.clientHeight + 'px';
sourceElement.parentElement.removeChild(sourceElement);
}
this.targetIndex = dropIndex;
this.target = drop;
phElement.style.display = '';
dropElement.parentElement.insertBefore(phElement, dropIndex > dragIndex ? dropElement.nextSibling : dropElement);
this.placeholder.enter(drag, drag.element.nativeElement.offsetLeft, drag.element.nativeElement.offsetTop);
return false;
// tslint:disable-next-line:semicolon
});
}
/**
* @return {?}
*/
ngOnInit() { }
/**
* @return {?}
*/
ngAfterViewInit() {
/** @type {?} */
const phElement = this.placeholder.element.nativeElement;
phElement.style.display = 'none';
phElement.parentElement.removeChild(phElement);
}
/**
* @return {?}
*/
add() {
this.svr.editLabel.add(this.category.ID);
this.dialog.open(EditLabelComponent, {
width: '800px',
height: '100%',
minWidth: '800px',
data: this.svr,
position: {
top: '0px',
right: '0px'
}
});
}
/**
* @return {?}
*/
addCategoryClick() {
/** @type {?} */
const dialogRef = this.dialog.open(EditCategoryDialogComponent, {
width: '360px',
height: '224px',
data: {
name: '新的类别',
title: '增加新的类别'
}
});
dialogRef.afterClosed().subscribe((/**
* @param {?} result
* @return {?}
*/
(result) => {
if (result) {
this.svr
.addCategory({ name: result.name, beforeAtID: this.category.ID })
.subscribe((/**
* @return {?}
*/
() => { }), this.errProcess());
}
}));
}
/**
* @private
* @return {?}
*/
errProcess() {
return (/**
* @param {?} err
* @return {?}
*/
err => {
if (err instanceof HttpErrorResponse) {
/** @type {?} */
const derr = IsDuplicatePKError(err.error);
if (derr.Yes) {
this.snackBar.open('名称重复', '关闭', { duration: 5000 });
}
else {
this.snackBar.open(err.error, '关闭', { duration: 5000 });
}
}
else {
this.snackBar.open(err, '关闭', { duration: 5000 });
}
});
}
/**
* @return {?}
*/
editCategoryClick() {
/** @type {?} */
const dialogRef = this.dialog.open(EditCategoryDialogComponent, {
width: '360px',
height: '224px',
data: {
name: this.category.Name,
title: '修改类别'
}
});
dialogRef.afterClosed().subscribe((/**
* @param {?} result
* @return {?}
*/
(result) => {
if (result) {
this.svr
.editCategory({ name: result.name, id: this.category.ID })
.subscribe((/**
* @return {?}
*/
() => { }), this.errProcess());
}
}));
}
/**
* @return {?}
*/
up() {
this.svr.setCategoryPosition(this.category, this.category.Position - 1);
}
/**
* @return {?}
*/
down() {
this.svr.setCategoryPosition(this.category, this.category.Position + 1);
}
/**
* @return {?}
*/
delete() {
/** @type {?} */
const dialogRef = this.dialog.open(ConfirmDialogComponent, {
width: '360px',
height: '224px',
data: `确定要删除类别[${this.category.Name}]及其所有的标签吗?`
});
dialogRef.afterClosed().subscribe((/**
* @param {?} result
* @return {?}
*/
(result) => {
if (result) {
this.svr.removeCategory(this.category.ID).subscribe((/**
* @return {?}
*/
() => { }), this.errProcess());
}
}));
}
/**
* @param {?} e
* @return {?}
*/
dragMoved(e) {
/** @type {?} */
const point = this.getPointerPositionOnPage(e.event);
this.listGroup._items.forEach((/**
* @param {?} dropList
* @return {?}
*/
dropList => {
if (__isInsideDropListClientRect(dropList, point.x, point.y)) {
this.activeContainer = dropList;
return;
}
}));
}
/**
* @param {?} event
* @return {?}
*/
dropListDropped(event) {
if (!this.target) {
return;
}
/** @type {?} */
const phElement = this.placeholder.element.nativeElement;
/** @type {?} */
const parent = phElement.parentElement;
phElement.style.display = 'none';
parent.removeChild(phElement);
parent.appendChild(phElement);
parent.insertBefore(this.source.element.nativeElement, parent.children[this.sourceIndex]);
this.target = null;
this.source = null;
if (this.sourceIndex !== this.targetIndex && this.category.Labels) {
this.cd.detach();
// moveItemInArray(this.category.Labels, this.sourceIndex, this.targetIndex);
this.svr.backface
.setLabelPosition({
CategoryID: this.category.ID,
ID: this.category.Labels[this.sourceIndex].ID,
Position: this.targetIndex
})
.subscribe((/**
* @param {?} v
* @return {?}
*/
v => {
this.category.setLabelsPosition(v.map((/**
* @param {?} vv
* @return {?}
*/
vv => vv.ID)));
this.cd.reattach();
}), this.errProcess());
}
}
/**
* @param {?} event
* @return {?}
*/
getPointerPositionOnPage(event) {
// `touches` will be empty for start/end events so we have to fall back to `changedTouches`.
/** @type {?} */
const point = __isTouchEvent(event) ? event.touches[0] || event.changedTouches[0] : event;
/** @type {?} */
const scrollPosition = this.viewportRuler.getViewportScrollPosition();
return {
x: point.pageX - scrollPosition.left,
y: point.pageY - scrollPosition.top
};
}
/**
* @param {?} collection
* @param {?} node
* @return {?}
*/
indexOfNum(collection, node) {
return Array.prototype.indexOf.call(collection, node);
}
}
CategoryComponent.decorators = [
{ type: Component, args: [{
selector: 'common-label-category',
template: "<div class=\"title\">\r\n\t<ng-content></ng-content>\r\n\t<span>\r\n\t\t<span class=\"title-name\">{{ category?.displayLabel() }}</span></span\r\n\t>\r\n\t<span>\r\n\t\t<button mat-icon-button (click)=\"editCategoryClick()\">\r\n\t\t\t<mat-icon class=\"\u7C7B\u522B\u529F\u80FD\u56FE\u6807\" svgIcon=\"outlined:edit\"></mat-icon>\r\n\t\t</button>\r\n\t\t<button mat-icon-button (click)=\"delete()\">\r\n\t\t\t<mat-icon class=\"\u7C7B\u522B\u529F\u80FD\u56FE\u6807\" svgIcon=\"outlined:delete\"></mat-icon>\r\n\t\t</button>\r\n\t\t<div class=\"\u5206\u5272\u7EBF\"></div>\r\n\t\t<button mat-icon-button (click)=\"up()\" *ngIf=\"category.Position > 1\">\r\n\t\t\t<mat-icon class=\"\u7C7B\u522B\u529F\u80FD\u56FE\u6807 \u7C7B\u522B\u529F\u80FD\u9AD8\u4EAE\u56FE\u6807\" svgIcon=\"arrow_upward\"></mat-icon>\r\n\t\t</button>\r\n\t\t<button mat-icon-button (click)=\"down()\" *ngIf=\"svr.categorys[svr.categorys.length - 1] !== category\">\r\n\t\t\t<mat-icon class=\"\u7C7B\u522B\u529F\u80FD\u56FE\u6807 \u7C7B\u522B\u529F\u80FD\u9AD8\u4EAE\u56FE\u6807\" svgIcon=\"arrow_downward\"></mat-icon>\r\n\t\t</button>\r\n\r\n\t\t<button mat-icon-button (click)=\"addCategoryClick()\">\r\n\t\t\t<mat-icon class=\"\u7C7B\u522B\u529F\u80FD\u56FE\u6807 \u7C7B\u522B\u529F\u80FD\u9AD8\u4EAE\u56FE\u6807\" svgIcon=\"outlined:add\"></mat-icon>\r\n\t\t</button>\r\n\t</span>\r\n</div>\r\n<div class=\"example-container\" cdkDropListGroup>\r\n\t<div\r\n\t\tcdkDropList\r\n\t\t[cdkDropListEnterPredicate]=\"dropListEnterPredicate\"\r\n\t\t(cdkDropListDropped)=\"dropListDropped($event)\"\r\n\t></div>\r\n\t<div\r\n\t\tcdkDropList\r\n\t\t*ngFor=\"let label of category?.Labels\"\r\n\t\t[cdkDropListEnterPredicate]=\"dropListEnterPredicate\"\r\n\t\t(cdkDropListDropped)=\"dropListDropped($event)\"\r\n\t>\r\n\t\t<common-label-for-edit\r\n\t\t\t[label]=\"label\"\r\n\t\t\t[categoryID]=\"category?.ID\"\r\n\t\t\tcdkDrag\r\n\t\t\tclass=\"example-box \u5355\u4E2A\u6807\u7B7E\"\r\n\t\t\t(cdkDragMoved)=\"dragMoved($event)\"\r\n\t\t>\r\n\t\t\t<mat-icon cdkDragHandle class=\"\u62D6\u52A8\u56FE\u6807\" svgIcon=\"drag_indicator\"> </mat-icon>\r\n\t\t</common-label-for-edit>\r\n\t</div>\r\n\t<span class=\"\u6807\u7B7E \u6DFB\u52A0\u6807\u7B7E\" (click)=\"add()\">\r\n\t\t<mat-icon class=\"\u6DFB\u52A0\u56FE\u6807\" svgIcon=\"add\"></mat-icon>\r\n\t</span>\r\n</div>\r\n",
styles: ["@charset \"UTF-8\";:host:hover .title{padding-left:32px;box-sizing:border-box}:host:hover .title .title-name{font-size:14px;font-weight:700}:host:hover .title .\u5206\u5272\u7EBF,:host:hover .title .\u7C7B\u522B\u529F\u80FD\u56FE\u6807{display:inline-block}.title{height:64px;padding:16px 0 16px 8px;box-sizing:border-box;display:flex;justify-content:space-between;align-items:center}.title .title-name{font-size:12px}.title button{width:32px;height:32px;line-height:32px}.title .\u7C7B\u522B\u529F\u80FD\u56FE\u6807{width:24px;height:24px;line-height:24px;cursor:pointer;display:none}.title .\u5206\u5272\u7EBF{width:1px;height:24px;vertical-align:middle;display:none}.\u6807\u7B7E{font-size:14px;display:inline-block;margin:0 16px 8px 0;height:34px;padding:0 24px;border-radius:4px;line-height:34px;cursor:pointer;position:relative}.\u6807\u7B7E:hover .\u67E5\u770B\u6309\u94AE{display:block}.\u5355\u4E2A\u6807\u7B7E{height:34px;border-radius:4px;line-height:34px;margin:0 16px 16px 0;cursor:pointer}.\u5355\u4E2A\u6807\u7B7E .\u62D6\u52A8\u56FE\u6807{width:16px;height:16px;line-height:16px;position:absolute;left:0;top:50%;-webkit-transform:translateY(-50%);transform:translateY(-50%);display:none}.\u5355\u4E2A\u6807\u7B7E:hover .\u62D6\u52A8\u56FE\u6807{display:block}.\u6DFB\u52A0\u6807\u7B7E{width:40px;padding:0 8px;text-align:center;vertical-align:top}.\u6DFB\u52A0\u56FE\u6807{padding:5px 0;width:24px;height:24px;line-height:24px}.\u67E5\u770B\u6309\u94AE{width:16px;height:16px;line-height:16px;position:absolute;right:0;top:0;display:none}.example-container{padding-left:24px;display:flex;flex-wrap:wrap}.example-box{min-width:50px;position:relative;z-index:1;box-shadow:none}.example-box:last-child{border:0}.cdk-drop-list{display:flex}.cdk-drag-preview{box-sizing:border-box;border-radius:4px}.cdk-drag-placeholder{opacity:.3}.cdk-drag-animating{transition:transform 250ms cubic-bezier(0,0,.2,1);transition:transform 250ms cubic-bezier(0,0,.2,1),-webkit-transform 250ms cubic-bezier(0,0,.2,1)}"]
}] }
];
/** @nocollapse */
CategoryComponent.ctorParameters = () => [
{ type: LabelManagerService },
{ type: MatDialog },
{ type: MatSnackBar },
{ type: ViewportRuler },
{ type: ChangeDetectorRef }
];
CategoryComponent.propDecorators = {
category: [{ type: Input }],
hostClass: [{ type: HostBinding, args: ['class.label-category',] }],
listGroup: [{ type: ViewChild, args: [CdkDropListGroup, { static: true },] }],
placeholder: [{ type: ViewChild, args: [CdkDropList, { static: true },] }]
};
if (false) {
/** @type {?} */
CategoryComponent.prototype.category;
/** @type {?} */
CategoryComponent.prototype.hostClass;
/** @type {?} */
CategoryComponent.prototype.listGroup;
/** @type {?} */
CategoryComponent.prototype.placeholder;
/** @type {?} */
CategoryComponent.prototype.target;
/** @type {?} */
CategoryComponent.prototype.targetIndex;
/** @type {?} */
CategoryComponent.prototype.source;
/** @type {?} */
CategoryComponent.prototype.sourceIndex;
/** @type {?} */
CategoryComponent.prototype.dragIndex;
/** @type {?} */
CategoryComponent.prototype.activeContainer;
/** @type {?} */
CategoryComponent.prototype.dropListEnterPredicate;
/** @type {?} */
CategoryComponent.prototype.svr;
/** @type {?} */
CategoryComponent.prototype.dialog;
/**
* @type {?}
* @private
*/
CategoryComponent.prototype.snackBar;
/**
* @type {?}
* @private
*/
CategoryComponent.prototype.viewportRuler;
/**
* @type {?}
* @private
*/
CategoryComponent.prototype.cd;
}
/**
* Determines whether an event is a touch event.
* @param {?} event
* @return {?}
*/
function __isTouchEvent(event) {
return event.type.startsWith('touch');
}
/**
* @param {?} dropList
* @param {?} x
* @param {?} y
* @return {?}
*/
function __isInsideDropListClientRect(dropList, x, y) {
const { top, bottom, left, right } = dropList.element.nativeElement.getBoundingClientRect();
return y >= top && y <= bottom && x >= left && x <= right;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"label-category.component.js","sourceRoot":"ng://dbweb-common/","sources":["lib/components/label-manager/label-category/label-category.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CdkDrag, CdkDragDrop, CdkDragMove, CdkDropList, CdkDropListGroup } from '@angular/cdk/drag-drop';\r\nimport { ViewportRuler } from '@angular/cdk/overlay';\r\nimport { HttpErrorResponse } from '@angular/common/http';\r\nimport { AfterViewInit, ChangeDetectorRef, Component, HostBinding, Input, OnInit, ViewChild } from '@angular/core';\r\nimport { MatDialog, MatSnackBar } from '@angular/material';\r\nimport { IsDuplicatePKError } from 'dbweb-core';\r\nimport { ConfirmDialogComponent } from '../../../components/confirm-dialog/confirm-dialog.component';\r\nimport { Category } from '../../../services/eleview/types/category';\r\nimport { Label } from '../../../services/eleview/types/label';\r\nimport { DialogData, EditCategoryDialogComponent } from '../edit-category-dialog/edit-category-dialog.component';\r\nimport { EditLabelComponent } from '../edit-label/edit-label.component';\r\nimport { LabelManagerService } from '../service/label-manager.service';\r\ninterface Item {\r\n\tCategoryID: string;\r\n\tID: string;\r\n\tName: string;\r\n}\r\n@Component({\r\n\tselector: 'common-label-category',\r\n\ttemplateUrl: './label-category.component.html',\r\n\tstyleUrls: ['./label-category.component.scss']\r\n})\r\nexport class CategoryComponent implements OnInit, AfterViewInit {\r\n\t@Input() category: Category;\r\n\t@HostBinding('class.label-category') hostClass = true;\r\n\t@ViewChild(CdkDropListGroup, { static: true }) listGroup: CdkDropListGroup<CdkDropList>;\r\n\t@ViewChild(CdkDropList, { static: true }) placeholder: CdkDropList;\r\n\tpublic target: CdkDropList;\r\n\tpublic targetIndex: number;\r\n\tpublic source: CdkDropList = null;\r\n\tpublic sourceIndex: number;\r\n\tpublic dragIndex: number;\r\n\tpublic activeContainer: CdkDropList;\r\n\tconstructor(\r\n\t\tpublic svr: LabelManagerService,\r\n\t\tpublic dialog: MatDialog,\r\n\t\tprivate snackBar: MatSnackBar,\r\n\t\tprivate viewportRuler: ViewportRuler,\r\n\t\tprivate cd: ChangeDetectorRef\r\n\t) {}\r\n\tngOnInit() {}\r\n\r\n\tngAfterViewInit() {\r\n\t\tconst phElement = this.placeholder.element.nativeElement;\r\n\r\n\t\tphElement.style.display = 'none';\r\n\t\tphElement.parentElement.removeChild(phElement);\r\n\t}\r\n\tadd(): void {\r\n\t\tthis.svr.editLabel.add(this.category.ID);\r\n\t\tthis.dialog.open(EditLabelComponent, {\r\n\t\t\twidth: '800px',\r\n\t\t\theight: '100%',\r\n\t\t\tminWidth: '800px',\r\n\t\t\tdata: this.svr,\r\n\t\t\tposition: {\r\n\t\t\t\ttop: '0px',\r\n\t\t\t\tright: '0px'\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\taddCategoryClick(): void {\r\n\t\tconst dialogRef = this.dialog.open(EditCategoryDialogComponent, {\r\n\t\t\twidth: '360px',\r\n\t\t\theight: '224px',\r\n\t\t\tdata: {\r\n\t\t\t\tname: '新的类别',\r\n\t\t\t\ttitle: '增加新的类别'\r\n\t\t\t}\r\n\t\t});\r\n\r\n\t\tdialogRef.afterClosed().subscribe((result: DialogData) => {\r\n\t\t\tif (result) {\r\n\t\t\t\tthis.svr\r\n\t\t\t\t\t.addCategory({ name: result.name, beforeAtID: this.category.ID })\r\n\t\t\t\t\t.subscribe(() => {}, this.errProcess());\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\tprivate errProcess(): (error: any) => void {\r\n\t\treturn err => {\r\n\t\t\tif (err instanceof HttpErrorResponse) {\r\n\t\t\t\tconst derr = IsDuplicatePKError(err.error);\r\n\t\t\t\tif (derr.Yes) {\r\n\t\t\t\t\tthis.snackBar.open('名称重复', '关闭', { duration: 5000 });\r\n\t\t\t\t} else {\r\n\t\t\t\t\tthis.snackBar.open(err.error, '关闭', { duration: 5000 });\r\n\t\t\t\t}\r\n\t\t\t} else {\r\n\t\t\t\tthis.snackBar.open(err, '关闭', { duration: 5000 });\r\n\t\t\t}\r\n\t\t};\r\n\t}\r\n\r\n\teditCategoryClick(): void {\r\n\t\tconst dialogRef = this.dialog.open(EditCategoryDialogComponent, {\r\n\t\t\twidth: '360px',\r\n\t\t\theight: '224px',\r\n\t\t\tdata: {\r\n\t\t\t\tname: this.category.Name,\r\n\t\t\t\ttitle: '修改类别'\r\n\t\t\t}\r\n\t\t});\r\n\r\n\t\tdialogRef.afterClosed().subscribe((result: DialogData) => {\r\n\t\t\tif (result) {\r\n\t\t\t\tthis.svr\r\n\t\t\t\t\t.editCategory({ name: result.name, id: this.category.ID })\r\n\t\t\t\t\t.subscribe(() => {}, this.errProcess());\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\tup() {\r\n\t\tthis.svr.setCategoryPosition(this.category, this.category.Position - 1);\r\n\t}\r\n\tdown() {\r\n\t\tthis.svr.setCategoryPosition(this.category, this.category.Position + 1);\r\n\t}\r\n\tdelete() {\r\n\t\tconst dialogRef = this.dialog.open(ConfirmDialogComponent, {\r\n\t\t\twidth: '360px',\r\n\t\t\theight: '224px',\r\n\t\t\tdata: `确定要删除类别[${this.category.Name}]及其所有的标签吗？`\r\n\t\t});\r\n\r\n\t\tdialogRef.afterClosed().subscribe((result: boolean) => {\r\n\t\t\tif (result) {\r\n\t\t\t\tthis.svr.removeCategory(this.category.ID).subscribe(() => {}, this.errProcess());\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\tdragMoved(e: CdkDragMove) {\r\n\t\tconst point = this.getPointerPositionOnPage(e.event);\r\n\r\n\t\tthis.listGroup._items.forEach(dropList => {\r\n\t\t\tif (__isInsideDropListClientRect(dropList, point.x, point.y)) {\r\n\t\t\t\tthis.activeContainer = dropList;\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\r\n\tdropListDropped(event: CdkDragDrop<Label[]>) {\r\n\t\tif (!this.target) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tconst phElement = this.placeholder.element.nativeElement;\r\n\t\tconst parent = phElement.parentElement;\r\n\r\n\t\tphElement.style.display = 'none';\r\n\r\n\t\tparent.removeChild(phElement);\r\n\t\tparent.appendChild(phElement);\r\n\t\tparent.insertBefore(this.source.element.nativeElement, parent.children[this.sourceIndex]);\r\n\r\n\t\tthis.target = null;\r\n\t\tthis.source = null;\r\n\r\n\t\tif (this.sourceIndex !== this.targetIndex && this.category.Labels) {\r\n\t\t\tthis.cd.detach();\r\n\t\t\t// moveItemInArray(this.category.Labels, this.sourceIndex, this.targetIndex);\r\n\t\t\tthis.svr.backface\r\n\t\t\t\t.setLabelPosition({\r\n\t\t\t\t\tCategoryID: this.category.ID,\r\n\t\t\t\t\tID: this.category.Labels[this.sourceIndex].ID,\r\n\t\t\t\t\tPosition: this.targetIndex\r\n\t\t\t\t})\r\n\t\t\t\t.subscribe(v => {\r\n\t\t\t\t\tthis.category.setLabelsPosition(v.map(vv => vv.ID));\r\n\t\t\t\t\tthis.cd.reattach();\r\n\t\t\t\t}, this.errProcess());\r\n\t\t}\r\n\t}\r\n\r\n\tdropListEnterPredicate = (drag: CdkDrag, drop: CdkDropList) => {\r\n\t\tif (drop === this.placeholder) {\r\n\t\t\treturn true;\r\n\t\t}\r\n\t\tif (drop !== this.activeContainer) {\r\n\t\t\treturn false;\r\n\t\t}\r\n\t\tconst phElement = this.placeholder.element.nativeElement;\r\n\t\tconst sourceElement = drag.dropContainer.element.nativeElement;\r\n\t\tconst dropElement = drop.element.nativeElement;\r\n\t\tconst dragIndex = this.indexOfNum(dropElement.parentElement.children, this.source ? phElement : sourceElement);\r\n\t\tconst dropIndex = this.indexOfNum(dropElement.parentElement.children, dropElement);\r\n\r\n\t\tif (!this.source) {\r\n\t\t\tthis.sourceIndex = dragIndex;\r\n\t\t\tthis.source = drag.dropContainer;\r\n\r\n\t\t\tphElement.style.width = sourceElement.clientWidth + 'px';\r\n\t\t\tphElement.style.height = sourceElement.clientHeight + 'px';\r\n\r\n\t\t\tsourceElement.parentElement.removeChild(sourceElement);\r\n\t\t}\r\n\r\n\t\tthis.targetIndex = dropIndex;\r\n\t\tthis.target = drop;\r\n\r\n\t\tphElement.style.display = '';\r\n\t\tdropElement.parentElement.insertBefore(\r\n\t\t\tphElement,\r\n\t\t\tdropIndex > dragIndex ? dropElement.nextSibling : dropElement\r\n\t\t);\r\n\r\n\t\tthis.placeholder.enter(drag, drag.element.nativeElement.offsetLeft, drag.element.nativeElement.offsetTop);\r\n\t\treturn false;\r\n\t\t// tslint:disable-next-line:semicolon\r\n\t};\r\n\r\n\tgetPointerPositionOnPage(event: MouseEvent | TouchEvent) {\r\n\t\t// `touches` will be empty for start/end events so we have to fall back to `changedTouches`.\r\n\t\tconst point = __isTouchEvent(event) ? event.touches[0] || event.changedTouches[0] : event;\r\n\t\tconst scrollPosition = this.viewportRuler.getViewportScrollPosition();\r\n\r\n\t\treturn {\r\n\t\t\tx: point.pageX - scrollPosition.left,\r\n\t\t\ty: point.pageY - scrollPosition.top\r\n\t\t};\r\n\t}\r\n\tindexOfNum(collection, node) {\r\n\t\treturn Array.prototype.indexOf.call(collection, node);\r\n\t}\r\n}\r\n/** Determines whether an event is a touch event. */\r\nfunction __isTouchEvent(event: MouseEvent | TouchEvent): event is TouchEvent {\r\n\treturn event.type.startsWith('touch');\r\n}\r\n\r\nfunction __isInsideDropListClientRect(dropList: CdkDropList, x: number, y: number) {\r\n\tconst { top, bottom, left, right } = dropList.element.nativeElement.getBoundingClientRect();\r\n\treturn y >= top && y <= bottom && x >= left && x <= right;\r\n}\r\n"]}