@bixi/label
Version:
385 lines • 34.9 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, Output, ViewChild, ViewContainerRef, ViewEncapsulation } from '@angular/core';
import { DomSanitizer } from '@angular/platform-browser';
import { Subscription } from 'rxjs';
import { delayWhen, filter } from 'rxjs/operators';
import { EVENTS } from './label.event';
import { LabelHub } from './label.hub';
import { functionProxy } from './label.util';
var BixiLabelCoreComponent = /** @class */ (function () {
function BixiLabelCoreComponent(sanitizer, cdr) {
var _this = this;
this.sanitizer = sanitizer;
this.cdr = cdr;
this.subscription = new Subscription();
this.hoverInLabelsEvent = null;
this.labelingEvent = null;
this.labelTooltipDisabled = false;
this.labelModalDisabled = false;
this.startLabeling = new EventEmitter();
this.deleteLabels = new EventEmitter();
this.clickLabels = new EventEmitter();
this.pdfLoadFailed = new EventEmitter();
this.pdfScrolling = new EventEmitter();
this.mergeTables = new EventEmitter();
this.splitTable = new EventEmitter();
this.tblOperationRecords = new EventEmitter();
this.messageHandler = (/**
* @param {?} e
* @return {?}
*/
function (e) {
var _a = e.data, id = _a.id, event = _a.event, data = _a.data;
if (_this.hub.id !== id)
return;
if (_this.hub.logAllEvents) {
if (!_this.hub.logIgnoreEvents.includes(event)) {
console.log("[@bixi/label] Event(" + _this.hub.id + ")", e.data);
}
}
switch (event) {
case EVENTS.ready: {
// 初始化标注器
_this.hub.setReady(true);
_this.hub.innerSetPagination({
pageCount: data.pageCount
});
break;
}
case EVENTS.zoomChange: {
_this.hub.setZoom(data.zoom);
break;
}
case EVENTS.startLabeling: {
_this.hub.startLabeling(data);
_this.startLabeling.emit(data);
break;
}
case EVENTS.deleteLabels: {
_this.hub.deleteLabels(data);
_this.deleteLabels.emit(data);
break;
}
case EVENTS.paginationChange: {
_this.hub.innerSetPagination({
pageNumber: data.pageNumber
});
break;
}
case EVENTS.searchResult: {
_this.hub.setSearchResult(data);
break;
}
case EVENTS.clickLabels: {
_this.clickLabels.emit(data);
break;
}
case EVENTS.hoverInLabel: {
_this.hub.hoverInLabels(data);
break;
}
case EVENTS.hoverOutLabel: {
_this.hub.hoverInLabels(null);
break;
}
case EVENTS.pdfScrolling: {
if (_this.hub.hoverInLabelsEvent) {
_this.hub.hoverInLabels(null);
}
_this.pdfScrolling.emit(true);
break;
}
case EVENTS.pdfLoadFailed: {
_this.pdfLoadFailed.emit();
break;
}
case EVENTS.log: {
_this.hub.setLog(data);
break;
}
case EVENTS.resize: {
_this.hub.resize$.next();
break;
}
case EVENTS.mergeTables: {
_this.mergeTables.emit(data);
break;
}
case EVENTS.splitTable: {
_this.splitTable.emit(data);
break;
}
case EVENTS.tblOperationRecords: {
_this.tblOperationRecords.emit(data);
break;
}
default: {
if (_this.hub.logUnhandledEvents) {
if (!_this.hub.logIgnoreEvents.includes(event)) {
console.warn("[@bixi/label] Unhandled Event(" + _this.hub.id + ") ", event, data);
}
}
break;
}
}
});
}
Object.defineProperty(BixiLabelCoreComponent.prototype, "engine", {
get: /**
* @return {?}
*/
function () {
return this._engine;
},
set: /**
* @param {?} val
* @return {?}
*/
function (val) {
this.url = this.sanitizer.bypassSecurityTrustResourceUrl("" + (val || './bixi-label/index.html'));
this._engine = val;
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
BixiLabelCoreComponent.prototype.onLoad = /**
* @return {?}
*/
function () {
if (!this.hub)
return;
/** @type {?} */
var api = this.api;
this.hub.setApi(api);
this.hub.setLoaded(!!api);
};
Object.defineProperty(BixiLabelCoreComponent.prototype, "api", {
get: /**
* @return {?}
*/
function () {
if (!this.iframe)
return;
/** @type {?} */
var service = this.iframe.element.nativeElement.contentWindow.ProxyApiService2;
if (this.hub.dev) {
return functionProxy(service);
}
return service;
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
BixiLabelCoreComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
var _this = this;
this.subscription.add(this.hub.init$
.pipe(filter((/**
* @param {?} i
* @return {?}
*/
function (i) { return !!i; })), delayWhen((/**
* @return {?}
*/
function () { return _this.hub.loaded$.pipe(filter((/**
* @param {?} r
* @return {?}
*/
function (r) { return r === true; }))); })))
.subscribe((/**
* @param {?} options
* @return {?}
*/
function (options) {
if (!_this.api)
return;
_this.api.init(options);
})));
this.subscription.add(this.hub.labels$
.pipe(filter((/**
* @param {?} i
* @return {?}
*/
function (i) { return !!i; })), delayWhen((/**
* @return {?}
*/
function () { return _this.hub.ready$.pipe(filter((/**
* @param {?} r
* @return {?}
*/
function (r) { return r === true; }))); })))
.subscribe((/**
* @param {?} labels
* @return {?}
*/
function (labels) {
if (!_this.api)
return;
_this.api.setLabels(labels);
})));
this.subscription.add(this.hub.tables$
.pipe(filter((/**
* @param {?} i
* @return {?}
*/
function (i) { return !!i; })), delayWhen((/**
* @return {?}
*/
function () { return _this.hub.ready$.pipe(filter((/**
* @param {?} r
* @return {?}
*/
function (r) { return r === true; }))); })))
.subscribe((/**
* @param {?} tables
* @return {?}
*/
function (tables) {
if (!_this.api)
return;
_this.api.setTables(tables);
})));
this.subscription.add(this.hub.hoverInLabelsEvent$
.subscribe((/**
* @param {?} event
* @return {?}
*/
function (event) {
_this.hoverInLabelsEvent = event;
_this.cdr.detectChanges();
})));
this.subscription.add(this.hub.labelingEvent$
.subscribe((/**
* @param {?} event
* @return {?}
*/
function (event) {
_this.labelingEvent = event;
_this.cdr.detectChanges();
})));
window.addEventListener('message', this.messageHandler);
};
/**
* @return {?}
*/
BixiLabelCoreComponent.prototype.onCloseLabelModal = /**
* @return {?}
*/
function () {
this.hub.stopLabeling();
this.hub.restore();
};
/**
* @return {?}
*/
BixiLabelCoreComponent.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
this.subscription.unsubscribe();
this.hub.destory();
window.removeEventListener('message', this.messageHandler);
};
BixiLabelCoreComponent.decorators = [
{ type: Component, args: [{
selector: 'bixi-label-core',
template: "\n <div class=\"bixi-label-core\">\n <iframe\n #iframe\n [src]=\"url\"\n (load)=\"onLoad()\"\n [attr.id]=\"hub.id\"\n [title]=\"hub.id\">\n </iframe>\n <bixi-label-tooltip\n *ngIf=\"hoverInLabelsEvent && !labelTooltipDisabled\"\n [tooltip]=\"hoverInLabelsEvent\"\n [content]=\"labelTooltipContent\">\n </bixi-label-tooltip>\n <bixi-label-modal\n *ngIf=\"labelModalContent && labelingEvent && !labelModalDisabled\"\n [dragBoundary]=\"dragBoundary\"\n (close)=\"onCloseLabelModal()\"\n [labeling]=\"labelingEvent\"\n [title]=\"labelModalTitle\"\n [content]=\"labelModalContent\">\n </bixi-label-modal>\n </div>\n ",
exportAs: 'bixiLabelText',
encapsulation: ViewEncapsulation.None,
preserveWhitespaces: true,
changeDetection: ChangeDetectionStrategy.OnPush,
styles: [".bixi-label-core{position:relative;width:100%;height:100%}.bixi-label-core iframe{width:100%;height:100%;vertical-align:top;border:none}.bixi-label-modal-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1000;background-color:rgba(0,0,0,.5);-webkit-tap-highlight-color:transparent;opacity:0;transition:opacity .4s cubic-bezier(.25,.8,.25,1);pointer-events:auto}.bixi-label-modal-backdrop.cdk-overlay-backdrop-showing{opacity:1}.bixi-label-modal,.bixi-label-tooltip{position:absolute;top:0;left:0}.bixi-label-tooltip{pointer-events:none}.bixi-label-modal{display:flex;flex-direction:column;background:#fff;border-radius:2px;box-shadow:0 3px 6px -4px rgba(0,0,0,.12),0 6px 16px 0 rgba(0,0,0,.08),0 9px 28px 8px rgba(0,0,0,.05)}.bixi-label-modal-header{height:32px;font-size:12px;border-bottom:1px solid #d9d9d9;cursor:move}.bixi-label-modal-header-inner{display:flex;justify-content:space-between;height:100%;line-height:32px}.bixi-label-modal-content{height:calc(100% - 32px);overflow:auto}.bixi-label-modal .bixi-label-modal-title{padding-left:8px;font-weight:500}.bixi-label-modal .bixi-label-modal-close-icon{width:36px;height:100%;text-align:center;cursor:pointer;-webkit-user-drag:none}"]
}] }
];
/** @nocollapse */
BixiLabelCoreComponent.ctorParameters = function () { return [
{ type: DomSanitizer },
{ type: ChangeDetectorRef }
]; };
BixiLabelCoreComponent.propDecorators = {
dragBoundary: [{ type: Input }],
iframe: [{ type: ViewChild, args: ['iframe', { read: ViewContainerRef },] }],
hub: [{ type: Input }],
engine: [{ type: Input }],
labelTooltipContent: [{ type: Input }],
labelTooltipDisabled: [{ type: Input }],
labelModalTitle: [{ type: Input }],
labelModalDisabled: [{ type: Input }],
labelModalContent: [{ type: Input }],
startLabeling: [{ type: Output }],
deleteLabels: [{ type: Output }],
clickLabels: [{ type: Output }],
pdfLoadFailed: [{ type: Output }],
pdfScrolling: [{ type: Output }],
mergeTables: [{ type: Output }],
splitTable: [{ type: Output }],
tblOperationRecords: [{ type: Output }]
};
return BixiLabelCoreComponent;
}());
export { BixiLabelCoreComponent };
if (false) {
/** @type {?} */
BixiLabelCoreComponent.prototype.subscription;
/** @type {?} */
BixiLabelCoreComponent.prototype._engine;
/** @type {?} */
BixiLabelCoreComponent.prototype.url;
/** @type {?} */
BixiLabelCoreComponent.prototype.hoverInLabelsEvent;
/** @type {?} */
BixiLabelCoreComponent.prototype.labelingEvent;
/** @type {?} */
BixiLabelCoreComponent.prototype.dragBoundary;
/** @type {?} */
BixiLabelCoreComponent.prototype.iframe;
/** @type {?} */
BixiLabelCoreComponent.prototype.hub;
/** @type {?} */
BixiLabelCoreComponent.prototype.labelTooltipContent;
/** @type {?} */
BixiLabelCoreComponent.prototype.labelTooltipDisabled;
/** @type {?} */
BixiLabelCoreComponent.prototype.labelModalTitle;
/** @type {?} */
BixiLabelCoreComponent.prototype.labelModalDisabled;
/** @type {?} */
BixiLabelCoreComponent.prototype.labelModalContent;
/** @type {?} */
BixiLabelCoreComponent.prototype.startLabeling;
/** @type {?} */
BixiLabelCoreComponent.prototype.deleteLabels;
/** @type {?} */
BixiLabelCoreComponent.prototype.clickLabels;
/** @type {?} */
BixiLabelCoreComponent.prototype.pdfLoadFailed;
/** @type {?} */
BixiLabelCoreComponent.prototype.pdfScrolling;
/** @type {?} */
BixiLabelCoreComponent.prototype.mergeTables;
/** @type {?} */
BixiLabelCoreComponent.prototype.splitTable;
/** @type {?} */
BixiLabelCoreComponent.prototype.tblOperationRecords;
/** @type {?} */
BixiLabelCoreComponent.prototype.messageHandler;
/** @type {?} */
BixiLabelCoreComponent.prototype.sanitizer;
/**
* @type {?}
* @private
*/
BixiLabelCoreComponent.prototype.cdr;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"label-core.component.js","sourceRoot":"ng://@bixi/label/","sources":["src/label-core.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  TemplateRef,\n  ViewChild,\n  ViewContainerRef,\n  ViewEncapsulation\n} from '@angular/core';\nimport { DomSanitizer, SafeResourceUrl } from '@angular/platform-browser';\nimport { Subscription } from 'rxjs';\nimport { delayWhen, filter } from 'rxjs/operators';\nimport { EVENTS } from './label.event';\nimport { LabelHub } from './label.hub';\nimport { IClickLabelsEvent, IDeleteLabelsEvent, IHoverInLabelsEvent, ILabelingEvent, ISafeAny, ITableMatrix, ITableOperationRecord } from './label.type';\nimport { functionProxy } from './label.util';\n\n@Component({\n  selector: 'bixi-label-core',\n  template: `\n  <div class=\"bixi-label-core\">\n    <iframe\n      #iframe\n      [src]=\"url\"\n      (load)=\"onLoad()\"\n      [attr.id]=\"hub.id\"\n      [title]=\"hub.id\">\n    </iframe>\n    <bixi-label-tooltip\n      *ngIf=\"hoverInLabelsEvent && !labelTooltipDisabled\"\n      [tooltip]=\"hoverInLabelsEvent\"\n      [content]=\"labelTooltipContent\">\n    </bixi-label-tooltip>\n    <bixi-label-modal\n      *ngIf=\"labelModalContent && labelingEvent && !labelModalDisabled\"\n      [dragBoundary]=\"dragBoundary\"\n      (close)=\"onCloseLabelModal()\"\n      [labeling]=\"labelingEvent\"\n      [title]=\"labelModalTitle\"\n      [content]=\"labelModalContent\">\n    </bixi-label-modal>\n   </div>\n  `,\n  exportAs: 'bixiLabelText',\n  encapsulation: ViewEncapsulation.None,\n  preserveWhitespaces: true,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  // TODO 做主题切换\n  styleUrls: ['./style/index.less']\n})\nexport class BixiLabelCoreComponent implements OnInit, OnDestroy {\n  subscription = new Subscription();\n  _engine: string;\n  url: SafeResourceUrl;\n  hoverInLabelsEvent: IHoverInLabelsEvent | null = null;\n  labelingEvent: ILabelingEvent | null = null;\n  @Input() dragBoundary: string;\n  @ViewChild('iframe', { read: ViewContainerRef }) iframe: ViewContainerRef;\n  @Input() hub: LabelHub;\n  @Input()\n  set engine(val: string) {\n    this.url = this.sanitizer.bypassSecurityTrustResourceUrl(`${val || './bixi-label/index.html'}`);\n    this._engine = val;\n  }\n  get engine() {\n    return this._engine;\n  }\n  @Input() labelTooltipContent: TemplateRef<ISafeAny> | undefined;\n  @Input() labelTooltipDisabled: boolean = false;\n  @Input() labelModalTitle: string;\n  @Input() labelModalDisabled: boolean = false;\n  @Input() labelModalContent: TemplateRef<ISafeAny> | undefined;\n  @Output() startLabeling: EventEmitter<ILabelingEvent> = new EventEmitter<ILabelingEvent>();\n  @Output() deleteLabels: EventEmitter<IDeleteLabelsEvent> = new EventEmitter<IDeleteLabelsEvent>();\n  @Output() clickLabels: EventEmitter<IClickLabelsEvent> = new EventEmitter<IClickLabelsEvent>();\n  @Output() pdfLoadFailed = new EventEmitter();\n  @Output() pdfScrolling = new EventEmitter();\n  @Output() mergeTables: EventEmitter<ITableMatrix[]> = new EventEmitter();\n  @Output() splitTable: EventEmitter<ITableMatrix[]> = new EventEmitter();\n  @Output() tblOperationRecords: EventEmitter<ITableOperationRecord[]> = new EventEmitter();\n  constructor(\n    public sanitizer: DomSanitizer,\n    private cdr: ChangeDetectorRef\n  ) { }\n\n  onLoad() {\n    if (!this.hub) return;\n    const api = this.api;\n    this.hub.setApi(api);\n    this.hub.setLoaded(!!api);\n  }\n\n  get api() {\n    if (!this.iframe) return;\n    const service = this.iframe.element.nativeElement.contentWindow.ProxyApiService2;\n    if (this.hub.dev) {\n      return functionProxy(service);\n    }\n    return service;\n  }\n\n  ngOnInit() {\n    this.subscription.add(this.hub.init$\n      .pipe(\n        filter(i => !!i),\n        delayWhen(() => this.hub.loaded$.pipe(filter(r => r === true)))\n      )\n      .subscribe(options => {\n        if (!this.api) return;\n        this.api.init(options);\n      }));\n    this.subscription.add(this.hub.labels$\n      .pipe(\n        filter(i => !!i),\n        delayWhen(() => this.hub.ready$.pipe(filter(r => r === true)))\n      )\n      .subscribe((labels) => {\n        if (!this.api) return;\n        this.api.setLabels(labels);\n      }));\n    this.subscription.add(this.hub.tables$\n      .pipe(\n        filter(i => !!i),\n        delayWhen(() => this.hub.ready$.pipe(filter(r => r === true)))\n      )\n      .subscribe((tables) => {\n        if (!this.api) return;\n        this.api.setTables(tables);\n      }));\n    this.subscription.add(this.hub.hoverInLabelsEvent$\n      .subscribe(event => {\n        this.hoverInLabelsEvent = event;\n        this.cdr.detectChanges();\n      }));\n    this.subscription.add(this.hub.labelingEvent$\n      .subscribe(event => {\n        this.labelingEvent = event;\n        this.cdr.detectChanges();\n      }));\n    window.addEventListener('message', this.messageHandler);\n  }\n\n  onCloseLabelModal() {\n    this.hub.stopLabeling();\n    this.hub.restore();\n  }\n\n  messageHandler = (e: MessageEvent) => {\n    const { id, event, data } = e.data;\n    if (this.hub.id !== id) return;\n    if (this.hub.logAllEvents) {\n      if (!this.hub.logIgnoreEvents.includes(event)) {\n        console.log(`[@bixi/label] Event(${this.hub.id})`, e.data);\n      }\n    }\n    switch (event) {\n      case EVENTS.ready: {\n        // 初始化标注器\n        this.hub.setReady(true);\n        this.hub.innerSetPagination({\n          pageCount: data.pageCount\n        });\n        break;\n      }\n      case EVENTS.zoomChange: {\n        this.hub.setZoom(data.zoom);\n        break;\n      }\n      case EVENTS.startLabeling: {\n        this.hub.startLabeling(data);\n        this.startLabeling.emit(data);\n        break;\n      }\n      case EVENTS.deleteLabels: {\n        this.hub.deleteLabels(data);\n        this.deleteLabels.emit(data);\n        break;\n      }\n      case EVENTS.paginationChange: {\n        this.hub.innerSetPagination({\n          pageNumber: data.pageNumber\n        });\n        break;\n      }\n      case EVENTS.searchResult: {\n        this.hub.setSearchResult(data);\n        break;\n      }\n      case EVENTS.clickLabels: {\n        this.clickLabels.emit(data);\n        break;\n      }\n      case EVENTS.hoverInLabel: {\n        this.hub.hoverInLabels(data);\n        break;\n      }\n      case EVENTS.hoverOutLabel: {\n        this.hub.hoverInLabels(null);\n        break;\n      }\n      case EVENTS.pdfScrolling: {\n        if (this.hub.hoverInLabelsEvent) {\n          this.hub.hoverInLabels(null);\n        }\n        this.pdfScrolling.emit(true);\n        break;\n      }\n      case EVENTS.pdfLoadFailed: {\n        this.pdfLoadFailed.emit();\n        break;\n      }\n      case EVENTS.log: {\n        this.hub.setLog(data);\n        break;\n      }\n      case EVENTS.resize: {\n        this.hub.resize$.next();\n        break;\n      }\n      case EVENTS.mergeTables: {\n        this.mergeTables.emit(data);\n        break;\n      }\n      case EVENTS.splitTable: {\n        this.splitTable.emit(data);\n        break;\n      }\n      case EVENTS.tblOperationRecords: {\n        this.tblOperationRecords.emit(data);\n        break;\n      }\n      default: {\n        if (this.hub.logUnhandledEvents) {\n          if (!this.hub.logIgnoreEvents.includes(event)) {\n            console.warn(`[@bixi/label] Unhandled Event(${this.hub.id}) `, event, data);\n          }\n        }\n        break;\n      }\n    }\n  }\n\n  ngOnDestroy() {\n    this.subscription.unsubscribe();\n    this.hub.destory();\n    window.removeEventListener('message', this.messageHandler);\n  }\n}\n"]}