UNPKG

@bixi/label

Version:
388 lines 33.4 kB
/** * @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'; export class BixiLabelCoreComponent { /** * @param {?} sanitizer * @param {?} cdr */ constructor(sanitizer, cdr) { 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 {?} */ (e) => { const { id, event, data } = e.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; } } }); } /** * @param {?} val * @return {?} */ set engine(val) { this.url = this.sanitizer.bypassSecurityTrustResourceUrl(`${val || './bixi-label/index.html'}`); this._engine = val; } /** * @return {?} */ get engine() { return this._engine; } /** * @return {?} */ onLoad() { if (!this.hub) return; /** @type {?} */ const api = this.api; this.hub.setApi(api); this.hub.setLoaded(!!api); } /** * @return {?} */ get api() { if (!this.iframe) return; /** @type {?} */ const service = this.iframe.element.nativeElement.contentWindow.ProxyApiService2; if (this.hub.dev) { return functionProxy(service); } return service; } /** * @return {?} */ ngOnInit() { this.subscription.add(this.hub.init$ .pipe(filter((/** * @param {?} i * @return {?} */ i => !!i)), delayWhen((/** * @return {?} */ () => this.hub.loaded$.pipe(filter((/** * @param {?} r * @return {?} */ r => r === true)))))) .subscribe((/** * @param {?} options * @return {?} */ options => { if (!this.api) return; this.api.init(options); }))); this.subscription.add(this.hub.labels$ .pipe(filter((/** * @param {?} i * @return {?} */ i => !!i)), delayWhen((/** * @return {?} */ () => this.hub.ready$.pipe(filter((/** * @param {?} r * @return {?} */ r => r === true)))))) .subscribe((/** * @param {?} labels * @return {?} */ (labels) => { if (!this.api) return; this.api.setLabels(labels); }))); this.subscription.add(this.hub.tables$ .pipe(filter((/** * @param {?} i * @return {?} */ i => !!i)), delayWhen((/** * @return {?} */ () => this.hub.ready$.pipe(filter((/** * @param {?} r * @return {?} */ r => r === true)))))) .subscribe((/** * @param {?} tables * @return {?} */ (tables) => { if (!this.api) return; this.api.setTables(tables); }))); this.subscription.add(this.hub.hoverInLabelsEvent$ .subscribe((/** * @param {?} event * @return {?} */ event => { this.hoverInLabelsEvent = event; this.cdr.detectChanges(); }))); this.subscription.add(this.hub.labelingEvent$ .subscribe((/** * @param {?} event * @return {?} */ event => { this.labelingEvent = event; this.cdr.detectChanges(); }))); window.addEventListener('message', this.messageHandler); } /** * @return {?} */ onCloseLabelModal() { this.hub.stopLabeling(); this.hub.restore(); } /** * @return {?} */ ngOnDestroy() { this.subscription.unsubscribe(); this.hub.destory(); window.removeEventListener('message', this.messageHandler); } } BixiLabelCoreComponent.decorators = [ { type: Component, args: [{ selector: 'bixi-label-core', template: ` <div class="bixi-label-core"> <iframe #iframe [src]="url" (load)="onLoad()" [attr.id]="hub.id" [title]="hub.id"> </iframe> <bixi-label-tooltip *ngIf="hoverInLabelsEvent && !labelTooltipDisabled" [tooltip]="hoverInLabelsEvent" [content]="labelTooltipContent"> </bixi-label-tooltip> <bixi-label-modal *ngIf="labelModalContent && labelingEvent && !labelModalDisabled" [dragBoundary]="dragBoundary" (close)="onCloseLabelModal()" [labeling]="labelingEvent" [title]="labelModalTitle" [content]="labelModalContent"> </bixi-label-modal> </div> `, 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 = () => [ { 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 }] }; 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":";;;;AAAA,OAAO,EACL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,YAAY,EACZ,KAAK,EAGL,MAAM,EAEN,SAAS,EACT,gBAAgB,EAChB,iBAAiB,EAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,YAAY,EAAmB,MAAM,2BAA2B,CAAC;AAC1E,OAAO,EAAE,YAAY,EAAE,MAAM,MAAM,CAAC;AACpC,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACvC,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAEvC,OAAO,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAmC7C,MAAM,OAAO,sBAAsB;;;;;IA8BjC,YACS,SAAuB,EACtB,GAAsB;QADvB,cAAS,GAAT,SAAS,CAAc;QACtB,QAAG,GAAH,GAAG,CAAmB;QA/BhC,iBAAY,GAAG,IAAI,YAAY,EAAE,CAAC;QAGlC,uBAAkB,GAA+B,IAAI,CAAC;QACtD,kBAAa,GAA0B,IAAI,CAAC;QAanC,yBAAoB,GAAY,KAAK,CAAC;QAEtC,uBAAkB,GAAY,KAAK,CAAC;QAEnC,kBAAa,GAAiC,IAAI,YAAY,EAAkB,CAAC;QACjF,iBAAY,GAAqC,IAAI,YAAY,EAAsB,CAAC;QACxF,gBAAW,GAAoC,IAAI,YAAY,EAAqB,CAAC;QACrF,kBAAa,GAAG,IAAI,YAAY,EAAE,CAAC;QACnC,iBAAY,GAAG,IAAI,YAAY,EAAE,CAAC;QAClC,gBAAW,GAAiC,IAAI,YAAY,EAAE,CAAC;QAC/D,eAAU,GAAiC,IAAI,YAAY,EAAE,CAAC;QAC9D,wBAAmB,GAA0C,IAAI,YAAY,EAAE,CAAC;QAoE1F,mBAAc;;;;QAAG,CAAC,CAAe,EAAE,EAAE;kBAC7B,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,CAAC,CAAC,IAAI;YAClC,IAAI,IAAI,CAAC,GAAG,CAAC,EAAE,KAAK,EAAE;gBAAE,OAAO;YAC/B,IAAI,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE;gBACzB,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,eAAe,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE;oBAC7C,OAAO,CAAC,GAAG,CAAC,uBAAuB,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC;iBAC5D;aACF;YACD,QAAQ,KAAK,EAAE;gBACb,KAAK,MAAM,CAAC,KAAK,CAAC,CAAC;oBACjB,SAAS;oBACT,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;oBACxB,IAAI,CAAC,GAAG,CAAC,kBAAkB,CAAC;wBAC1B,SAAS,EAAE,IAAI,CAAC,SAAS;qBAC1B,CAAC,CAAC;oBACH,MAAM;iBACP;gBACD,KAAK,MAAM,CAAC,UAAU,CAAC,CAAC;oBACtB,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;oBAC5B,MAAM;iBACP;gBACD,KAAK,MAAM,CAAC,aAAa,CAAC,CAAC;oBACzB,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;oBAC7B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;oBAC9B,MAAM;iBACP;gBACD,KAAK,MAAM,CAAC,YAAY,CAAC,CAAC;oBACxB,IAAI,CAAC,GAAG,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;oBAC5B,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;oBAC7B,MAAM;iBACP;gBACD,KAAK,MAAM,CAAC,gBAAgB,CAAC,CAAC;oBAC5B,IAAI,CAAC,GAAG,CAAC,kBAAkB,CAAC;wBAC1B,UAAU,EAAE,IAAI,CAAC,UAAU;qBAC5B,CAAC,CAAC;oBACH,MAAM;iBACP;gBACD,KAAK,MAAM,CAAC,YAAY,CAAC,CAAC;oBACxB,IAAI,CAAC,GAAG,CAAC,eAAe,CAAC,IAAI,CAAC,CAAC;oBAC/B,MAAM;iBACP;gBACD,KAAK,MAAM,CAAC,WAAW,CAAC,CAAC;oBACvB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;oBAC5B,MAAM;iBACP;gBACD,KAAK,MAAM,CAAC,YAAY,CAAC,CAAC;oBACxB,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;oBAC7B,MAAM;iBACP;gBACD,KAAK,MAAM,CAAC,aAAa,CAAC,CAAC;oBACzB,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;oBAC7B,MAAM;iBACP;gBACD,KAAK,MAAM,CAAC,YAAY,CAAC,CAAC;oBACxB,IAAI,IAAI,CAAC,GAAG,CAAC,kBAAkB,EAAE;wBAC/B,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;qBAC9B;oBACD,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;oBAC7B,MAAM;iBACP;gBACD,KAAK,MAAM,CAAC,aAAa,CAAC,CAAC;oBACzB,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;oBAC1B,MAAM;iBACP;gBACD,KAAK,MAAM,CAAC,GAAG,CAAC,CAAC;oBACf,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;oBACtB,MAAM;iBACP;gBACD,KAAK,MAAM,CAAC,MAAM,CAAC,CAAC;oBAClB,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;oBACxB,MAAM;iBACP;gBACD,KAAK,MAAM,CAAC,WAAW,CAAC,CAAC;oBACvB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;oBAC5B,MAAM;iBACP;gBACD,KAAK,MAAM,CAAC,UAAU,CAAC,CAAC;oBACtB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;oBAC3B,MAAM;iBACP;gBACD,KAAK,MAAM,CAAC,mBAAmB,CAAC,CAAC;oBAC/B,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;oBACpC,MAAM;iBACP;gBACD,OAAO,CAAC,CAAC;oBACP,IAAI,IAAI,CAAC,GAAG,CAAC,kBAAkB,EAAE;wBAC/B,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,eAAe,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE;4BAC7C,OAAO,CAAC,IAAI,CAAC,iCAAiC,IAAI,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;yBAC7E;qBACF;oBACD,MAAM;iBACP;aACF;QACH,CAAC,EAAA;IA7JG,CAAC;;;;;IAxBL,IACI,MAAM,CAAC,GAAW;QACpB,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,8BAA8B,CAAC,GAAG,GAAG,IAAI,yBAAyB,EAAE,CAAC,CAAC;QAChG,IAAI,CAAC,OAAO,GAAG,GAAG,CAAC;IACrB,CAAC;;;;IACD,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;;;;IAmBD,MAAM;QACJ,IAAI,CAAC,IAAI,CAAC,GAAG;YAAE,OAAO;;cAChB,GAAG,GAAG,IAAI,CAAC,GAAG;QACpB,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QACrB,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;IAC5B,CAAC;;;;IAED,IAAI,GAAG;QACL,IAAI,CAAC,IAAI,CAAC,MAAM;YAAE,OAAO;;cACnB,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,aAAa,CAAC,gBAAgB;QAChF,IAAI,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE;YAChB,OAAO,aAAa,CAAC,OAAO,CAAC,CAAC;SAC/B;QACD,OAAO,OAAO,CAAC;IACjB,CAAC;;;;IAED,QAAQ;QACN,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK;aACjC,IAAI,CACH,MAAM;;;;QAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAC,EAChB,SAAS;;;QAAC,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM;;;;QAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,IAAI,EAAC,CAAC,EAAC,CAChE;aACA,SAAS;;;;QAAC,OAAO,CAAC,EAAE;YACnB,IAAI,CAAC,IAAI,CAAC,GAAG;gBAAE,OAAO;YACtB,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACzB,CAAC,EAAC,CAAC,CAAC;QACN,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO;aACnC,IAAI,CACH,MAAM;;;;QAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAC,EAChB,SAAS;;;QAAC,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM;;;;QAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,IAAI,EAAC,CAAC,EAAC,CAC/D;aACA,SAAS;;;;QAAC,CAAC,MAAM,EAAE,EAAE;YACpB,IAAI,CAAC,IAAI,CAAC,GAAG;gBAAE,OAAO;YACtB,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QAC7B,CAAC,EAAC,CAAC,CAAC;QACN,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO;aACnC,IAAI,CACH,MAAM;;;;QAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAC,EAChB,SAAS;;;QAAC,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM;;;;QAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,IAAI,EAAC,CAAC,EAAC,CAC/D;aACA,SAAS;;;;QAAC,CAAC,MAAM,EAAE,EAAE;YACpB,IAAI,CAAC,IAAI,CAAC,GAAG;gBAAE,OAAO;YACtB,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QAC7B,CAAC,EAAC,CAAC,CAAC;QACN,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,mBAAmB;aAC/C,SAAS;;;;QAAC,KAAK,CAAC,EAAE;YACjB,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;YAChC,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QAC3B,CAAC,EAAC,CAAC,CAAC;QACN,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,cAAc;aAC1C,SAAS;;;;QAAC,KAAK,CAAC,EAAE;YACjB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;YAC3B,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QAC3B,CAAC,EAAC,CAAC,CAAC;QACN,MAAM,CAAC,gBAAgB,CAAC,SAAS,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;IAC1D,CAAC;;;;IAED,iBAAiB;QACf,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;QACxB,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;IACrB,CAAC;;;;IAiGD,WAAW;QACT,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC;QAChC,IAAI,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC;QACnB,MAAM,CAAC,mBAAmB,CAAC,SAAS,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;IAC7D,CAAC;;;YArOF,SAAS,SAAC;gBACT,QAAQ,EAAE,iBAAiB;gBAC3B,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;GAuBT;gBACD,QAAQ,EAAE,eAAe;gBACzB,aAAa,EAAE,iBAAiB,CAAC,IAAI;gBACrC,mBAAmB,EAAE,IAAI;gBACzB,eAAe,EAAE,uBAAuB,CAAC,MAAM;;aAGhD;;;;YAxCQ,YAAY;YAZnB,iBAAiB;;;2BA2DhB,KAAK;qBACL,SAAS,SAAC,QAAQ,EAAE,EAAE,IAAI,EAAE,gBAAgB,EAAE;kBAC9C,KAAK;qBACL,KAAK;kCAQL,KAAK;mCACL,KAAK;8BACL,KAAK;iCACL,KAAK;gCACL,KAAK;4BACL,MAAM;2BACN,MAAM;0BACN,MAAM;4BACN,MAAM;2BACN,MAAM;0BACN,MAAM;yBACN,MAAM;kCACN,MAAM;;;;IA5BP,8CAAkC;;IAClC,yCAAgB;;IAChB,qCAAqB;;IACrB,oDAAsD;;IACtD,+CAA4C;;IAC5C,8CAA8B;;IAC9B,wCAA0E;;IAC1E,qCAAuB;;IASvB,qDAAgE;;IAChE,sDAA+C;;IAC/C,iDAAiC;;IACjC,oDAA6C;;IAC7C,mDAA8D;;IAC9D,+CAA2F;;IAC3F,8CAAkG;;IAClG,6CAA+F;;IAC/F,+CAA6C;;IAC7C,8CAA4C;;IAC5C,6CAAyE;;IACzE,4CAAwE;;IACxE,qDAA0F;;IAoE1F,gDA6FC;;IA/JC,2CAA8B;;;;;IAC9B,qCAA8B","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"]}