@bixi/label
Version:
388 lines • 33.4 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';
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(`[/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(`[/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":"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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"]}