@bixi/label
Version:
208 lines • 17.4 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { __read, __spread } from "tslib";
import { CdkConnectedOverlay } from '@angular/cdk/overlay';
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, Output, ViewChild, ViewEncapsulation } from '@angular/core';
import { DEFAULT_TOOLTIP_POSITIONS, POSITION_MAP } from 'ng-zorro-antd/core/overlay';
/** @type {?} */
var OVERLAY_WIDTH = 468;
/** @type {?} */
var OVERLAY_HEIGHT = 288;
var BixiLabelModalComponent = /** @class */ (function () {
function BixiLabelModalComponent(cdr) {
var _this = this;
this.cdr = cdr;
this.overlayWidth = OVERLAY_WIDTH;
this.overlayHeight = OVERLAY_HEIGHT;
this.placement = 'right';
this.isOpen = false;
this._labeling = null;
// tslint:disable-next-line: no-output-native
this.close = new EventEmitter();
this.onClose = (/**
* @return {?}
*/
function () {
_this.onHide();
_this.close.emit();
});
}
Object.defineProperty(BixiLabelModalComponent.prototype, "labeling", {
get: /**
* @return {?}
*/
function () {
return this._labeling;
},
set: /**
* @param {?} val
* @return {?}
*/
function (val) {
this._labeling = val;
if (val) {
this.onShow();
}
else {
this.onHide();
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(BixiLabelModalComponent.prototype, "labels", {
get: /**
* @return {?}
*/
function () {
return this.labeling ? (this.labeling.data) || [] : [];
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
BixiLabelModalComponent.prototype.onShow = /**
* @return {?}
*/
function () {
var _this = this;
if (this.isOpen && this.overlay) {
// 如果是二次标注的话,只需要调整位置就可以了
Promise.resolve().then((/**
* @return {?}
*/
function () {
_this.cdr.detectChanges();
_this.overlay.overlayRef.updatePosition();
}));
return;
}
this.isOpen = true;
this.cdr.detectChanges();
};
/**
* @return {?}
*/
BixiLabelModalComponent.prototype.onHide = /**
* @return {?}
*/
function () {
this.isOpen = false;
this.cdr.detectChanges();
};
/**
* @return {?}
*/
BixiLabelModalComponent.prototype.onDetach = /**
* @return {?}
*/
function () {
// 其它方式关闭的话,也触发一次 cancel
if (this.isOpen) {
this.onClose();
}
};
Object.defineProperty(BixiLabelModalComponent.prototype, "overlayStyle", {
get: /**
* @return {?}
*/
function () {
return {
width: (this.overlayWidth || 0) + "px",
height: (this.overlayHeight || 0) + "px"
};
},
enumerable: true,
configurable: true
});
Object.defineProperty(BixiLabelModalComponent.prototype, "positions", {
get: /**
* @return {?}
*/
function () {
return __spread([POSITION_MAP[this.placement]], DEFAULT_TOOLTIP_POSITIONS);
},
enumerable: true,
configurable: true
});
Object.defineProperty(BixiLabelModalComponent.prototype, "originStyle", {
get: /**
* @return {?}
*/
function () {
if (!this.labeling) {
return {
'width': '0px',
'height': '0px'
};
}
return {
position: 'absolute',
width: '20px',
height: '20px',
top: (this.labeling.position.top || 0) + "px",
left: (this.labeling.position.left || 0) + "px"
};
},
enumerable: true,
configurable: true
});
BixiLabelModalComponent.decorators = [
{ type: Component, args: [{
selector: 'bixi-label-modal',
template: "\n <div [ngStyle]=\"originStyle\" cdkOverlayOrigin #trigger=\"cdkOverlayOrigin\">\n </div>\n <ng-template\n #overlay=\"cdkConnectedOverlay\"\n cdkConnectedOverlayBackdropClass=\"bixi-label-modal-backdrop\"\n cdkConnectedOverlay\n [cdkConnectedOverlayOrigin]=\"trigger\"\n [cdkConnectedOverlayHasBackdrop]=\"true\"\n [cdkConnectedOverlayPositions]=\"positions\"\n [cdkConnectedOverlayOpen]=\"isOpen\"\n [cdkConnectedOverlayPush]=\"true\"\n [cdkConnectedOverlayMinHeight]=\"overlayHeight\"\n [cdkConnectedOverlayMinWidth]=\"overlayWidth\"\n [cdkConnectedOverlayOffsetX]=\"0\"\n [cdkConnectedOverlayOffsetY]=\"-10\"\n (backdropClick)=\"onClose()\"\n (detach)=\"onDetach()\"\n >\n <div class=\"bixi-label-modal\" [ngStyle]=\"overlayStyle\" cdkDrag [cdkDragBoundary]=\"dragBoundary || 'body'\">\n <div class=\"bixi-label-modal-header\" cdkDragHandle>\n <div class='bixi-label-modal-header-inner'>\n <div class=\"bixi-label-modal-title\">{{title}}</div>\n <div class=\"bixi-label-modal-close-icon\" (click)=\"onClose()\">\n <i nz-icon nzType=\"close\" nzTheme=\"outline\"></i>\n </div>\n </div>\n </div>\n <div class=\"bixi-label-modal-content\">\n <ng-template\n [ngTemplateOutlet]=\"content\"\n [ngTemplateOutletContext]=\"{$implicit: labeling, labeling: labeling, labels: labels, close: onClose }\">\n </ng-template>\n </div>\n </div>\n </ng-template>\n ",
exportAs: 'bixiLabelModal',
encapsulation: ViewEncapsulation.None,
preserveWhitespaces: true,
changeDetection: ChangeDetectionStrategy.OnPush
}] }
];
/** @nocollapse */
BixiLabelModalComponent.ctorParameters = function () { return [
{ type: ChangeDetectorRef }
]; };
BixiLabelModalComponent.propDecorators = {
overlay: [{ type: ViewChild, args: ['overlay', { static: false },] }],
content: [{ type: Input }],
title: [{ type: Input }],
dragBoundary: [{ type: Input }],
labeling: [{ type: Input }],
close: [{ type: Output }]
};
return BixiLabelModalComponent;
}());
export { BixiLabelModalComponent };
if (false) {
/** @type {?} */
BixiLabelModalComponent.prototype.overlayWidth;
/** @type {?} */
BixiLabelModalComponent.prototype.overlayHeight;
/** @type {?} */
BixiLabelModalComponent.prototype.placement;
/** @type {?} */
BixiLabelModalComponent.prototype.isOpen;
/** @type {?} */
BixiLabelModalComponent.prototype._labeling;
/** @type {?} */
BixiLabelModalComponent.prototype.overlay;
/** @type {?} */
BixiLabelModalComponent.prototype.content;
/** @type {?} */
BixiLabelModalComponent.prototype.title;
/** @type {?} */
BixiLabelModalComponent.prototype.dragBoundary;
/** @type {?} */
BixiLabelModalComponent.prototype.close;
/** @type {?} */
BixiLabelModalComponent.prototype.onClose;
/**
* @type {?}
* @private
*/
BixiLabelModalComponent.prototype.cdr;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"label-modal.component.js","sourceRoot":"ng://@bixi/label/","sources":["src/label-modal.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CdkConnectedOverlay } from '@angular/cdk/overlay';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport { DEFAULT_TOOLTIP_POSITIONS, POSITION_MAP } from 'ng-zorro-antd/core/overlay';\nimport { ILabelingEvent, ISafeAny } from './label.type';\n\nconst OVERLAY_WIDTH = 468;\nconst OVERLAY_HEIGHT = 288;\n\n@Component({\n  selector: 'bixi-label-modal',\n  template: `\n  <div [ngStyle]=\"originStyle\" cdkOverlayOrigin #trigger=\"cdkOverlayOrigin\">\n  </div>\n  <ng-template\n    #overlay=\"cdkConnectedOverlay\"\n    cdkConnectedOverlayBackdropClass=\"bixi-label-modal-backdrop\"\n    cdkConnectedOverlay\n    [cdkConnectedOverlayOrigin]=\"trigger\"\n    [cdkConnectedOverlayHasBackdrop]=\"true\"\n    [cdkConnectedOverlayPositions]=\"positions\"\n    [cdkConnectedOverlayOpen]=\"isOpen\"\n    [cdkConnectedOverlayPush]=\"true\"\n    [cdkConnectedOverlayMinHeight]=\"overlayHeight\"\n    [cdkConnectedOverlayMinWidth]=\"overlayWidth\"\n    [cdkConnectedOverlayOffsetX]=\"0\"\n    [cdkConnectedOverlayOffsetY]=\"-10\"\n    (backdropClick)=\"onClose()\"\n    (detach)=\"onDetach()\"\n  >\n    <div class=\"bixi-label-modal\" [ngStyle]=\"overlayStyle\"  cdkDrag [cdkDragBoundary]=\"dragBoundary || 'body'\">\n      <div class=\"bixi-label-modal-header\" cdkDragHandle>\n        <div class='bixi-label-modal-header-inner'>\n          <div  class=\"bixi-label-modal-title\">{{title}}</div>\n          <div class=\"bixi-label-modal-close-icon\" (click)=\"onClose()\">\n            <i nz-icon nzType=\"close\" nzTheme=\"outline\"></i>\n          </div>\n        </div>\n      </div>\n      <div class=\"bixi-label-modal-content\">\n        <ng-template\n          [ngTemplateOutlet]=\"content\"\n          [ngTemplateOutletContext]=\"{$implicit: labeling, labeling: labeling, labels: labels, close: onClose }\">\n        </ng-template>\n      </div>\n    </div>\n  </ng-template>\n  `,\n  exportAs: 'bixiLabelModal',\n  encapsulation: ViewEncapsulation.None,\n  preserveWhitespaces: true,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class BixiLabelModalComponent {\n  overlayWidth = OVERLAY_WIDTH;\n  overlayHeight = OVERLAY_HEIGHT;\n  placement = 'right';\n  isOpen = false;\n  _labeling: ILabelingEvent | null = null;\n  @ViewChild('overlay', { static: false }) overlay!: CdkConnectedOverlay;\n  @Input() content: TemplateRef<ISafeAny> | undefined;\n  @Input() title: string;\n  @Input() dragBoundary: string;\n  @Input()\n  set labeling(val: ILabelingEvent | null) {\n    this._labeling = val;\n    if (val) {\n      this.onShow();\n    } else {\n      this.onHide();\n    }\n  }\n  get labeling() {\n    return this._labeling;\n  }\n\n  // tslint:disable-next-line: no-output-native\n  @Output() close = new EventEmitter();\n\n  constructor(\n    private cdr: ChangeDetectorRef\n  ) { }\n\n  get labels() {\n    return this.labeling ? (this.labeling.data) || [] : [];\n  }\n\n\n  onShow() {\n    if (this.isOpen && this.overlay) {\n      // 如果是二次标注的话，只需要调整位置就可以了\n      Promise.resolve().then(() => {\n        this.cdr.detectChanges();\n        this.overlay.overlayRef.updatePosition();\n      });\n      return;\n    }\n    this.isOpen = true;\n    this.cdr.detectChanges();\n  }\n\n  onHide() {\n    this.isOpen = false;\n    this.cdr.detectChanges();\n  }\n\n  onClose = () => {\n    this.onHide();\n    this.close.emit();\n  }\n\n  onDetach() {\n    // 其它方式关闭的话，也触发一次 cancel\n    if (this.isOpen) {\n      this.onClose();\n    }\n  }\n\n  get overlayStyle() {\n    return {\n      width: `${this.overlayWidth || 0}px`,\n      height: `${this.overlayHeight || 0}px`\n    };\n  }\n\n  get positions() {\n    return [POSITION_MAP[this.placement], ...DEFAULT_TOOLTIP_POSITIONS];\n  }\n\n  get originStyle() {\n    if (!this.labeling) {\n      return {\n        'width': '0px',\n        'height': '0px'\n      };\n    }\n    return {\n      position: 'absolute',\n      width: '20px',\n      height: '20px',\n      top: `${this.labeling.position.top || 0}px`,\n      left: `${this.labeling.position.left || 0}px`\n    };\n  }\n}\n"]}