@worktile/theia 3.0.5 → 3.0.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (36) hide show
  1. package/bundles/worktile-theia.umd.js +64 -27
  2. package/bundles/worktile-theia.umd.js.map +1 -1
  3. package/editor.component.d.ts +2 -1
  4. package/esm2015/components/toolbar-dropdown/toolbar-dropdown.component.js +3 -2
  5. package/esm2015/components/toolbar-group/toolbar-group.component.js +2 -1
  6. package/esm2015/core/toolbar-item/base-toolbar-item.js +4 -4
  7. package/esm2015/editor.component.js +15 -2
  8. package/esm2015/interfaces/toolbar.js +1 -1
  9. package/esm2015/plugins/code/code.component.js +6 -3
  10. package/esm2015/plugins/color/toolbar-item.component.js +2 -1
  11. package/esm2015/plugins/deserializers/deserialize-md.plugin.js +2 -1
  12. package/esm2015/plugins/image/image.component.js +13 -8
  13. package/esm2015/plugins/image/image.editor.js +3 -5
  14. package/esm2015/plugins/link/link.component.js +3 -1
  15. package/esm2015/plugins/quick-insert/quick-insert.editor.js +2 -1
  16. package/esm2015/plugins/table/components/toolbar/table-toolbar.component.js +2 -1
  17. package/esm2015/plugins/table/table.service.js +2 -1
  18. package/esm2015/plugins/table/toolbar-item.component.js +2 -1
  19. package/esm2015/plugins/vertical-align/toolbar-item.component.js +2 -1
  20. package/esm2015/queries/get-plugin-by-toolbar.js +13 -0
  21. package/esm2015/queries/get-toolbar-disabled.js +1 -1
  22. package/esm2015/queries/index.js +3 -3
  23. package/esm2015/services/color-select.service.js +2 -1
  24. package/esm2015/services/context.service.js +7 -6
  25. package/esm2015/services/table-contextmenu.service.js +2 -1
  26. package/fesm2015/worktile-theia.js +64 -28
  27. package/fesm2015/worktile-theia.js.map +1 -1
  28. package/interfaces/toolbar.d.ts +2 -0
  29. package/package.json +1 -1
  30. package/plugins/image/image.component.d.ts +4 -1
  31. package/queries/get-plugin-by-toolbar.d.ts +3 -0
  32. package/queries/get-toolbar-disabled.d.ts +2 -2
  33. package/queries/index.d.ts +2 -2
  34. package/services/context.service.d.ts +8 -4
  35. package/esm2015/queries/get-plugin-key-by-toolbar-key.js +0 -10
  36. package/queries/get-plugin-key-by-toolbar-key.d.ts +0 -3
@@ -1,15 +1,16 @@
1
1
  import { Injectable } from '@angular/core';
2
- import { fromEvent } from 'rxjs';
2
+ import { fromEvent, Subject } from 'rxjs';
3
3
  import { FontSizes } from '../constants/node-types';
4
4
  import * as i0 from "@angular/core";
5
5
  export class TheContextService {
6
6
  constructor(ngZone) {
7
7
  this.ngZone = ngZone;
8
- this.fileList = [];
8
+ this.uploadingFiles = [];
9
9
  this.paintFormatStatus = {
10
10
  isActive: false,
11
11
  marks: {}
12
12
  };
13
+ this.uploadingStatus$ = new Subject();
13
14
  this.ngZone.runOutsideAngular(() => {
14
15
  this.onMouseUp$ = fromEvent(window, `mouseup`);
15
16
  this.onMouseMove$ = fromEvent(window, `mousemove`);
@@ -44,11 +45,11 @@ export class TheContextService {
44
45
  const firstElementChild = this.getFirstElementChild();
45
46
  return 0.48 * firstElementChild.clientWidth;
46
47
  }
47
- setUploadFileList(file) {
48
- this.fileList.push(file);
48
+ addUploadingFiles(file) {
49
+ this.uploadingFiles.push(file);
49
50
  }
50
51
  removeUploadImage(file) {
51
- this.fileList.splice(this.fileList.findIndex(item => item.file === file), 1);
52
+ this.uploadingFiles.splice(this.uploadingFiles.findIndex(item => item.url === file.url), 1);
52
53
  }
53
54
  }
54
55
  TheContextService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheContextService, deps: [{ token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Injectable });
@@ -56,4 +57,4 @@ TheContextService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", ve
56
57
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheContextService, decorators: [{
57
58
  type: Injectable
58
59
  }], ctorParameters: function () { return [{ type: i0.NgZone }]; } });
59
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGV4dC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvc3JjL3NlcnZpY2VzL2NvbnRleHQuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUE0QixNQUFNLGVBQWUsQ0FBQztBQUNyRSxPQUFPLEVBQUUsU0FBUyxFQUFjLE1BQU0sTUFBTSxDQUFDO0FBRTdDLE9BQU8sRUFBRSxTQUFTLEVBQWEsTUFBTSx5QkFBeUIsQ0FBQzs7QUFlL0QsTUFBTSxPQUFPLGlCQUFpQjtJQWdCMUIsWUFBb0IsTUFBYztRQUFkLFdBQU0sR0FBTixNQUFNLENBQVE7UUFibEMsYUFBUSxHQUFrQyxFQUFFLENBQUM7UUFFdEMsc0JBQWlCLEdBQXNCO1lBQzFDLFFBQVEsRUFBRSxLQUFLO1lBQ2YsS0FBSyxFQUFFLEVBQUU7U0FDWixDQUFDO1FBU0UsSUFBSSxDQUFDLE1BQU0sQ0FBQyxpQkFBaUIsQ0FBQyxHQUFHLEVBQUU7WUFDL0IsSUFBSSxDQUFDLFVBQVUsR0FBRyxTQUFTLENBQWEsTUFBTSxFQUFFLFNBQVMsQ0FBQyxDQUFDO1lBQzNELElBQUksQ0FBQyxZQUFZLEdBQUcsU0FBUyxDQUFhLE1BQU0sRUFBRSxXQUFXLENBQUMsQ0FBQztZQUMvRCxJQUFJLENBQUMsWUFBWSxHQUFHLFNBQVMsQ0FBYSxNQUFNLEVBQUUsV0FBVyxDQUFDLENBQUM7UUFDbkUsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRU0sVUFBVSxDQUFDLE9BQTBCO1FBQ3hDLElBQUksQ0FBQyxPQUFPLEdBQUcsT0FBTyxDQUFDO0lBQzNCLENBQUM7SUFFTSxVQUFVO1FBQ2IsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxFQUFFO1lBQ3JCLE1BQU0saUJBQWlCLEdBQUcsSUFBSSxDQUFDLG9CQUFvQixFQUFFLENBQUM7WUFDdEQsSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLEdBQUcsaUJBQWlCLENBQUMsV0FBVyxDQUFDO1NBQ3REO1FBQ0QsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDO0lBQ3hCLENBQUM7SUFFTSxhQUFhO1FBQ2hCLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUM7SUFDbkMsQ0FBQztJQUVNLGtCQUFrQjs7UUFDckIsT0FBTyxDQUFBLE1BQUEsSUFBSSxDQUFDLE9BQU8sQ0FBQyxVQUFVLDBDQUFFLFFBQVEsS0FBSSxTQUFTLENBQUMsVUFBVSxDQUFDO0lBQ3JFLENBQUM7SUFFTSxrQkFBa0I7UUFDckIsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxhQUFhLENBQUMsa0JBQWtCLENBQUMsQ0FBQztJQUN4RSxDQUFDO0lBRU0sb0JBQW9CO1FBQ3ZCLE1BQU0sZUFBZSxHQUFHLElBQUksQ0FBQyxrQkFBa0IsRUFBRSxDQUFDO1FBQ2xELE9BQU8sZUFBZSxhQUFmLGVBQWUsdUJBQWYsZUFBZSxDQUFFLGlCQUFnQyxDQUFDO0lBQzdELENBQUM7SUFFTSxrQkFBa0I7UUFDckIsTUFBTSxpQkFBaUIsR0FBRyxJQUFJLENBQUMsb0JBQW9CLEVBQUUsQ0FBQztRQUN0RCxPQUFPLElBQUksR0FBRyxpQkFBaUIsQ0FBQyxXQUFXLENBQUM7SUFDaEQsQ0FBQztJQUVELGlCQUFpQixDQUFDLElBQWlDO1FBQy9DLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQzdCLENBQUM7SUFFRCxpQkFBaUIsQ0FBQyxJQUFVO1FBQ3hCLElBQUksQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUNoQixJQUFJLENBQUMsUUFBUSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxJQUFJLEtBQUssSUFBSSxDQUFDLEVBQ25ELENBQUMsQ0FDSixDQUFDO0lBQ04sQ0FBQzs7K0dBbkVRLGlCQUFpQjttSEFBakIsaUJBQWlCOzRGQUFqQixpQkFBaUI7a0JBRDdCLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBOZ1pvbmUsIFZpZXdDb250YWluZXJSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGZyb21FdmVudCwgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgVGhlT3B0aW9ucyB9IGZyb20gJy4uL2ludGVyZmFjZXMvZWRpdG9yJztcbmltcG9ydCB7IEZvbnRTaXplcywgTWFya1R5cGVzIH0gZnJvbSAnLi4vY29uc3RhbnRzL25vZGUtdHlwZXMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFRoZUNvbnRleHRPcHRpb25zIHtcbiAgICB0aGVPcHRpb25zOiBUaGVPcHRpb25zO1xuICAgIHdpZHRoPzogbnVtYmVyO1xuICAgIG5hdGl2ZUVsZW1lbnQ6IEhUTUxFbGVtZW50O1xuICAgIHZpZXdDb250YWluZXJSZWY6IFZpZXdDb250YWluZXJSZWY7XG59XG5cbmludGVyZmFjZSBQYWludEZvcm1hdFN0YXR1cyB7XG4gICAgaXNBY3RpdmU6IGJvb2xlYW47XG4gICAgbWFya3M6IHsgW2tleSBpbiBNYXJrVHlwZXNdPzogYW55IH07XG59XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBUaGVDb250ZXh0U2VydmljZSB7XG4gICAgcHJpdmF0ZSBvcHRpb25zOiBUaGVDb250ZXh0T3B0aW9ucztcblxuICAgIGZpbGVMaXN0OiB7IHVybDogc3RyaW5nOyBmaWxlOiBGaWxlIH1bXSA9IFtdO1xuXG4gICAgcHVibGljIHBhaW50Rm9ybWF0U3RhdHVzOiBQYWludEZvcm1hdFN0YXR1cyA9IHtcbiAgICAgICAgaXNBY3RpdmU6IGZhbHNlLFxuICAgICAgICBtYXJrczoge31cbiAgICB9O1xuXG4gICAgcHVibGljIG9uTW91c2VVcCQ6IE9ic2VydmFibGU8TW91c2VFdmVudD47XG5cbiAgICBwdWJsaWMgb25Nb3VzZU1vdmUkOiBPYnNlcnZhYmxlPE1vdXNlRXZlbnQ+O1xuXG4gICAgcHVibGljIG9uTW91c2VEb3duJDogT2JzZXJ2YWJsZTxNb3VzZUV2ZW50PjtcblxuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgbmdab25lOiBOZ1pvbmUpIHtcbiAgICAgICAgdGhpcy5uZ1pvbmUucnVuT3V0c2lkZUFuZ3VsYXIoKCkgPT4ge1xuICAgICAgICAgICAgdGhpcy5vbk1vdXNlVXAkID0gZnJvbUV2ZW50PE1vdXNlRXZlbnQ+KHdpbmRvdywgYG1vdXNldXBgKTtcbiAgICAgICAgICAgIHRoaXMub25Nb3VzZU1vdmUkID0gZnJvbUV2ZW50PE1vdXNlRXZlbnQ+KHdpbmRvdywgYG1vdXNlbW92ZWApO1xuICAgICAgICAgICAgdGhpcy5vbk1vdXNlRG93biQgPSBmcm9tRXZlbnQ8TW91c2VFdmVudD4od2luZG93LCBgbW91c2Vkb3duYCk7XG4gICAgICAgIH0pO1xuICAgIH1cblxuICAgIHB1YmxpYyBpbml0aWFsaXplKG9wdGlvbnM6IFRoZUNvbnRleHRPcHRpb25zKSB7XG4gICAgICAgIHRoaXMub3B0aW9ucyA9IG9wdGlvbnM7XG4gICAgfVxuXG4gICAgcHVibGljIGdldE9wdGlvbnMoKSB7XG4gICAgICAgIGlmICghdGhpcy5vcHRpb25zLndpZHRoKSB7XG4gICAgICAgICAgICBjb25zdCBmaXJzdEVsZW1lbnRDaGlsZCA9IHRoaXMuZ2V0Rmlyc3RFbGVtZW50Q2hpbGQoKTtcbiAgICAgICAgICAgIHRoaXMub3B0aW9ucy53aWR0aCA9IGZpcnN0RWxlbWVudENoaWxkLm9mZnNldFdpZHRoO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiB0aGlzLm9wdGlvbnM7XG4gICAgfVxuXG4gICAgcHVibGljIGdldFRoZU9wdGlvbnMoKSB7XG4gICAgICAgIHJldHVybiB0aGlzLm9wdGlvbnMudGhlT3B0aW9ucztcbiAgICB9XG5cbiAgICBwdWJsaWMgZ2V0RGVmYXVsdEZvbnRTaXplKCkge1xuICAgICAgICByZXR1cm4gdGhpcy5vcHRpb25zLnRoZU9wdGlvbnM/LmZvbnRTaXplIHx8IEZvbnRTaXplcy5mb250U2l6ZTE0O1xuICAgIH1cblxuICAgIHB1YmxpYyBnZXRFZGl0YWJsZUVsZW1lbnQoKSB7XG4gICAgICAgIHJldHVybiB0aGlzLm9wdGlvbnMubmF0aXZlRWxlbWVudC5xdWVyeVNlbGVjdG9yKCcudGhlLWVkaXRvci10eXBvJyk7XG4gICAgfVxuXG4gICAgcHVibGljIGdldEZpcnN0RWxlbWVudENoaWxkKCkge1xuICAgICAgICBjb25zdCBlZGl0YWJsZUVsZW1lbnQgPSB0aGlzLmdldEVkaXRhYmxlRWxlbWVudCgpO1xuICAgICAgICByZXR1cm4gZWRpdGFibGVFbGVtZW50Py5maXJzdEVsZW1lbnRDaGlsZCBhcyBIVE1MRWxlbWVudDtcbiAgICB9XG5cbiAgICBwdWJsaWMgbGF5b3V0RGVmYXVsdFdpZHRoKCkge1xuICAgICAgICBjb25zdCBmaXJzdEVsZW1lbnRDaGlsZCA9IHRoaXMuZ2V0Rmlyc3RFbGVtZW50Q2hpbGQoKTtcbiAgICAgICAgcmV0dXJuIDAuNDggKiBmaXJzdEVsZW1lbnRDaGlsZC5jbGllbnRXaWR0aDtcbiAgICB9XG5cbiAgICBzZXRVcGxvYWRGaWxlTGlzdChmaWxlOiB7IHVybDogc3RyaW5nOyBmaWxlOiBGaWxlIH0pIHtcbiAgICAgICAgdGhpcy5maWxlTGlzdC5wdXNoKGZpbGUpO1xuICAgIH1cblxuICAgIHJlbW92ZVVwbG9hZEltYWdlKGZpbGU6IEZpbGUpIHtcbiAgICAgICAgdGhpcy5maWxlTGlzdC5zcGxpY2UoXG4gICAgICAgICAgICB0aGlzLmZpbGVMaXN0LmZpbmRJbmRleChpdGVtID0+IGl0ZW0uZmlsZSA9PT0gZmlsZSksXG4gICAgICAgICAgICAxXG4gICAgICAgICk7XG4gICAgfVxufVxuIl19
60
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGV4dC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvc3JjL3NlcnZpY2VzL2NvbnRleHQuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUE0QixNQUFNLGVBQWUsQ0FBQztBQUNyRSxPQUFPLEVBQUUsU0FBUyxFQUFjLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUV0RCxPQUFPLEVBQUUsU0FBUyxFQUFhLE1BQU0seUJBQXlCLENBQUM7O0FBZS9ELE1BQU0sT0FBTyxpQkFBaUI7SUFrQjFCLFlBQW9CLE1BQWM7UUFBZCxXQUFNLEdBQU4sTUFBTSxDQUFRO1FBZmxDLG1CQUFjLEdBQWtDLEVBQUUsQ0FBQztRQUU1QyxzQkFBaUIsR0FBc0I7WUFDMUMsUUFBUSxFQUFFLEtBQUs7WUFDZixLQUFLLEVBQUUsRUFBRTtTQUNaLENBQUM7UUFRSyxxQkFBZ0IsR0FBRyxJQUFJLE9BQU8sRUFBVyxDQUFDO1FBRzdDLElBQUksQ0FBQyxNQUFNLENBQUMsaUJBQWlCLENBQUMsR0FBRyxFQUFFO1lBQy9CLElBQUksQ0FBQyxVQUFVLEdBQUcsU0FBUyxDQUFhLE1BQU0sRUFBRSxTQUFTLENBQUMsQ0FBQztZQUMzRCxJQUFJLENBQUMsWUFBWSxHQUFHLFNBQVMsQ0FBYSxNQUFNLEVBQUUsV0FBVyxDQUFDLENBQUM7WUFDL0QsSUFBSSxDQUFDLFlBQVksR0FBRyxTQUFTLENBQWEsTUFBTSxFQUFFLFdBQVcsQ0FBQyxDQUFDO1FBQ25FLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVNLFVBQVUsQ0FBQyxPQUEwQjtRQUN4QyxJQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQztJQUMzQixDQUFDO0lBRU0sVUFBVTtRQUNiLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLEtBQUssRUFBRTtZQUNyQixNQUFNLGlCQUFpQixHQUFHLElBQUksQ0FBQyxvQkFBb0IsRUFBRSxDQUFDO1lBQ3RELElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxHQUFHLGlCQUFpQixDQUFDLFdBQVcsQ0FBQztTQUN0RDtRQUNELE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQztJQUN4QixDQUFDO0lBRU0sYUFBYTtRQUNoQixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsVUFBVSxDQUFDO0lBQ25DLENBQUM7SUFFTSxrQkFBa0I7O1FBQ3JCLE9BQU8sQ0FBQSxNQUFBLElBQUksQ0FBQyxPQUFPLENBQUMsVUFBVSwwQ0FBRSxRQUFRLEtBQUksU0FBUyxDQUFDLFVBQVUsQ0FBQztJQUNyRSxDQUFDO0lBRU0sa0JBQWtCO1FBQ3JCLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUMsYUFBYSxDQUFDLGtCQUFrQixDQUFDLENBQUM7SUFDeEUsQ0FBQztJQUVNLG9CQUFvQjtRQUN2QixNQUFNLGVBQWUsR0FBRyxJQUFJLENBQUMsa0JBQWtCLEVBQUUsQ0FBQztRQUNsRCxPQUFPLGVBQWUsYUFBZixlQUFlLHVCQUFmLGVBQWUsQ0FBRSxpQkFBZ0MsQ0FBQztJQUM3RCxDQUFDO0lBRU0sa0JBQWtCO1FBQ3JCLE1BQU0saUJBQWlCLEdBQUcsSUFBSSxDQUFDLG9CQUFvQixFQUFFLENBQUM7UUFDdEQsT0FBTyxJQUFJLEdBQUcsaUJBQWlCLENBQUMsV0FBVyxDQUFDO0lBQ2hELENBQUM7SUFFRCxpQkFBaUIsQ0FBQyxJQUFpQztRQUMvQyxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNuQyxDQUFDO0lBRUQsaUJBQWlCLENBQUMsSUFBaUM7UUFDL0MsSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLENBQ3RCLElBQUksQ0FBQyxjQUFjLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLEdBQUcsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQzVELENBQUMsQ0FDSixDQUFDO0lBQ04sQ0FBQzs7K0dBckVRLGlCQUFpQjttSEFBakIsaUJBQWlCOzRGQUFqQixpQkFBaUI7a0JBRDdCLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBOZ1pvbmUsIFZpZXdDb250YWluZXJSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGZyb21FdmVudCwgT2JzZXJ2YWJsZSwgU3ViamVjdCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgVGhlT3B0aW9ucyB9IGZyb20gJy4uL2ludGVyZmFjZXMvZWRpdG9yJztcbmltcG9ydCB7IEZvbnRTaXplcywgTWFya1R5cGVzIH0gZnJvbSAnLi4vY29uc3RhbnRzL25vZGUtdHlwZXMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFRoZUNvbnRleHRPcHRpb25zIHtcbiAgICB0aGVPcHRpb25zOiBUaGVPcHRpb25zO1xuICAgIHdpZHRoPzogbnVtYmVyO1xuICAgIG5hdGl2ZUVsZW1lbnQ6IEhUTUxFbGVtZW50O1xuICAgIHZpZXdDb250YWluZXJSZWY6IFZpZXdDb250YWluZXJSZWY7XG59XG5cbmludGVyZmFjZSBQYWludEZvcm1hdFN0YXR1cyB7XG4gICAgaXNBY3RpdmU6IGJvb2xlYW47XG4gICAgbWFya3M6IHsgW2tleSBpbiBNYXJrVHlwZXNdPzogYW55IH07XG59XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBUaGVDb250ZXh0U2VydmljZSB7XG4gICAgcHJpdmF0ZSBvcHRpb25zOiBUaGVDb250ZXh0T3B0aW9ucztcblxuICAgIHVwbG9hZGluZ0ZpbGVzOiB7IHVybDogc3RyaW5nOyBmaWxlOiBGaWxlIH1bXSA9IFtdO1xuXG4gICAgcHVibGljIHBhaW50Rm9ybWF0U3RhdHVzOiBQYWludEZvcm1hdFN0YXR1cyA9IHtcbiAgICAgICAgaXNBY3RpdmU6IGZhbHNlLFxuICAgICAgICBtYXJrczoge31cbiAgICB9O1xuXG4gICAgcHVibGljIG9uTW91c2VVcCQ6IE9ic2VydmFibGU8TW91c2VFdmVudD47XG5cbiAgICBwdWJsaWMgb25Nb3VzZU1vdmUkOiBPYnNlcnZhYmxlPE1vdXNlRXZlbnQ+O1xuXG4gICAgcHVibGljIG9uTW91c2VEb3duJDogT2JzZXJ2YWJsZTxNb3VzZUV2ZW50PjtcblxuICAgIHB1YmxpYyB1cGxvYWRpbmdTdGF0dXMkID0gbmV3IFN1YmplY3Q8Ym9vbGVhbj4oKTtcblxuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgbmdab25lOiBOZ1pvbmUpIHtcbiAgICAgICAgdGhpcy5uZ1pvbmUucnVuT3V0c2lkZUFuZ3VsYXIoKCkgPT4ge1xuICAgICAgICAgICAgdGhpcy5vbk1vdXNlVXAkID0gZnJvbUV2ZW50PE1vdXNlRXZlbnQ+KHdpbmRvdywgYG1vdXNldXBgKTtcbiAgICAgICAgICAgIHRoaXMub25Nb3VzZU1vdmUkID0gZnJvbUV2ZW50PE1vdXNlRXZlbnQ+KHdpbmRvdywgYG1vdXNlbW92ZWApO1xuICAgICAgICAgICAgdGhpcy5vbk1vdXNlRG93biQgPSBmcm9tRXZlbnQ8TW91c2VFdmVudD4od2luZG93LCBgbW91c2Vkb3duYCk7XG4gICAgICAgIH0pO1xuICAgIH1cblxuICAgIHB1YmxpYyBpbml0aWFsaXplKG9wdGlvbnM6IFRoZUNvbnRleHRPcHRpb25zKSB7XG4gICAgICAgIHRoaXMub3B0aW9ucyA9IG9wdGlvbnM7XG4gICAgfVxuXG4gICAgcHVibGljIGdldE9wdGlvbnMoKSB7XG4gICAgICAgIGlmICghdGhpcy5vcHRpb25zLndpZHRoKSB7XG4gICAgICAgICAgICBjb25zdCBmaXJzdEVsZW1lbnRDaGlsZCA9IHRoaXMuZ2V0Rmlyc3RFbGVtZW50Q2hpbGQoKTtcbiAgICAgICAgICAgIHRoaXMub3B0aW9ucy53aWR0aCA9IGZpcnN0RWxlbWVudENoaWxkLm9mZnNldFdpZHRoO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiB0aGlzLm9wdGlvbnM7XG4gICAgfVxuXG4gICAgcHVibGljIGdldFRoZU9wdGlvbnMoKSB7XG4gICAgICAgIHJldHVybiB0aGlzLm9wdGlvbnMudGhlT3B0aW9ucztcbiAgICB9XG5cbiAgICBwdWJsaWMgZ2V0RGVmYXVsdEZvbnRTaXplKCkge1xuICAgICAgICByZXR1cm4gdGhpcy5vcHRpb25zLnRoZU9wdGlvbnM/LmZvbnRTaXplIHx8IEZvbnRTaXplcy5mb250U2l6ZTE0O1xuICAgIH1cblxuICAgIHB1YmxpYyBnZXRFZGl0YWJsZUVsZW1lbnQoKSB7XG4gICAgICAgIHJldHVybiB0aGlzLm9wdGlvbnMubmF0aXZlRWxlbWVudC5xdWVyeVNlbGVjdG9yKCcudGhlLWVkaXRvci10eXBvJyk7XG4gICAgfVxuXG4gICAgcHVibGljIGdldEZpcnN0RWxlbWVudENoaWxkKCkge1xuICAgICAgICBjb25zdCBlZGl0YWJsZUVsZW1lbnQgPSB0aGlzLmdldEVkaXRhYmxlRWxlbWVudCgpO1xuICAgICAgICByZXR1cm4gZWRpdGFibGVFbGVtZW50Py5maXJzdEVsZW1lbnRDaGlsZCBhcyBIVE1MRWxlbWVudDtcbiAgICB9XG5cbiAgICBwdWJsaWMgbGF5b3V0RGVmYXVsdFdpZHRoKCkge1xuICAgICAgICBjb25zdCBmaXJzdEVsZW1lbnRDaGlsZCA9IHRoaXMuZ2V0Rmlyc3RFbGVtZW50Q2hpbGQoKTtcbiAgICAgICAgcmV0dXJuIDAuNDggKiBmaXJzdEVsZW1lbnRDaGlsZC5jbGllbnRXaWR0aDtcbiAgICB9XG5cbiAgICBhZGRVcGxvYWRpbmdGaWxlcyhmaWxlOiB7IHVybDogc3RyaW5nOyBmaWxlOiBGaWxlIH0pIHtcbiAgICAgICAgdGhpcy51cGxvYWRpbmdGaWxlcy5wdXNoKGZpbGUpO1xuICAgIH1cblxuICAgIHJlbW92ZVVwbG9hZEltYWdlKGZpbGU6IHsgdXJsOiBzdHJpbmc7IGZpbGU6IEZpbGUgfSkge1xuICAgICAgICB0aGlzLnVwbG9hZGluZ0ZpbGVzLnNwbGljZShcbiAgICAgICAgICAgIHRoaXMudXBsb2FkaW5nRmlsZXMuZmluZEluZGV4KGl0ZW0gPT4gaXRlbS51cmwgPT09IGZpbGUudXJsKSxcbiAgICAgICAgICAgIDFcbiAgICAgICAgKTtcbiAgICB9XG59XG4iXX0=
@@ -163,6 +163,7 @@ export class TheTableContextMenuService {
163
163
  y: event.y
164
164
  },
165
165
  hasBackdrop: false,
166
+ minWidth: 0,
166
167
  placement: 'bottomLeft',
167
168
  viewContainerRef: this.theContextService.getOptions().viewContainerRef,
168
169
  manualClosure: true,
@@ -186,4 +187,4 @@ TheTableContextMenuService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12
186
187
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheTableContextMenuService, decorators: [{
187
188
  type: Injectable
188
189
  }], ctorParameters: function () { return [{ type: i1.TheColorSelectService }, { type: i2.TableStore }, { type: i3.ThyPopover }, { type: i0.NgZone }, { type: i4.TheContextService }]; } });
189
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-contextmenu.service.js","sourceRoot":"","sources":["../../../../packages/src/services/table-contextmenu.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAU,MAAM,eAAe,CAAC;AACnD,OAAO,EAAE,gBAAgB,EAAa,sBAAsB,EAAE,0BAA0B,EAAE,MAAM,2BAA2B,CAAC;AAG5H,OAAO,EAAE,WAAW,EAAE,MAAM,+BAA+B,CAAC;AAE5D,OAAO,EAAE,uBAAuB,EAAE,MAAM,iDAAiD,CAAC;AAE1F,OAAO,EAAE,SAAS,EAAE,MAAM,mCAAmC,CAAC;AAC9D,OAAO,EAAE,uBAAuB,EAAE,MAAM,mDAAmD,CAAC;;;;;;AAI5F,MAAM,OAAO,0BAA0B;IAenC,YACY,kBAAyC,EACzC,UAAsB,EACtB,UAAsB,EACtB,MAAc,EACd,iBAAoC;QAJpC,uBAAkB,GAAlB,kBAAkB,CAAuB;QACzC,eAAU,GAAV,UAAU,CAAY;QACtB,eAAU,GAAV,UAAU,CAAY;QACtB,WAAM,GAAN,MAAM,CAAQ;QACd,sBAAiB,GAAjB,iBAAiB,CAAmB;QAGhD,iBAAY,GAAiB;YACzB;gBACI,GAAG,EAAE,kBAAkB;gBACvB,IAAI,EAAE,eAAe;gBACrB,OAAO,EAAE,IAAI;gBACb,IAAI,EAAE,OAAO;gBACb,UAAU,EAAE,aAAa;gBACzB,YAAY,EAAE,GAAG,EAAE,GAAE,CAAC;gBACtB,YAAY,EAAE,CAAC,KAAiB,EAAE,EAAE;oBAChC,IAAI,IAAI,CAAC,kBAAkB,CAAC,iBAAiB,EAAE;wBAC3C,OAAO;qBACV;oBACD,MAAM,QAAQ,GAAG,WAAW,CAAC,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;oBACzD,IAAI,CAAC,kBAAkB,CAAC,iBAAiB,CACrC,KAAK,CAAC,MAAqB,EAC3B,IAAI,CAAC,eAAe,EACpB,gBAAgB,EAChB;wBACI,kBAAkB,EAAE,CAAC;wBACrB,UAAU,EAAE,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE;wBACpC,YAAY,EAAE,QAAQ,CAAC,CAAC,CAAC,0BAA0B,CAAC,CAAC,CAAC,sBAAsB;qBAC/E,EACD,CAAC,QAAmB,EAAE,EAAE;wBACpB,IAAI,CAAC,QAAQ,KAAK,0BAA0B,IAAI,QAAQ,CAAC,IAAI,CAAC,QAAQ,KAAK,sBAAsB,IAAI,CAAC,QAAQ,CAAC,EAAE;4BAC7G,IAAI,CAAC,UAAU,CAAC,+BAA+B,CAAC,IAAI,CAAC,CAAC;yBACzD;6BAAM;4BACH,IAAI,CAAC,UAAU,CAAC,+BAA+B,CAAC,QAAQ,CAAC,CAAC;yBAC7D;wBACD,IAAI,CAAC,UAAU,CAAC,eAAe,EAAE,CAAC;oBACtC,CAAC,EACD,UAAU,EACV,CAAC,CACJ,CAAC;gBACN,CAAC;gBACD,cAAc,EAAE,CAAC,KAAiB,EAAE,EAAE;oBAClC,IAAI,KAAK,CAAC,aAAa,YAAY,WAAW,EAAE;wBAC5C,IAAI,KAAK,CAAC,aAAa,CAAC,SAAS,CAAC,QAAQ,CAAC,iBAAiB,CAAC,EAAE;4BAC3D,OAAO;yBACV;qBACJ;oBACD,IAAI,IAAI,CAAC,kBAAkB,CAAC,iBAAiB,EAAE;wBAC3C,IAAI,CAAC,kBAAkB,CAAC,gBAAgB,EAAE,CAAC;qBAC9C;gBACL,CAAC;aACJ;YACD;gBACI,GAAG,EAAE,iBAAiB;gBACtB,IAAI,EAAE,OAAO;gBACb,OAAO,EAAE,IAAI;gBACb,IAAI,EAAE,QAAQ;gBACd,YAAY,EAAE,GAAG,EAAE;oBACf,IAAI,CAAC,UAAU,CAAC,yBAAyB,EAAE,CAAC;oBAC5C,IAAI,CAAC,UAAU,CAAC,eAAe,EAAE,CAAC;gBACtC,CAAC;aACJ;YACD;gBACI,GAAG,EAAE,aAAa;gBAClB,IAAI,EAAE,mBAAmB;gBACzB,IAAI,EAAE,OAAO;gBACb,YAAY,EAAE,GAAG,EAAE;oBACf,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;gBAC3C,CAAC;aACJ;YACD;gBACI,GAAG,EAAE,aAAa;gBAClB,IAAI,EAAE,qBAAqB;gBAC3B,IAAI,EAAE,OAAO;gBACb,OAAO,EAAE,IAAI;gBACb,YAAY,EAAE,GAAG,EAAE;oBACf,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;gBAC3B,CAAC;aACJ;YACD;gBACI,GAAG,EAAE,uBAAuB;gBAC5B,IAAI,EAAE,mBAAmB;gBACzB,IAAI,EAAE,OAAO;gBACb,YAAY,EAAE,GAAG,EAAE;oBACf,IAAI,CAAC,UAAU,CAAC,mBAAmB,EAAE,CAAC;oBACtC,IAAI,CAAC,UAAU,CAAC,mBAAmB,EAAE,CAAC;gBAC1C,CAAC;gBACD,YAAY,EAAE,GAAG,EAAE;oBACf,IAAI,CAAC,UAAU,CAAC,gBAAgB,EAAE,CAAC;gBACvC,CAAC;aACJ;YACD;gBACI,GAAG,EAAE,0BAA0B;gBAC/B,IAAI,EAAE,sBAAsB;gBAC5B,OAAO,EAAE,IAAI;gBACb,IAAI,EAAE,OAAO;gBACb,YAAY,EAAE,GAAG,EAAE;oBACf,IAAI,CAAC,UAAU,CAAC,sBAAsB,EAAE,CAAC;oBACzC,IAAI,CAAC,UAAU,CAAC,mBAAmB,EAAE,CAAC;gBAC1C,CAAC;gBACD,YAAY,EAAE,GAAG,EAAE;oBACf,IAAI,CAAC,UAAU,CAAC,mBAAmB,EAAE,CAAC;gBAC1C,CAAC;aACJ;YACD;gBACI,GAAG,EAAE,cAAc;gBACnB,IAAI,EAAE,OAAO;gBACb,IAAI,EAAE,MAAM;gBACZ,YAAY,EAAE,GAAG,EAAE;oBACf,WAAW,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;oBACrC,IAAI,CAAC,UAAU,CAAC,mBAAmB,EAAE,CAAC;gBAC1C,CAAC;gBACD,YAAY,EAAE,GAAG,EAAE;oBACf,IAAI,CAAC,UAAU,CAAC,iBAAiB,EAAE,CAAC;gBACxC,CAAC;aACJ;SACJ,CAAC;IA/GC,CAAC;IAlBJ,IAAI,QAAQ;QACR,OAAO,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC;IAC1D,CAAC;IAED,IAAI,MAAM;QACN,OAAO,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC;IACrD,CAAC;IAED,IAAI,eAAe;QACf,OAAO,IAAI,CAAC,UAAU,CAAC,8BAA8B,EAAE,CAAC;IAC5D,CAAC;IAyHD,YAAY,CAAC,KAAiB;QAC1B,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE;YACjB,uBAAuB,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;YACvF,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;gBAC7B,IAAI,IAAI,CAAC,GAAG,KAAK,kBAAkB,EAAE;oBACjC,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,UAAU,CAAC,8BAA8B,EAAE,CAAC;iBAC3E;YACL,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,uBAAuB,EAAE;gBACzD,MAAM,EAAE,KAAK,CAAC,MAAqB;gBACnC,YAAY,EAAE;oBACV,YAAY,EAAE,IAAI,CAAC,YAAY;oBAC/B,YAAY,EAAE,CAAC,MAAkB,EAAE,EAAE;wBACjC,MAAM,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;oBAChC,CAAC;oBACD,YAAY,EAAE,CAAC,SAAqB,EAAE,MAAkB,EAAE,EAAE;wBACxD,IAAI,MAAM,CAAC,YAAY,EAAE;4BACrB,MAAM,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;yBAClC;oBACL,CAAC;oBACD,cAAc,EAAE,CAAC,SAAqB,EAAE,MAAkB,EAAE,EAAE;wBAC1D,IAAI,MAAM,CAAC,GAAG,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE;4BACnC,IAAI,CAAC,UAAU,CAAC,mBAAmB,EAAE,CAAC;yBACzC;wBACD,IAAI,MAAM,CAAC,cAAc,EAAE;4BACvB,MAAM,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;yBACpC;oBACL,CAAC;iBACJ;gBACD,cAAc,EAAE;oBACZ,CAAC,EAAE,KAAK,CAAC,CAAC,GAAG,EAAE;oBACf,CAAC,EAAE,KAAK,CAAC,CAAC;iBACb;gBACD,WAAW,EAAE,KAAK;gBAClB,SAAS,EAAE,YAAY;gBACvB,gBAAgB,EAAE,IAAI,CAAC,iBAAiB,CAAC,UAAU,EAAE,CAAC,gBAAgB;gBACtE,aAAa,EAAE,IAAI;gBACnB,cAAc,EAAE,KAAK;gBACrB,gBAAgB,EAAE,KAAK;aAC1B,CAAC,CAAC;YACH,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,GAAG,EAAE;gBACtC,IAAI,CAAC,UAAU,CAAC,kBAAkB,EAAE,CAAC;YACzC,CAAC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACP,CAAC;IAED,gBAAgB;QACZ,IAAI,IAAI,CAAC,QAAQ,EAAE;YACf,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;YACrB,OAAO,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC;SACrC;IACL,CAAC;;wHAzLQ,0BAA0B;4HAA1B,0BAA0B;4FAA1B,0BAA0B;kBADtC,UAAU","sourcesContent":["import { Injectable, NgZone } from '@angular/core';\nimport { BackgroundColors, ColorType, SpecialBackgroundColor, TableHeaderBackgroundColor } from '../constants/color-select';\nimport { TableStore } from '../plugins/table/table.store';\nimport { TheColorSelectService } from './color-select.service';\nimport { TableEditor } from '../plugins/table/table.editor';\nimport { ThyPopoverRef, ThyPopover } from 'ngx-tethys/popover';\nimport { TheContextMenuComponent } from '../components/contextmenu/contextmenu.component';\nimport { TheContextService } from './context.service';\nimport { splitCell } from '../plugins/table/utils/split-cell';\nimport { setCellMenuInvisibility } from '../plugins/table/utils/set-menu-cell-invisibility';\nimport { MenuEntity } from '../plugins/table/table.types';\n\n@Injectable()\nexport class TheTableContextMenuService {\n    menuRef: ThyPopoverRef<TheContextMenuComponent>;\n\n    get isOpened() {\n        return this.menuRef && this.menuRef.componentInstance;\n    }\n\n    get editor() {\n        return this.tableStore && this.tableStore.editor;\n    }\n\n    get backgroundColor() {\n        return this.tableStore.getSelectedCellBackgroundColor();\n    }\n\n    constructor(\n        private colorSelectService: TheColorSelectService,\n        private tableStore: TableStore,\n        private thyPopover: ThyPopover,\n        private ngZone: NgZone,\n        private theContextService: TheContextService\n    ) {}\n\n    menuEntities: MenuEntity[] = [\n        {\n            key: 'background-color',\n            icon: 'background-tt',\n            divider: true,\n            name: '单元格背景',\n            extendIcon: 'angle-right',\n            actionHandle: () => {},\n            activeHandle: (event: MouseEvent) => {\n                if (this.colorSelectService.isOpenColorSelect) {\n                    return;\n                }\n                const isHeader = TableEditor.isActiveHeader(this.editor);\n                this.colorSelectService.toggleColorSelect(\n                    event.target as HTMLElement,\n                    this.backgroundColor,\n                    BackgroundColors,\n                    {\n                        perRowColorNumbers: 7,\n                        rowOptions: { 1: '#bbb', 2: '#bbb' },\n                        specialColor: isHeader ? TableHeaderBackgroundColor : SpecialBackgroundColor\n                    },\n                    (newColor: ColorType) => {\n                        if ((newColor === TableHeaderBackgroundColor && isHeader) || (newColor === SpecialBackgroundColor && !isHeader)) {\n                            this.tableStore.setSelectedCellsBackgroundColor(null);\n                        } else {\n                            this.tableStore.setSelectedCellsBackgroundColor(newColor);\n                        }\n                        this.tableStore.selectFirstCell();\n                    },\n                    'rightTop',\n                    0\n                );\n            },\n            deactiveHandle: (event: MouseEvent) => {\n                if (event.relatedTarget instanceof HTMLElement) {\n                    if (event.relatedTarget.classList.contains('color-container')) {\n                        return;\n                    }\n                }\n                if (this.colorSelectService.isOpenColorSelect) {\n                    this.colorSelectService.closeColorSelect();\n                }\n            }\n        },\n        {\n            key: 'clear-selection',\n            icon: 'sweep',\n            divider: true,\n            name: '清空选中区域',\n            actionHandle: () => {\n                this.tableStore.clearSelectedCellsContent();\n                this.tableStore.selectFirstCell();\n            }\n        },\n        {\n            key: 'merge-cells',\n            icon: 'table-merge-cells',\n            name: '合并单元格',\n            actionHandle: () => {\n                this.tableStore.mergeCell(this.editor);\n            }\n        },\n        {\n            key: 'split-cells',\n            icon: 'table-unmerge-cells',\n            name: '拆分单元格',\n            divider: true,\n            actionHandle: () => {\n                splitCell(this.editor);\n            }\n        },\n        {\n            key: 'delete-selection-rows',\n            icon: 'table-delete-rows',\n            name: '删除所在行',\n            actionHandle: () => {\n                this.tableStore.removeDangerousRows();\n                this.tableStore.clearDangerousCells();\n            },\n            activeHandle: () => {\n                this.tableStore.setDangerousRows();\n            }\n        },\n        {\n            key: 'delete-selection-columns',\n            icon: 'table-delete-columns',\n            divider: true,\n            name: '删除所在列',\n            actionHandle: () => {\n                this.tableStore.removeDangerousColumns();\n                this.tableStore.clearDangerousCells();\n            },\n            activeHandle: () => {\n                this.tableStore.setDangerousColumns();\n            }\n        },\n        {\n            key: 'delete-table',\n            icon: 'trash',\n            name: '删除表格',\n            actionHandle: () => {\n                TableEditor.removeTable(this.editor);\n                this.tableStore.clearDangerousCells();\n            },\n            activeHandle: () => {\n                this.tableStore.setDangerousTable();\n            }\n        }\n    ];\n\n    openMenuList(event: MouseEvent) {\n        this.ngZone.run(() => {\n            setCellMenuInvisibility(this.editor, this.menuEntities, this.tableStore.selectedCells);\n            this.menuEntities.forEach(item => {\n                if (item.key === 'background-color') {\n                    item.backgroundColor = this.tableStore.getSelectedCellBackgroundColor();\n                }\n            });\n            this.menuRef = this.thyPopover.open(TheContextMenuComponent, {\n                origin: event.target as HTMLElement,\n                initialState: {\n                    menuEntities: this.menuEntities,\n                    actionHandle: (entity: MenuEntity) => {\n                        entity.actionHandle(entity);\n                    },\n                    activeHandle: (menuEvent: MouseEvent, entity: MenuEntity) => {\n                        if (entity.activeHandle) {\n                            entity.activeHandle(menuEvent);\n                        }\n                    },\n                    deactiveHandle: (menuEvent: MouseEvent, entity: MenuEntity) => {\n                        if (entity.key.indexOf('delete') >= 0) {\n                            this.tableStore.clearDangerousCells();\n                        }\n                        if (entity.deactiveHandle) {\n                            entity.deactiveHandle(menuEvent);\n                        }\n                    }\n                },\n                originPosition: {\n                    x: event.x + 30,\n                    y: event.y\n                },\n                hasBackdrop: false,\n                placement: 'bottomLeft',\n                viewContainerRef: this.theContextService.getOptions().viewContainerRef,\n                manualClosure: true,\n                insideClosable: false,\n                backdropClosable: false\n            });\n            this.menuRef.afterClosed().subscribe(() => {\n                this.tableStore.clearSelectedCells();\n            });\n        });\n    }\n\n    closeContextMenu() {\n        if (this.isOpened) {\n            this.menuRef.close();\n            return this.menuRef.afterClosed();\n        }\n    }\n}\n"]}
190
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-contextmenu.service.js","sourceRoot":"","sources":["../../../../packages/src/services/table-contextmenu.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, NgZone } from '@angular/core';\nimport { BackgroundColors, ColorType, SpecialBackgroundColor, TableHeaderBackgroundColor } from '../constants/color-select';\nimport { TableStore } from '../plugins/table/table.store';\nimport { TheColorSelectService } from './color-select.service';\nimport { TableEditor } from '../plugins/table/table.editor';\nimport { ThyPopoverRef, ThyPopover } from 'ngx-tethys/popover';\nimport { TheContextMenuComponent } from '../components/contextmenu/contextmenu.component';\nimport { TheContextService } from './context.service';\nimport { splitCell } from '../plugins/table/utils/split-cell';\nimport { setCellMenuInvisibility } from '../plugins/table/utils/set-menu-cell-invisibility';\nimport { MenuEntity } from '../plugins/table/table.types';\n\n@Injectable()\nexport class TheTableContextMenuService {\n    menuRef: ThyPopoverRef<TheContextMenuComponent>;\n\n    get isOpened() {\n        return this.menuRef && this.menuRef.componentInstance;\n    }\n\n    get editor() {\n        return this.tableStore && this.tableStore.editor;\n    }\n\n    get backgroundColor() {\n        return this.tableStore.getSelectedCellBackgroundColor();\n    }\n\n    constructor(\n        private colorSelectService: TheColorSelectService,\n        private tableStore: TableStore,\n        private thyPopover: ThyPopover,\n        private ngZone: NgZone,\n        private theContextService: TheContextService\n    ) {}\n\n    menuEntities: MenuEntity[] = [\n        {\n            key: 'background-color',\n            icon: 'background-tt',\n            divider: true,\n            name: '单元格背景',\n            extendIcon: 'angle-right',\n            actionHandle: () => {},\n            activeHandle: (event: MouseEvent) => {\n                if (this.colorSelectService.isOpenColorSelect) {\n                    return;\n                }\n                const isHeader = TableEditor.isActiveHeader(this.editor);\n                this.colorSelectService.toggleColorSelect(\n                    event.target as HTMLElement,\n                    this.backgroundColor,\n                    BackgroundColors,\n                    {\n                        perRowColorNumbers: 7,\n                        rowOptions: { 1: '#bbb', 2: '#bbb' },\n                        specialColor: isHeader ? TableHeaderBackgroundColor : SpecialBackgroundColor\n                    },\n                    (newColor: ColorType) => {\n                        if ((newColor === TableHeaderBackgroundColor && isHeader) || (newColor === SpecialBackgroundColor && !isHeader)) {\n                            this.tableStore.setSelectedCellsBackgroundColor(null);\n                        } else {\n                            this.tableStore.setSelectedCellsBackgroundColor(newColor);\n                        }\n                        this.tableStore.selectFirstCell();\n                    },\n                    'rightTop',\n                    0\n                );\n            },\n            deactiveHandle: (event: MouseEvent) => {\n                if (event.relatedTarget instanceof HTMLElement) {\n                    if (event.relatedTarget.classList.contains('color-container')) {\n                        return;\n                    }\n                }\n                if (this.colorSelectService.isOpenColorSelect) {\n                    this.colorSelectService.closeColorSelect();\n                }\n            }\n        },\n        {\n            key: 'clear-selection',\n            icon: 'sweep',\n            divider: true,\n            name: '清空选中区域',\n            actionHandle: () => {\n                this.tableStore.clearSelectedCellsContent();\n                this.tableStore.selectFirstCell();\n            }\n        },\n        {\n            key: 'merge-cells',\n            icon: 'table-merge-cells',\n            name: '合并单元格',\n            actionHandle: () => {\n                this.tableStore.mergeCell(this.editor);\n            }\n        },\n        {\n            key: 'split-cells',\n            icon: 'table-unmerge-cells',\n            name: '拆分单元格',\n            divider: true,\n            actionHandle: () => {\n                splitCell(this.editor);\n            }\n        },\n        {\n            key: 'delete-selection-rows',\n            icon: 'table-delete-rows',\n            name: '删除所在行',\n            actionHandle: () => {\n                this.tableStore.removeDangerousRows();\n                this.tableStore.clearDangerousCells();\n            },\n            activeHandle: () => {\n                this.tableStore.setDangerousRows();\n            }\n        },\n        {\n            key: 'delete-selection-columns',\n            icon: 'table-delete-columns',\n            divider: true,\n            name: '删除所在列',\n            actionHandle: () => {\n                this.tableStore.removeDangerousColumns();\n                this.tableStore.clearDangerousCells();\n            },\n            activeHandle: () => {\n                this.tableStore.setDangerousColumns();\n            }\n        },\n        {\n            key: 'delete-table',\n            icon: 'trash',\n            name: '删除表格',\n            actionHandle: () => {\n                TableEditor.removeTable(this.editor);\n                this.tableStore.clearDangerousCells();\n            },\n            activeHandle: () => {\n                this.tableStore.setDangerousTable();\n            }\n        }\n    ];\n\n    openMenuList(event: MouseEvent) {\n        this.ngZone.run(() => {\n            setCellMenuInvisibility(this.editor, this.menuEntities, this.tableStore.selectedCells);\n            this.menuEntities.forEach(item => {\n                if (item.key === 'background-color') {\n                    item.backgroundColor = this.tableStore.getSelectedCellBackgroundColor();\n                }\n            });\n            this.menuRef = this.thyPopover.open(TheContextMenuComponent, {\n                origin: event.target as HTMLElement,\n                initialState: {\n                    menuEntities: this.menuEntities,\n                    actionHandle: (entity: MenuEntity) => {\n                        entity.actionHandle(entity);\n                    },\n                    activeHandle: (menuEvent: MouseEvent, entity: MenuEntity) => {\n                        if (entity.activeHandle) {\n                            entity.activeHandle(menuEvent);\n                        }\n                    },\n                    deactiveHandle: (menuEvent: MouseEvent, entity: MenuEntity) => {\n                        if (entity.key.indexOf('delete') >= 0) {\n                            this.tableStore.clearDangerousCells();\n                        }\n                        if (entity.deactiveHandle) {\n                            entity.deactiveHandle(menuEvent);\n                        }\n                    }\n                },\n                originPosition: {\n                    x: event.x + 30,\n                    y: event.y\n                },\n                hasBackdrop: false,\n                minWidth: 0,\n                placement: 'bottomLeft',\n                viewContainerRef: this.theContextService.getOptions().viewContainerRef,\n                manualClosure: true,\n                insideClosable: false,\n                backdropClosable: false\n            });\n            this.menuRef.afterClosed().subscribe(() => {\n                this.tableStore.clearSelectedCells();\n            });\n        });\n    }\n\n    closeContextMenu() {\n        if (this.isOpened) {\n            this.menuRef.close();\n            return this.menuRef.afterClosed();\n        }\n    }\n}\n"]}
@@ -10,7 +10,7 @@ import { mixinUnsubscribe, MixinBase } from 'ngx-tethys/core';
10
10
  import isHotkey, { isKeyHotkey } from 'is-hotkey';
11
11
  import { Range, Node, Element as Element$1, Text, Editor, Transforms, Span, Path, Point, Operation, createEditor } from 'slate';
12
12
  import { HistoryEditor, withHistory } from 'slate-history';
13
- import { fromEvent, timer, Subject, combineLatest, Observable, BehaviorSubject, merge, ReplaySubject } from 'rxjs';
13
+ import { Subject, fromEvent, timer, combineLatest, Observable, BehaviorSubject, merge, ReplaySubject } from 'rxjs';
14
14
  import * as i1$1 from 'ngx-tethys/popover';
15
15
  import { ThyPopover } from 'ngx-tethys/popover';
16
16
  import * as i3 from 'ngx-tethys/icon';
@@ -572,11 +572,12 @@ var PluginKeys;
572
572
  class TheContextService {
573
573
  constructor(ngZone) {
574
574
  this.ngZone = ngZone;
575
- this.fileList = [];
575
+ this.uploadingFiles = [];
576
576
  this.paintFormatStatus = {
577
577
  isActive: false,
578
578
  marks: {}
579
579
  };
580
+ this.uploadingStatus$ = new Subject();
580
581
  this.ngZone.runOutsideAngular(() => {
581
582
  this.onMouseUp$ = fromEvent(window, `mouseup`);
582
583
  this.onMouseMove$ = fromEvent(window, `mousemove`);
@@ -611,11 +612,11 @@ class TheContextService {
611
612
  const firstElementChild = this.getFirstElementChild();
612
613
  return 0.48 * firstElementChild.clientWidth;
613
614
  }
614
- setUploadFileList(file) {
615
- this.fileList.push(file);
615
+ addUploadingFiles(file) {
616
+ this.uploadingFiles.push(file);
616
617
  }
617
618
  removeUploadImage(file) {
618
- this.fileList.splice(this.fileList.findIndex(item => item.file === file), 1);
619
+ this.uploadingFiles.splice(this.uploadingFiles.findIndex(item => item.url === file.url), 1);
619
620
  }
620
621
  }
621
622
  TheContextService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheContextService, deps: [{ token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Injectable });
@@ -754,6 +755,7 @@ class TheColorSelectService {
754
755
  option
755
756
  },
756
757
  origin,
758
+ minWidth: 0,
757
759
  backdropClosable: this.backdropClosable,
758
760
  placement: placement || this.placement,
759
761
  offset: offset !== null ? offset : this.offset,
@@ -2045,14 +2047,17 @@ const getToolbarItemDisabled = (editor, key, customTypes) => {
2045
2047
  }
2046
2048
  };
2047
2049
 
2048
- const getPluginKeyByToolbarKey = (editor, toolbarKey) => {
2050
+ const getPluginByToolbarItem = (editor, toolbarItem) => {
2051
+ const pluginKey = toolbarItem.pluginKey;
2052
+ if (pluginKey) {
2053
+ return editor.pluginsByKey[pluginKey];
2054
+ }
2049
2055
  for (let key in editor.pluginsByKey) {
2050
2056
  const toolbarItems = editor.pluginsByKey[key].toolbarItems;
2051
- if (toolbarItems && toolbarItems.some(item => item.key === toolbarKey)) {
2052
- toolbarKey = key;
2057
+ if (toolbarItems && toolbarItems.some(item => item.key === toolbarItem.key)) {
2058
+ return editor.pluginsByKey[key];
2053
2059
  }
2054
2060
  }
2055
- return toolbarKey;
2056
2061
  };
2057
2062
 
2058
2063
  var index$1 = /*#__PURE__*/Object.freeze({
@@ -2113,7 +2118,7 @@ var index$1 = /*#__PURE__*/Object.freeze({
2113
2118
  findDescendant: findDescendant,
2114
2119
  someNode: someNode,
2115
2120
  getToolbarItemDisabled: getToolbarItemDisabled,
2116
- getPluginKeyByToolbarKey: getPluginKeyByToolbarKey
2121
+ getPluginByToolbarItem: getPluginByToolbarItem
2117
2122
  });
2118
2123
 
2119
2124
  const insertElements = (editor, elements) => {
@@ -2456,6 +2461,7 @@ const withDeserializeMd = (editor) => {
2456
2461
  viewContainerRef,
2457
2462
  placement,
2458
2463
  offset: -100,
2464
+ minWidth: 0,
2459
2465
  hasBackdrop: false,
2460
2466
  backdropClosable: false,
2461
2467
  closeOnNavigation: false,
@@ -2669,6 +2675,7 @@ const ImageEditor = {
2669
2675
  const inputFile = document.createElement('input');
2670
2676
  inputFile.setAttribute('type', 'file');
2671
2677
  inputFile.setAttribute('accept', 'image/*');
2678
+ inputFile.setAttribute('multiple', 'true');
2672
2679
  inputFile.onchange = (event) => {
2673
2680
  ImageEditor.insertImages(editor, event.target.files);
2674
2681
  };
@@ -2682,10 +2689,7 @@ const ImageEditor = {
2682
2689
  const verify = ImageEditor.verifyImage(editor, image);
2683
2690
  if (verify) {
2684
2691
  const url = URL.createObjectURL(image);
2685
- contextService.setUploadFileList({
2686
- url,
2687
- file: image
2688
- });
2692
+ contextService.addUploadingFiles({ url, file: image });
2689
2693
  imageNodes.push({ type: ElementKinds.image, url, children: [text] });
2690
2694
  }
2691
2695
  }
@@ -2833,9 +2837,9 @@ class TheImageComponent extends TheBaseElementComponent {
2833
2837
  ngOnInit() {
2834
2838
  var _a;
2835
2839
  this.layoutDefaultWidth = this.theContextService.layoutDefaultWidth();
2836
- this.file = (_a = this.theContextService.fileList.find(item => item.url === this.element.url)) === null || _a === void 0 ? void 0 : _a.file;
2837
- if (this.file && this.file instanceof File) {
2838
- this.uploadImage(this.file);
2840
+ this.fileItem = this.theContextService.uploadingFiles.find(item => item.url === this.element.url);
2841
+ if (((_a = this.fileItem) === null || _a === void 0 ? void 0 : _a.file) && this.fileItem.file instanceof File) {
2842
+ this.uploadImage(this.fileItem.file);
2839
2843
  }
2840
2844
  super.ngOnInit();
2841
2845
  }
@@ -2859,16 +2863,19 @@ class TheImageComponent extends TheBaseElementComponent {
2859
2863
  this.mouseUpSubscription = this.theContextService.onMouseUp$.subscribe(e => this.endDrag(e));
2860
2864
  this.uploadingSubscription = this.imageUploaderService
2861
2865
  .getUploadingItems$()
2862
- .pipe(map(fileUploadingItem => this.file && fileUploadingItem.find(item => item.file === this.file)))
2866
+ .pipe(map(fileUploadingItem => { var _a; return ((_a = this.fileItem) === null || _a === void 0 ? void 0 : _a.file) && fileUploadingItem.find(item => { var _a; return item.file === ((_a = this.fileItem) === null || _a === void 0 ? void 0 : _a.file); }); }))
2863
2867
  .subscribe(uploadingItem => {
2864
2868
  if (!uploadingItem || !uploadingItem.result) {
2865
2869
  return;
2866
2870
  }
2867
2871
  this.percentage = uploadingItem.result.uploadFile.progress.percentage;
2868
- const { status, uploadFile } = uploadingItem.result;
2869
- if (status === ThyUploadStatus.done && uploadFile.response && uploadFile.responseStatus === 200) {
2870
- this.uploading = false;
2872
+ const { status } = uploadingItem.result;
2873
+ // 成功和失败都要上传结束
2874
+ if (status === ThyUploadStatus.done) {
2871
2875
  this.uploadingSubscription.unsubscribe();
2876
+ this.uploading = false;
2877
+ this.theContextService.removeUploadImage(this.fileItem);
2878
+ this.theContextService.uploadingStatus$.next(false);
2872
2879
  }
2873
2880
  this.cdr.detectChanges();
2874
2881
  });
@@ -2883,6 +2890,7 @@ class TheImageComponent extends TheBaseElementComponent {
2883
2890
  thumbUrl: this.sanitizer.bypassSecurityTrustResourceUrl(URL.createObjectURL(file))
2884
2891
  };
2885
2892
  this.uploading = true;
2893
+ this.theContextService.uploadingStatus$.next(true);
2886
2894
  const [uploadFileEntity] = yield this.imageUploaderService.uploadFileHandle([file]).toPromise();
2887
2895
  const path = AngularEditor.findPath(this.editor, this.element);
2888
2896
  const { thumbUrl, originUrl } = uploadFileEntity;
@@ -3013,6 +3021,7 @@ class TheImageComponent extends TheBaseElementComponent {
3013
3021
  backdropClosable: true,
3014
3022
  hasBackdrop: false,
3015
3023
  offset: 10,
3024
+ minWidth: 0,
3016
3025
  viewContainerRef: this.viewContainerRef,
3017
3026
  scrollStrategy: this.overlay.scrollStrategies.reposition()
3018
3027
  });
@@ -6830,15 +6839,15 @@ class TheBaseToolbarItem {
6830
6839
  }
6831
6840
  }
6832
6841
  selectionChange(editor) {
6833
- var _a, _b, _c, _d, _e, _f;
6842
+ var _a, _b, _c, _d, _e;
6834
6843
  if (editor.selection) {
6835
6844
  this.active = ((_a = this._toolbarItem) === null || _a === void 0 ? void 0 : _a.active) ? (_b = this._toolbarItem) === null || _b === void 0 ? void 0 : _b.active(editor) : false;
6836
6845
  if ((_c = this._toolbarItem) === null || _c === void 0 ? void 0 : _c.disable) {
6837
6846
  this.disabled = ((_d = this._toolbarItem) === null || _d === void 0 ? void 0 : _d.disable) ? (_e = this._toolbarItem) === null || _e === void 0 ? void 0 : _e.disable(editor) : false;
6838
6847
  }
6839
6848
  else {
6840
- const pluginKey = getPluginKeyByToolbarKey(editor, (_f = this._toolbarItem) === null || _f === void 0 ? void 0 : _f.key);
6841
- this.disabled = pluginKey && getToolbarItemDisabled(editor, pluginKey);
6849
+ const thePlugin = getPluginByToolbarItem(editor, this._toolbarItem);
6850
+ this.disabled = thePlugin && getToolbarItemDisabled(editor, thePlugin.key);
6842
6851
  }
6843
6852
  }
6844
6853
  }
@@ -6952,6 +6961,7 @@ class TheToolbarDropdownComponent extends TheBaseToolbarDropdown {
6952
6961
  backdropClosable: true,
6953
6962
  hasBackdrop: false,
6954
6963
  offset: 10,
6964
+ minWidth: 0,
6955
6965
  viewContainerRef: this.viewContainerRef,
6956
6966
  scrollStrategy: this.overlay.scrollStrategies.reposition()
6957
6967
  });
@@ -6983,7 +6993,7 @@ class TheToolbarDropdownComponent extends TheBaseToolbarDropdown {
6983
6993
  }
6984
6994
  }
6985
6995
  TheToolbarDropdownComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheToolbarDropdownComponent, deps: [{ token: i0.ElementRef }, { token: i1$1.ThyPopover }, { token: i0.ViewContainerRef }, { token: i2.Overlay }], target: i0.ɵɵFactoryTarget.Component });
6986
- TheToolbarDropdownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.15", type: TheToolbarDropdownComponent, selector: "the-toolbar-dropdown", inputs: { itemMousedownHandle: "itemMousedownHandle" }, host: { listeners: { "mousedown": "toggleDropdown($event)", "document: mousedown": "handleDocumentMouseDown($event)" }, classAttribute: "the-toolbar-dropdown-container" }, viewQueries: [{ propertyName: "iconModeTemplate", first: true, predicate: ["iconModeTemplate"], descendants: true, static: true }, { propertyName: "textModeTemplate", first: true, predicate: ["textModeTemplate"], descendants: true, static: true }, { propertyName: "dropdownTemplate", first: true, predicate: ["dropdownTemplate"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<ng-template [ngTemplateOutlet]=\"template\"></ng-template>\n\n<ng-template #iconModeTemplate>\n <a thyIconNavLink class=\"icon-mode link-with-down\" [thyTooltip]=\"activeMenuItem?.name\" thyTooltipPlacement=\"top\">\n <thy-icon [thyIconName]=\"activeMenuItem?.icon\"></thy-icon>\n <thy-icon class=\"caret-down-icon font-size-sm text-desc\" thyIconName=\"caret-down\"></thy-icon>\n </a>\n</ng-template>\n\n<ng-template #textModeTemplate>\n <a thyIconNavLink class=\"text-mode\" [thyTooltip]=\"activeMenuItem?.name\" thyTooltipPlacement=\"top\">\n <span class=\"show-text\">{{ activeMenuItem?.name }}</span>\n <thy-icon class=\"text-caret-down-icon font-size-sm text-desc\" thyIconName=\"caret-down\"></thy-icon>\n </a>\n</ng-template>\n\n<ng-template #dropdownTemplate>\n <thy-action-menu class=\"dropdown\">\n <ng-container *ngFor=\"let menu of menus\">\n <a\n *ngIf=\"menu.key !== 'split'\"\n thyActionMenuItem\n href=\"javascript:;\"\n [thyActionMenuItemActive]=\"menu.key === activeMenuItem.key && !toolbarItem.dropdownFixedIcon\"\n (mousedown)=\"itemMousedown($event, menu)\"\n [ngStyle]=\"menu?.styles\"\n >\n <span *ngIf=\"menu.icon && mode === dropdownMode.icon\" thyActionMenuItemIcon>\n <thy-icon [thyIconName]=\"menu.icon\"></thy-icon>\n </span>\n <span *ngIf=\"menu.name\" thyActionMenuItemName>{{ menu.name }}</span>\n </a>\n <thy-action-menu-divider *ngIf=\"menu.key === 'split'\"></thy-action-menu-divider>\n </ng-container>\n </thy-action-menu>\n</ng-template>\n", components: [{ type: i3$1.ThyIconNavLinkComponent, selector: "[thyIconNavLink]", inputs: ["thyIconNavLinkIcon", "thyIconNavLinkActive"] }, { type: i3.ThyIconComponent, selector: "thy-icon", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { type: i2$1.ThyActionMenuComponent, selector: "thy-action-menu", inputs: ["thyTheme", "thyWidth"] }, { type: i2$1.ThyActionMenuDividerComponent, selector: "thy-action-menu-divider", inputs: ["thyTitle", "thyType"] }], directives: [{ type: i10.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i5$1.ThyTooltipDirective, selector: "[thyTooltip],[thy-tooltip]", inputs: ["thyTooltip", "thyTooltipPlacement", "thyTooltipClass", "thyTooltipShowDelay", "thyTooltipHideDelay", "thyTooltipTrigger", "thyTooltipDisabled", "thyTooltipTemplateContext", "thyTooltipOffset", "thyTooltipPin"], exportAs: ["thyTooltip"] }, { type: i10.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2$1.ThyActionMenuItemDirective, selector: "[thyActionMenuItem]", inputs: ["thyDisabled", "thyType"] }, { type: i2$1.ThyActionMenuItemActiveDirective, selector: "[thyActionMenuItemActive]", inputs: ["thyActionMenuItemActive"] }, { type: i10.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i2$1.ThyActionMenuItemIconDirective, selector: "[thyActionMenuItemIcon]" }, { type: i2$1.ThyActionMenuItemNameDirective, selector: "[thyActionMenuItemName]" }] });
6996
+ TheToolbarDropdownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.15", type: TheToolbarDropdownComponent, selector: "the-toolbar-dropdown", inputs: { itemMousedownHandle: "itemMousedownHandle" }, host: { listeners: { "mousedown": "toggleDropdown($event)", "document: mousedown": "handleDocumentMouseDown($event)" }, classAttribute: "the-toolbar-dropdown-container" }, viewQueries: [{ propertyName: "iconModeTemplate", first: true, predicate: ["iconModeTemplate"], descendants: true, static: true }, { propertyName: "textModeTemplate", first: true, predicate: ["textModeTemplate"], descendants: true, static: true }, { propertyName: "dropdownTemplate", first: true, predicate: ["dropdownTemplate"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<ng-template [ngTemplateOutlet]=\"template\"></ng-template>\n\n<ng-template #iconModeTemplate>\n <a thyIconNavLink class=\"icon-mode link-with-down\" [thyTooltip]=\"activeMenuItem?.name\" thyTooltipPlacement=\"top\">\n <thy-icon [thyIconName]=\"activeMenuItem?.icon\"></thy-icon>\n <thy-icon class=\"caret-down-icon font-size-sm text-desc\" thyIconName=\"caret-down\"></thy-icon>\n </a>\n</ng-template>\n\n<ng-template #textModeTemplate>\n <a thyIconNavLink class=\"text-mode\" [thyTooltip]=\"activeMenuItem?.name\" thyTooltipPlacement=\"top\">\n <span class=\"show-text\">{{ activeMenuItem?.name }}</span>\n <thy-icon class=\"text-caret-down-icon font-size-sm text-desc\" thyIconName=\"caret-down\"></thy-icon>\n </a>\n</ng-template>\n\n<ng-template #dropdownTemplate>\n <thy-action-menu class=\"dropdown\">\n <ng-container *ngFor=\"let menu of menus\">\n <a\n *ngIf=\"menu.key !== 'split'\"\n thyActionMenuItem\n href=\"javascript:;\"\n [thyActionMenuItemActive]=\"menu.key === activeMenuItem?.key && !toolbarItem?.dropdownFixedIcon\"\n (mousedown)=\"itemMousedown($event, menu)\"\n [ngStyle]=\"menu?.styles\"\n >\n <span *ngIf=\"menu.icon && mode === dropdownMode.icon\" thyActionMenuItemIcon>\n <thy-icon [thyIconName]=\"menu.icon\"></thy-icon>\n </span>\n <span *ngIf=\"menu.name\" thyActionMenuItemName>{{ menu.name }}</span>\n </a>\n <thy-action-menu-divider *ngIf=\"menu.key === 'split'\"></thy-action-menu-divider>\n </ng-container>\n </thy-action-menu>\n</ng-template>\n", components: [{ type: i3$1.ThyIconNavLinkComponent, selector: "[thyIconNavLink]", inputs: ["thyIconNavLinkIcon", "thyIconNavLinkActive"] }, { type: i3.ThyIconComponent, selector: "thy-icon", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { type: i2$1.ThyActionMenuComponent, selector: "thy-action-menu", inputs: ["thyTheme", "thyWidth"] }, { type: i2$1.ThyActionMenuDividerComponent, selector: "thy-action-menu-divider", inputs: ["thyTitle", "thyType"] }], directives: [{ type: i10.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i5$1.ThyTooltipDirective, selector: "[thyTooltip],[thy-tooltip]", inputs: ["thyTooltip", "thyTooltipPlacement", "thyTooltipClass", "thyTooltipShowDelay", "thyTooltipHideDelay", "thyTooltipTrigger", "thyTooltipDisabled", "thyTooltipTemplateContext", "thyTooltipOffset", "thyTooltipPin"], exportAs: ["thyTooltip"] }, { type: i10.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2$1.ThyActionMenuItemDirective, selector: "[thyActionMenuItem]", inputs: ["thyDisabled", "thyType"] }, { type: i2$1.ThyActionMenuItemActiveDirective, selector: "[thyActionMenuItemActive]", inputs: ["thyActionMenuItemActive"] }, { type: i10.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i2$1.ThyActionMenuItemIconDirective, selector: "[thyActionMenuItemIcon]" }, { type: i2$1.ThyActionMenuItemNameDirective, selector: "[thyActionMenuItemName]" }] });
6987
6997
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheToolbarDropdownComponent, decorators: [{
6988
6998
  type: Component,
6989
6999
  args: [{
@@ -7181,7 +7191,10 @@ class TheCodeComponent extends TheBaseElementComponent {
7181
7191
  }
7182
7192
  useMode() {
7183
7193
  this.options = Object.assign(Object.assign({}, this.options), { mode: this.element.language });
7184
- this.activeLanguage = this.menus.find(i => i.key === this.element.language);
7194
+ const menuItem = this.menus.find(i => i.key === this.element.language);
7195
+ if (menuItem) {
7196
+ this.activeLanguage = menuItem;
7197
+ }
7185
7198
  }
7186
7199
  useAutoWrap() {
7187
7200
  this.options = Object.assign(Object.assign({}, this.options), { lineWrapping: this.element.autoWrap || false });
@@ -7214,7 +7227,7 @@ class TheCodeComponent extends TheBaseElementComponent {
7214
7227
  }
7215
7228
  }
7216
7229
  TheCodeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheCodeComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i1$4.ThyNotifyService }, { token: TheContextService }, { token: i0.NgZone }, { token: THE_MODE_TOKEN }], target: i0.ɵɵFactoryTarget.Component });
7217
- TheCodeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.15", type: TheCodeComponent, selector: "div[theCode]", viewQueries: [{ propertyName: "codemirror", first: true, predicate: ["codemirror"], descendants: true, read: CodeMirrorComponent }], usesInheritance: true, ngImport: i0, template: "<div contenteditable=\"false\" class=\"the-code-block-operation\" *ngIf=\"isCollapsed && codemirror && !options.readOnly\">\n <thy-icon-nav>\n <the-toolbar-dropdown\n [menus]=\"menus\"\n [toolbarItem]=\"activeLanguage\"\n [dropdownItemKey]=\"activeLanguage.key\"\n [itemMousedownHandle]=\"onChangeLanguage\"\n >\n </the-toolbar-dropdown>\n <span class=\"auto-wrap d-flex align-items-center\">\n <span>\u81EA\u52A8\u6362\u884C</span>\n <thy-switch\n class=\"auto-wrap-btn d-flex\"\n [(ngModel)]=\"options.lineWrapping\"\n (ngModelChange)=\"onChangeWrap($event)\"\n thySize=\"sm\"\n ></thy-switch>\n </span>\n <a\n href=\"javascript:;\"\n thyIconNavLink\n thyIconNavLinkIcon=\"copy\"\n thyTooltip=\"\u590D\u5236\"\n thyTooltipPlacement=\"top\"\n (mousedown)=\"onCopy($event)\"\n ></a>\n <nav-split-line [mode]=\"ToolbarItemMode.vertical\"></nav-split-line>\n <a\n href=\"javascript:;\"\n thyIconNavLink\n thyIconNavLinkIcon=\"trash\"\n thyTooltip=\"\u5220\u9664\"\n class=\"remove-link\"\n thyTooltipPlacement=\"top\"\n (mousedown)=\"onDelete($event)\"\n ></a>\n </thy-icon-nav>\n</div>\n\n<slate-children [children]=\"children\" [context]=\"childrenContext\" [viewContext]=\"viewContext\"></slate-children>\n\n<!-- \u53EA\u8BFB\u6A21\u5F0F\u4E0BCodeMirror-sizer\u9AD8\u5EA6\u6BD4\u7F16\u8F91\u6A21\u5F0F\u4E0B\u591A2px\uFF0C\u8BBE\u7F6EthyMinHeight\u4E3A46px\u9632\u6B62\u62D6\u62FD\u5230\u6700\u5C0F\u9AD8\u5EA6\u65F6\u53EA\u8BFB\u6A21\u5F0F\u4E0B\u51FA\u73B0\u6EDA\u52A8\u6761 -->\n<div\n thyResizable\n [thyMinHeight]=\"46\"\n [thyBounds]=\"resizeBounds\"\n [style.height.px]=\"resizeHeight\"\n (thyResize)=\"onResize($event)\"\n (thyResizeEnd)=\"onEndResize()\"\n class=\"resize-code-container\"\n [ngClass]=\"{ focus: isCollapsed, readonly: options.readOnly, active: isHightLight && isCollapsed }\"\n>\n <ng-codemirror\n *ngIf=\"startRenderCodemirror\"\n #codemirror\n contenteditable=\"false\"\n class=\"ng-codemirror-wrapper\"\n [ngStyle]=\"{ maxHeight: maxHeight > 0 ? maxHeight + 'px' : 'auto' }\"\n [options]=\"options\"\n [ngModel]=\"code\"\n [delayRefreshTime]=\"300\"\n (ngModelChange)=\"codeChange($event)\"\n (focusChange)=\"focusChange($event)\"\n [autoMaxHeight]=\"maxHeight\"\n >\n </ng-codemirror>\n <thy-resize-handle thyDirection=\"bottom\" class=\"code-resize-icon\" *ngIf=\"isCollapsed && !options.readOnly\"></thy-resize-handle>\n</div>\n", components: [{ type: i3$1.ThyIconNavComponent, selector: "thy-icon-nav", inputs: ["thyType"] }, { type: TheToolbarDropdownComponent, selector: "the-toolbar-dropdown", inputs: ["itemMousedownHandle"] }, { type: i5$2.ThySwitchComponent, selector: "thy-switch", inputs: ["thyType", "thySize", "thyDisabled"], outputs: ["thyChange"] }, { type: i3$1.ThyIconNavLinkComponent, selector: "[thyIconNavLink]", inputs: ["thyIconNavLinkIcon", "thyIconNavLinkActive"] }, { type: NavSplitLineComponent, selector: "nav-split-line", inputs: ["mode"] }, { type: i1.SlateChildrenComponent, selector: "slate-children", inputs: ["children", "context", "viewContext"] }, { type: i8.CodeMirrorComponent, selector: "ng-codemirror, [ngCodeMirror]", inputs: ["autoMaxHeight", "delayRefreshTime", "options"], outputs: ["focusChange"] }, { type: i9.ThyResizeHandleComponent, selector: "thy-resize-handle, [thy-resize-handle]", inputs: ["thyDirection"], outputs: ["thyMouseDown"], exportAs: ["thyResizeHandle"] }], directives: [{ type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i5$1.ThyTooltipDirective, selector: "[thyTooltip],[thy-tooltip]", inputs: ["thyTooltip", "thyTooltipPlacement", "thyTooltipClass", "thyTooltipShowDelay", "thyTooltipHideDelay", "thyTooltipTrigger", "thyTooltipDisabled", "thyTooltipTemplateContext", "thyTooltipOffset", "thyTooltipPin"], exportAs: ["thyTooltip"] }, { type: i9.ThyResizableDirective, selector: "[thyResizable]", inputs: ["thyBounds", "thyMaxHeight", "thyMaxWidth", "thyMinHeight", "thyMinWidth", "thyGridColumnCount", "thyMaxColumn", "thyMinColumn", "thyLockAspectRatio", "thyPreview", "thyDisabled"], outputs: ["thyResize", "thyResizeEnd", "thyResizeStart"] }, { type: i10.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i10.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
7230
+ TheCodeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.15", type: TheCodeComponent, selector: "div[theCode]", viewQueries: [{ propertyName: "codemirror", first: true, predicate: ["codemirror"], descendants: true, read: CodeMirrorComponent }], usesInheritance: true, ngImport: i0, template: "<div contenteditable=\"false\" class=\"the-code-block-operation\" *ngIf=\"isCollapsed && codemirror && !options.readOnly\">\n <thy-icon-nav>\n <the-toolbar-dropdown\n [menus]=\"menus\"\n [toolbarItem]=\"activeLanguage\"\n [dropdownItemKey]=\"activeLanguage?.key\"\n [itemMousedownHandle]=\"onChangeLanguage\"\n >\n </the-toolbar-dropdown>\n <span class=\"auto-wrap d-flex align-items-center\">\n <span>\u81EA\u52A8\u6362\u884C</span>\n <thy-switch\n class=\"auto-wrap-btn d-flex\"\n [(ngModel)]=\"options.lineWrapping\"\n (ngModelChange)=\"onChangeWrap($event)\"\n thySize=\"sm\"\n ></thy-switch>\n </span>\n <a\n href=\"javascript:;\"\n thyIconNavLink\n thyIconNavLinkIcon=\"copy\"\n thyTooltip=\"\u590D\u5236\"\n thyTooltipPlacement=\"top\"\n (mousedown)=\"onCopy($event)\"\n ></a>\n <nav-split-line [mode]=\"ToolbarItemMode.vertical\"></nav-split-line>\n <a\n href=\"javascript:;\"\n thyIconNavLink\n thyIconNavLinkIcon=\"trash\"\n thyTooltip=\"\u5220\u9664\"\n class=\"remove-link\"\n thyTooltipPlacement=\"top\"\n (mousedown)=\"onDelete($event)\"\n ></a>\n </thy-icon-nav>\n</div>\n\n<slate-children [children]=\"children\" [context]=\"childrenContext\" [viewContext]=\"viewContext\"></slate-children>\n\n<!-- \u53EA\u8BFB\u6A21\u5F0F\u4E0BCodeMirror-sizer\u9AD8\u5EA6\u6BD4\u7F16\u8F91\u6A21\u5F0F\u4E0B\u591A2px\uFF0C\u8BBE\u7F6EthyMinHeight\u4E3A46px\u9632\u6B62\u62D6\u62FD\u5230\u6700\u5C0F\u9AD8\u5EA6\u65F6\u53EA\u8BFB\u6A21\u5F0F\u4E0B\u51FA\u73B0\u6EDA\u52A8\u6761 -->\n<div\n thyResizable\n [thyMinHeight]=\"46\"\n [thyBounds]=\"resizeBounds\"\n [style.height.px]=\"resizeHeight\"\n (thyResize)=\"onResize($event)\"\n (thyResizeEnd)=\"onEndResize()\"\n class=\"resize-code-container\"\n [ngClass]=\"{ focus: isCollapsed, readonly: options.readOnly, active: isHightLight && isCollapsed }\"\n>\n <ng-codemirror\n *ngIf=\"startRenderCodemirror\"\n #codemirror\n contenteditable=\"false\"\n class=\"ng-codemirror-wrapper\"\n [ngStyle]=\"{ maxHeight: maxHeight > 0 ? maxHeight + 'px' : 'auto' }\"\n [options]=\"options\"\n [ngModel]=\"code\"\n [delayRefreshTime]=\"300\"\n (ngModelChange)=\"codeChange($event)\"\n (focusChange)=\"focusChange($event)\"\n [autoMaxHeight]=\"maxHeight\"\n >\n </ng-codemirror>\n <thy-resize-handle thyDirection=\"bottom\" class=\"code-resize-icon\" *ngIf=\"isCollapsed && !options.readOnly\"></thy-resize-handle>\n</div>\n", components: [{ type: i3$1.ThyIconNavComponent, selector: "thy-icon-nav", inputs: ["thyType"] }, { type: TheToolbarDropdownComponent, selector: "the-toolbar-dropdown", inputs: ["itemMousedownHandle"] }, { type: i5$2.ThySwitchComponent, selector: "thy-switch", inputs: ["thyType", "thySize", "thyDisabled"], outputs: ["thyChange"] }, { type: i3$1.ThyIconNavLinkComponent, selector: "[thyIconNavLink]", inputs: ["thyIconNavLinkIcon", "thyIconNavLinkActive"] }, { type: NavSplitLineComponent, selector: "nav-split-line", inputs: ["mode"] }, { type: i1.SlateChildrenComponent, selector: "slate-children", inputs: ["children", "context", "viewContext"] }, { type: i8.CodeMirrorComponent, selector: "ng-codemirror, [ngCodeMirror]", inputs: ["autoMaxHeight", "delayRefreshTime", "options"], outputs: ["focusChange"] }, { type: i9.ThyResizeHandleComponent, selector: "thy-resize-handle, [thy-resize-handle]", inputs: ["thyDirection"], outputs: ["thyMouseDown"], exportAs: ["thyResizeHandle"] }], directives: [{ type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i5$1.ThyTooltipDirective, selector: "[thyTooltip],[thy-tooltip]", inputs: ["thyTooltip", "thyTooltipPlacement", "thyTooltipClass", "thyTooltipShowDelay", "thyTooltipHideDelay", "thyTooltipTrigger", "thyTooltipDisabled", "thyTooltipTemplateContext", "thyTooltipOffset", "thyTooltipPin"], exportAs: ["thyTooltip"] }, { type: i9.ThyResizableDirective, selector: "[thyResizable]", inputs: ["thyBounds", "thyMaxHeight", "thyMaxWidth", "thyMinHeight", "thyMinWidth", "thyGridColumnCount", "thyMaxColumn", "thyMinColumn", "thyLockAspectRatio", "thyPreview", "thyDisabled"], outputs: ["thyResize", "thyResizeEnd", "thyResizeStart"] }, { type: i10.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i10.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
7218
7231
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheCodeComponent, decorators: [{
7219
7232
  type: Component,
7220
7233
  args: [{
@@ -7561,6 +7574,7 @@ class TheBaseLinkComponent extends TheBaseElementComponent {
7561
7574
  origin: dom,
7562
7575
  placement: 'bottomLeft',
7563
7576
  offset: 8,
7577
+ minWidth: 0,
7564
7578
  hasBackdrop: false,
7565
7579
  outsideClosable: true,
7566
7580
  viewContainerRef: this.viewContainerRef,
@@ -7580,6 +7594,7 @@ class TheBaseLinkComponent extends TheBaseElementComponent {
7580
7594
  link,
7581
7595
  originSelection: this.editor.selection
7582
7596
  },
7597
+ minWidth: 0,
7583
7598
  origin: this.elementRef.nativeElement,
7584
7599
  backdropClosable: true,
7585
7600
  placement: 'bottomLeft',
@@ -8642,6 +8657,7 @@ class TheTableToolbarComponent {
8642
8657
  tableStore: this.tableStore,
8643
8658
  editor: this.editor
8644
8659
  },
8660
+ minWidth: 0,
8645
8661
  insideClosable: false,
8646
8662
  hasBackdrop: false,
8647
8663
  placement: 'bottomLeft',
@@ -8894,6 +8910,7 @@ class TheTableContextMenuService {
8894
8910
  y: event.y
8895
8911
  },
8896
8912
  hasBackdrop: false,
8913
+ minWidth: 0,
8897
8914
  placement: 'bottomLeft',
8898
8915
  viewContainerRef: this.theContextService.getOptions().viewContainerRef,
8899
8916
  manualClosure: true,
@@ -8955,6 +8972,7 @@ class TableService {
8955
8972
  offset: this.offset,
8956
8973
  hasBackdrop: this.hasBackdrop,
8957
8974
  insideClosable: this.insideClosable,
8975
+ minWidth: 0,
8958
8976
  panelClass: 'the-temp-table-toolbar-wrap',
8959
8977
  scrollStrategy: this.overlay.scrollStrategies.reposition(),
8960
8978
  manualClosure: true
@@ -10839,6 +10857,7 @@ class TheTableToolbarItemComponent extends TheBaseToolbarItem {
10839
10857
  editor: this.editor,
10840
10858
  optionsParam
10841
10859
  },
10860
+ minWidth: 0,
10842
10861
  backdropClosable: false,
10843
10862
  hasBackdrop: false,
10844
10863
  insideClosable: false,
@@ -11534,6 +11553,7 @@ const QuickInsertEditor = {
11534
11553
  offset: 4,
11535
11554
  hasBackdrop: false,
11536
11555
  insideClosable: true,
11556
+ minWidth: 0,
11537
11557
  panelClass: 'the-quick-toolbar-container',
11538
11558
  scrollStrategy: overlay.scrollStrategies.reposition(),
11539
11559
  manualClosure: true
@@ -12045,6 +12065,7 @@ class TheVerticalToolbarItemComponent extends TheBaseToolbarDropdown {
12045
12065
  panelClass: ['the-toolbar-dropdown-popover', (_a = this.toolbarItem) === null || _a === void 0 ? void 0 : _a.key],
12046
12066
  placement: 'bottomLeft',
12047
12067
  offset: 10,
12068
+ minWidth: 0,
12048
12069
  viewContainerRef: this.viewContainerRef,
12049
12070
  insideClosable: false,
12050
12071
  backdropClosable: false,
@@ -12319,6 +12340,7 @@ class TheColorToolbarItemComponent extends TheBaseToolbarItem {
12319
12340
  backdropClosable: false,
12320
12341
  placement: 'bottomLeft',
12321
12342
  offset: 10,
12343
+ minWidth: 0,
12322
12344
  hasBackdrop: false,
12323
12345
  insideClosable: false,
12324
12346
  panelClass: 'color-select-container'
@@ -13044,6 +13066,7 @@ class TheEditorComponent extends mixinUnsubscribe(MixinBase) {
13044
13066
  this.theOnSave = new EventEmitter();
13045
13067
  this.theOnDOMEvent = new EventEmitter();
13046
13068
  this.theEditorCreated = new EventEmitter();
13069
+ this.theUploadingStatus = new EventEmitter(); // true 上传结束 false 上传中
13047
13070
  this.autoScrollView = _.debounce(function (editor, scrollContainer) {
13048
13071
  return autoScrollViewHandle(editor, scrollContainer);
13049
13072
  }, 80);
@@ -13153,6 +13176,16 @@ class TheEditorComponent extends mixinUnsubscribe(MixinBase) {
13153
13176
  }
13154
13177
  ngOnInit() {
13155
13178
  this.initialize();
13179
+ this.theContextService.uploadingStatus$.subscribe(isUploading => {
13180
+ if (isUploading) {
13181
+ this.theUploadingStatus.emit(true);
13182
+ }
13183
+ else {
13184
+ if (this.theContextService.uploadingFiles.length === 0) {
13185
+ this.theUploadingStatus.emit(false);
13186
+ }
13187
+ }
13188
+ });
13156
13189
  this.onErrorHandler();
13157
13190
  }
13158
13191
  ngOnChanges(changes) {
@@ -13375,7 +13408,7 @@ class TheEditorComponent extends mixinUnsubscribe(MixinBase) {
13375
13408
  }
13376
13409
  }
13377
13410
  TheEditorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheEditorComponent, deps: [{ token: TheContextService }, { token: i0.ViewContainerRef }, { token: i0.ElementRef }, { token: i0.NgZone }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
13378
- TheEditorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.15", type: TheEditorComponent, selector: "the-editor, theEditor", inputs: { theOptions: "theOptions", thePlugins: "thePlugins", theGlobalToolbar: "theGlobalToolbar", theDecorate: "theDecorate", theOnError: "theOnError" }, outputs: { theOnSave: "theOnSave", theOnDOMEvent: "theOnDOMEvent", theEditorCreated: "theEditorCreated" }, host: { properties: { "class.the-editor-readonly": "theOptions?.readonly" }, classAttribute: "the-editor" }, providers: [
13411
+ TheEditorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.15", type: TheEditorComponent, selector: "the-editor, theEditor", inputs: { theOptions: "theOptions", thePlugins: "thePlugins", theGlobalToolbar: "theGlobalToolbar", theDecorate: "theDecorate", theOnError: "theOnError" }, outputs: { theOnSave: "theOnSave", theOnDOMEvent: "theOnDOMEvent", theEditorCreated: "theEditorCreated", theUploadingStatus: "theUploadingStatus" }, host: { properties: { "class.the-editor-readonly": "theOptions?.readonly" }, classAttribute: "the-editor" }, providers: [
13379
13412
  TheContextService,
13380
13413
  TheColorSelectService,
13381
13414
  {
@@ -13420,6 +13453,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImpo
13420
13453
  type: Output
13421
13454
  }], theEditorCreated: [{
13422
13455
  type: Output
13456
+ }], theUploadingStatus: [{
13457
+ type: Output
13423
13458
  }], templateInstance: [{
13424
13459
  type: ViewChild,
13425
13460
  args: ['templateInstance', { static: true }]
@@ -13527,6 +13562,7 @@ class TheToolbarGroupComponent {
13527
13562
  this.groupPopoverRef = this.thyPopover.open(this.groupTemplate, {
13528
13563
  panelClass: 'the-toolbar-group-container',
13529
13564
  offset: 10,
13565
+ minWidth: 0,
13530
13566
  placement: 'bottomRight',
13531
13567
  origin: event.currentTarget,
13532
13568
  viewContainerRef: this.viewContainerRef,