UNPKG

@bixi/label

Version:
208 lines 17.4 kB
/** * @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"]}