@worktile/theia 2.3.2 → 2.4.1
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.
- package/bundles/worktile-theia.umd.js +275 -198
- package/bundles/worktile-theia.umd.js.map +1 -1
- package/components/column-resize/column-resize.directive.d.ts +2 -2
- package/components/column-resize/column-resize.scss +6 -0
- package/components/column-resize/event-dispatcher.d.ts +7 -1
- package/components/column-resize/resize-ref.d.ts +3 -0
- package/constants/default.d.ts +0 -1
- package/custom-types.d.ts +2 -1
- package/editor.module.d.ts +45 -43
- package/esm2015/components/column-resize/column-resize.directive.js +26 -33
- package/esm2015/components/column-resize/event-dispatcher.js +8 -1
- package/esm2015/components/column-resize/overlay-handle.component.js +3 -3
- package/esm2015/components/column-resize/resize-ref.js +4 -1
- package/esm2015/constants/default.js +1 -1
- package/esm2015/custom-types.js +1 -1
- package/esm2015/editor.module.js +7 -6
- package/esm2015/plugins/index.js +2 -2
- package/esm2015/plugins/inline-code/inline-code.component.js +7 -7
- package/esm2015/plugins/link/link.component.js +11 -24
- package/esm2015/plugins/link/link.plugin.js +3 -4
- package/esm2015/plugins/quick-insert/components/quick-insert.component.js +7 -8
- package/esm2015/plugins/quick-insert/quick-insert.plugin.js +40 -0
- package/esm2015/plugins/table/components/insert-mark/insert-mark.component.js +7 -2
- package/esm2015/plugins/table/components/table.component.js +10 -4
- package/esm2015/plugins/table/components/td/td.component.js +59 -37
- package/esm2015/plugins/table/components/toolbar/table-options.component.js +90 -0
- package/esm2015/plugins/table/components/toolbar/table-toolbar.component.js +26 -7
- package/esm2015/plugins/table/table.service.js +2 -2
- package/esm2015/plugins/table/table.store.js +13 -3
- package/esm2015/plugins/table/table.types.js +1 -1
- package/esm2015/plugins/todo-item/todo-item.component.js +3 -3
- package/esm2015/services/table-contextmenu.service.js +1 -1
- package/esm2015/utils/dom.js +2 -42
- package/fesm2015/worktile-theia.js +281 -185
- package/fesm2015/worktile-theia.js.map +1 -1
- package/package.json +1 -1
- package/plugins/link/link.component.d.ts +2 -8
- package/plugins/link/link.component.scss +0 -2
- package/plugins/quick-insert/{quick-insert.plugint.d.ts → quick-insert.plugin.d.ts} +0 -0
- package/plugins/table/components/table.component.scss +142 -105
- package/plugins/table/components/td/td.component.d.ts +3 -2
- package/plugins/table/components/toolbar/table-options.component.d.ts +20 -0
- package/plugins/table/components/toolbar/table-toolbar.component.d.ts +4 -2
- package/plugins/table/table.store.d.ts +3 -1
- package/plugins/table/table.types.d.ts +10 -0
- package/styles/editor.scss +141 -131
- package/styles/typo.scss +0 -6
- package/utils/dom.d.ts +1 -5
- package/esm2015/plugins/quick-insert/quick-insert.plugint.js +0 -38
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
import { Component, Input, HostListener } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "ngx-tethys";
|
|
4
|
+
import * as i2 from "ngx-tethys/action-menu";
|
|
5
|
+
import * as i3 from "ngx-tethys/icon";
|
|
6
|
+
import * as i4 from "@angular/common";
|
|
7
|
+
export class TheTableOptionsComponent {
|
|
8
|
+
constructor(popoverRef) {
|
|
9
|
+
this.popoverRef = popoverRef;
|
|
10
|
+
this.tableDropdownList = [
|
|
11
|
+
// {
|
|
12
|
+
// name: '表头行',
|
|
13
|
+
// key: 'headerRow'
|
|
14
|
+
// },
|
|
15
|
+
// {
|
|
16
|
+
// name: '表头列',
|
|
17
|
+
// key: 'headerColumn'
|
|
18
|
+
// },
|
|
19
|
+
{
|
|
20
|
+
name: '序号列',
|
|
21
|
+
key: 'numberedColumn'
|
|
22
|
+
}
|
|
23
|
+
];
|
|
24
|
+
}
|
|
25
|
+
get table() {
|
|
26
|
+
return this.tableStore && this.tableStore.getTableEntry(this.editor)[0];
|
|
27
|
+
}
|
|
28
|
+
handleDocumentMouseDown(event) {
|
|
29
|
+
if (this.popoverRef && !document.querySelector('.table-options-pannel').contains(event.target)) {
|
|
30
|
+
this.popoverRef.close();
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
ngOnInit() {
|
|
34
|
+
this.setColumnOptions();
|
|
35
|
+
}
|
|
36
|
+
setColumnOptions() {
|
|
37
|
+
this.tableDropdownList.forEach(item => {
|
|
38
|
+
item.isActive = (this.table.options && this.table.options[item.key]) || false;
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
setTableOptions(event, option) {
|
|
42
|
+
event.preventDefault();
|
|
43
|
+
event.stopPropagation();
|
|
44
|
+
const currentOption = this.tableDropdownList.find(item => item.key === option.key);
|
|
45
|
+
currentOption.isActive = !option.isActive;
|
|
46
|
+
const tableOption = {};
|
|
47
|
+
tableOption[option.key] = currentOption.isActive || null;
|
|
48
|
+
this.tableStore.setTableOptions(this.editor, Object.assign(Object.assign({}, this.table.options), tableOption));
|
|
49
|
+
this.popoverRef.close();
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
TheTableOptionsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheTableOptionsComponent, deps: [{ token: i1.ThyPopoverRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
53
|
+
TheTableOptionsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.15", type: TheTableOptionsComponent, selector: "the-table-options", inputs: { tableStore: "tableStore", editor: "editor" }, host: { listeners: { "document: mousedown": "handleDocumentMouseDown($event)" } }, ngImport: i0, template: `
|
|
54
|
+
<thy-action-menu class="table-drop-menu">
|
|
55
|
+
<ng-container *ngFor="let option of tableDropdownList">
|
|
56
|
+
<a thyActionMenuItem href="javascript:;" (mousedown)="setTableOptions($event, option)">
|
|
57
|
+
<span thyActionMenuItemName>{{ option.name }}</span>
|
|
58
|
+
<span thyActionMenuItemExtendIcon class="text-primary" *ngIf="option.isActive">
|
|
59
|
+
<thy-icon thyIconName="check"></thy-icon>
|
|
60
|
+
</span>
|
|
61
|
+
</a>
|
|
62
|
+
</ng-container>
|
|
63
|
+
</thy-action-menu>
|
|
64
|
+
`, isInline: true, components: [{ type: i2.ThyActionMenuComponent, selector: "thy-action-menu", inputs: ["thyTheme", "thyWidth"] }, { type: i3.ThyIconComponent, selector: "thy-icon", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }], directives: [{ type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i2.ThyActionMenuItemDirective, selector: "[thyActionMenuItem]", inputs: ["thyDisabled", "thyType"] }, { type: i2.ThyActionMenuItemNameDirective, selector: "[thyActionMenuItemName]" }, { type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.ThyActionMenuItemExtendIconDirective, selector: "[thyActionMenuItemExtendIcon]" }] });
|
|
65
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheTableOptionsComponent, decorators: [{
|
|
66
|
+
type: Component,
|
|
67
|
+
args: [{
|
|
68
|
+
selector: 'the-table-options',
|
|
69
|
+
template: `
|
|
70
|
+
<thy-action-menu class="table-drop-menu">
|
|
71
|
+
<ng-container *ngFor="let option of tableDropdownList">
|
|
72
|
+
<a thyActionMenuItem href="javascript:;" (mousedown)="setTableOptions($event, option)">
|
|
73
|
+
<span thyActionMenuItemName>{{ option.name }}</span>
|
|
74
|
+
<span thyActionMenuItemExtendIcon class="text-primary" *ngIf="option.isActive">
|
|
75
|
+
<thy-icon thyIconName="check"></thy-icon>
|
|
76
|
+
</span>
|
|
77
|
+
</a>
|
|
78
|
+
</ng-container>
|
|
79
|
+
</thy-action-menu>
|
|
80
|
+
`
|
|
81
|
+
}]
|
|
82
|
+
}], ctorParameters: function () { return [{ type: i1.ThyPopoverRef }]; }, propDecorators: { tableStore: [{
|
|
83
|
+
type: Input
|
|
84
|
+
}], editor: [{
|
|
85
|
+
type: Input
|
|
86
|
+
}], handleDocumentMouseDown: [{
|
|
87
|
+
type: HostListener,
|
|
88
|
+
args: ['document: mousedown', ['$event']]
|
|
89
|
+
}] } });
|
|
90
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtb3B0aW9ucy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9zcmMvcGx1Z2lucy90YWJsZS9jb21wb25lbnRzL3Rvb2xiYXIvdGFibGUtb3B0aW9ucy5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBVSxLQUFLLEVBQUUsWUFBWSxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7Ozs7QUFxQnZFLE1BQU0sT0FBTyx3QkFBd0I7SUErQmpDLFlBQW9CLFVBQW1EO1FBQW5ELGVBQVUsR0FBVixVQUFVLENBQXlDO1FBdEJ2RSxzQkFBaUIsR0FBMEI7WUFDdkMsSUFBSTtZQUNKLG1CQUFtQjtZQUNuQix1QkFBdUI7WUFDdkIsS0FBSztZQUNMLElBQUk7WUFDSixtQkFBbUI7WUFDbkIsMEJBQTBCO1lBQzFCLEtBQUs7WUFDTDtnQkFDSSxJQUFJLEVBQUUsS0FBSztnQkFDWCxHQUFHLEVBQUUsZ0JBQWdCO2FBQ3hCO1NBQ0osQ0FBQztJQVN3RSxDQUFDO0lBMUIzRSxJQUFJLEtBQUs7UUFDTCxPQUFPLElBQUksQ0FBQyxVQUFVLElBQUksSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQzVFLENBQUM7SUFrQkQsdUJBQXVCLENBQUMsS0FBaUI7UUFDckMsSUFBSSxJQUFJLENBQUMsVUFBVSxJQUFJLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsTUFBcUIsQ0FBQyxFQUFFO1lBQzNHLElBQUksQ0FBQyxVQUFVLENBQUMsS0FBSyxFQUFFLENBQUM7U0FDM0I7SUFDTCxDQUFDO0lBSUQsUUFBUTtRQUNKLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDO0lBQzVCLENBQUM7SUFFRCxnQkFBZ0I7UUFDWixJQUFJLENBQUMsaUJBQWlCLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxFQUFFO1lBQ2xDLElBQUksQ0FBQyxRQUFRLEdBQUcsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxLQUFLLENBQUM7UUFDbEYsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRUQsZUFBZSxDQUFDLEtBQWlCLEVBQUUsTUFBMkI7UUFDMUQsS0FBSyxDQUFDLGNBQWMsRUFBRSxDQUFDO1FBQ3ZCLEtBQUssQ0FBQyxlQUFlLEVBQUUsQ0FBQztRQUN4QixNQUFNLGFBQWEsR0FBRyxJQUFJLENBQUMsaUJBQWlCLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLEdBQUcsS0FBSyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDbkYsYUFBYSxDQUFDLFFBQVEsR0FBRyxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUM7UUFDMUMsTUFBTSxXQUFXLEdBQUcsRUFBRSxDQUFDO1FBQ3ZCLFdBQVcsQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLEdBQUcsYUFBYSxDQUFDLFFBQVEsSUFBSSxJQUFJLENBQUM7UUFDekQsSUFBSSxDQUFDLFVBQVUsQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLE1BQU0sa0NBQ3BDLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxHQUNsQixXQUFXLEVBQ2hCLENBQUM7UUFDSCxJQUFJLENBQUMsVUFBVSxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQzVCLENBQUM7O3NIQXZEUSx3QkFBd0I7MEdBQXhCLHdCQUF3QixvTUFidkI7Ozs7Ozs7Ozs7O0tBV1Q7NEZBRVEsd0JBQXdCO2tCQWZwQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxtQkFBbUI7b0JBQzdCLFFBQVEsRUFBRTs7Ozs7Ozs7Ozs7S0FXVDtpQkFDSjtvR0FFWSxVQUFVO3NCQUFsQixLQUFLO2dCQUVHLE1BQU07c0JBQWQsS0FBSztnQkFzQk4sdUJBQXVCO3NCQUR0QixZQUFZO3VCQUFDLHFCQUFxQixFQUFFLENBQUMsUUFBUSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQsIElucHV0LCBIb3N0TGlzdGVuZXIgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFRoeVBvcG92ZXJSZWYgfSBmcm9tICduZ3gtdGV0aHlzJztcbmltcG9ydCB7IEVkaXRvciB9IGZyb20gJ3NsYXRlJztcbmltcG9ydCB7IFRhYmxlU3RvcmUgfSBmcm9tICcuLi8uLi90YWJsZS5zdG9yZSc7XG5pbXBvcnQgeyBUYWJsZURyb3Bkb3duT3B0aW9uIH0gZnJvbSAnLi4vLi4vdGFibGUudHlwZXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ3RoZS10YWJsZS1vcHRpb25zJyxcbiAgICB0ZW1wbGF0ZTogYFxuICAgICAgICA8dGh5LWFjdGlvbi1tZW51IGNsYXNzPVwidGFibGUtZHJvcC1tZW51XCI+XG4gICAgICAgICAgICA8bmctY29udGFpbmVyICpuZ0Zvcj1cImxldCBvcHRpb24gb2YgdGFibGVEcm9wZG93bkxpc3RcIj5cbiAgICAgICAgICAgICAgICA8YSB0aHlBY3Rpb25NZW51SXRlbSBocmVmPVwiamF2YXNjcmlwdDo7XCIgKG1vdXNlZG93bik9XCJzZXRUYWJsZU9wdGlvbnMoJGV2ZW50LCBvcHRpb24pXCI+XG4gICAgICAgICAgICAgICAgICAgIDxzcGFuIHRoeUFjdGlvbk1lbnVJdGVtTmFtZT57eyBvcHRpb24ubmFtZSB9fTwvc3Bhbj5cbiAgICAgICAgICAgICAgICAgICAgPHNwYW4gdGh5QWN0aW9uTWVudUl0ZW1FeHRlbmRJY29uIGNsYXNzPVwidGV4dC1wcmltYXJ5XCIgKm5nSWY9XCJvcHRpb24uaXNBY3RpdmVcIj5cbiAgICAgICAgICAgICAgICAgICAgICAgIDx0aHktaWNvbiB0aHlJY29uTmFtZT1cImNoZWNrXCI+PC90aHktaWNvbj5cbiAgICAgICAgICAgICAgICAgICAgPC9zcGFuPlxuICAgICAgICAgICAgICAgIDwvYT5cbiAgICAgICAgICAgIDwvbmctY29udGFpbmVyPlxuICAgICAgICA8L3RoeS1hY3Rpb24tbWVudT5cbiAgICBgXG59KVxuZXhwb3J0IGNsYXNzIFRoZVRhYmxlT3B0aW9uc0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gICAgQElucHV0KCkgdGFibGVTdG9yZTogVGFibGVTdG9yZTtcblxuICAgIEBJbnB1dCgpIGVkaXRvcjogRWRpdG9yO1xuXG4gICAgZ2V0IHRhYmxlKCkge1xuICAgICAgICByZXR1cm4gdGhpcy50YWJsZVN0b3JlICYmIHRoaXMudGFibGVTdG9yZS5nZXRUYWJsZUVudHJ5KHRoaXMuZWRpdG9yKVswXTtcbiAgICB9XG5cbiAgICB0YWJsZURyb3Bkb3duTGlzdDogVGFibGVEcm9wZG93bk9wdGlvbltdID0gW1xuICAgICAgICAvLyB7XG4gICAgICAgIC8vICAgICBuYW1lOiAn6KGo5aS06KGMJyxcbiAgICAgICAgLy8gICAgIGtleTogJ2hlYWRlclJvdydcbiAgICAgICAgLy8gfSxcbiAgICAgICAgLy8ge1xuICAgICAgICAvLyAgICAgbmFtZTogJ+ihqOWktOWIlycsXG4gICAgICAgIC8vICAgICBrZXk6ICdoZWFkZXJDb2x1bW4nXG4gICAgICAgIC8vIH0sXG4gICAgICAgIHtcbiAgICAgICAgICAgIG5hbWU6ICfluo/lj7fliJcnLFxuICAgICAgICAgICAga2V5OiAnbnVtYmVyZWRDb2x1bW4nXG4gICAgICAgIH1cbiAgICBdO1xuXG4gICAgQEhvc3RMaXN0ZW5lcignZG9jdW1lbnQ6IG1vdXNlZG93bicsIFsnJGV2ZW50J10pXG4gICAgaGFuZGxlRG9jdW1lbnRNb3VzZURvd24oZXZlbnQ6IE1vdXNlRXZlbnQpIHtcbiAgICAgICAgaWYgKHRoaXMucG9wb3ZlclJlZiAmJiAhZG9jdW1lbnQucXVlcnlTZWxlY3RvcignLnRhYmxlLW9wdGlvbnMtcGFubmVsJykuY29udGFpbnMoZXZlbnQudGFyZ2V0IGFzIEhUTUxFbGVtZW50KSkge1xuICAgICAgICAgICAgdGhpcy5wb3BvdmVyUmVmLmNsb3NlKCk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIHBvcG92ZXJSZWY6IFRoeVBvcG92ZXJSZWY8VGhlVGFibGVPcHRpb25zQ29tcG9uZW50Pikge31cblxuICAgIG5nT25Jbml0KCk6IHZvaWQge1xuICAgICAgICB0aGlzLnNldENvbHVtbk9wdGlvbnMoKTtcbiAgICB9XG5cbiAgICBzZXRDb2x1bW5PcHRpb25zKCkge1xuICAgICAgICB0aGlzLnRhYmxlRHJvcGRvd25MaXN0LmZvckVhY2goaXRlbSA9PiB7XG4gICAgICAgICAgICBpdGVtLmlzQWN0aXZlID0gKHRoaXMudGFibGUub3B0aW9ucyAmJiB0aGlzLnRhYmxlLm9wdGlvbnNbaXRlbS5rZXldKSB8fCBmYWxzZTtcbiAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgc2V0VGFibGVPcHRpb25zKGV2ZW50OiBNb3VzZUV2ZW50LCBvcHRpb246IFRhYmxlRHJvcGRvd25PcHRpb24pIHtcbiAgICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgZXZlbnQuc3RvcFByb3BhZ2F0aW9uKCk7XG4gICAgICAgIGNvbnN0IGN1cnJlbnRPcHRpb24gPSB0aGlzLnRhYmxlRHJvcGRvd25MaXN0LmZpbmQoaXRlbSA9PiBpdGVtLmtleSA9PT0gb3B0aW9uLmtleSk7XG4gICAgICAgIGN1cnJlbnRPcHRpb24uaXNBY3RpdmUgPSAhb3B0aW9uLmlzQWN0aXZlO1xuICAgICAgICBjb25zdCB0YWJsZU9wdGlvbiA9IHt9O1xuICAgICAgICB0YWJsZU9wdGlvbltvcHRpb24ua2V5XSA9IGN1cnJlbnRPcHRpb24uaXNBY3RpdmUgfHwgbnVsbDtcbiAgICAgICAgdGhpcy50YWJsZVN0b3JlLnNldFRhYmxlT3B0aW9ucyh0aGlzLmVkaXRvciwge1xuICAgICAgICAgICAgLi4udGhpcy50YWJsZS5vcHRpb25zLFxuICAgICAgICAgICAgLi4udGFibGVPcHRpb25cbiAgICAgICAgfSk7XG4gICAgICAgIHRoaXMucG9wb3ZlclJlZi5jbG9zZSgpO1xuICAgIH1cbn1cbiJdfQ==
|
|
@@ -3,18 +3,21 @@ import { BackgroundColors, TableHeaderBackgroundColor, SpecialBackgroundColor }
|
|
|
3
3
|
import { splitCell } from '../../utils/split-cell';
|
|
4
4
|
import { setCellMenuInvisibility } from '../../utils/set-menu-cell-invisibility';
|
|
5
5
|
import { TableEditor } from '../../table.editor';
|
|
6
|
+
import { TheTableOptionsComponent } from './table-options.component';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
import * as i1 from "../../../../services/color-select.service";
|
|
8
9
|
import * as i2 from "ngx-tethys/popover";
|
|
9
10
|
import * as i3 from "ngx-tethys/nav";
|
|
10
11
|
import * as i4 from "ngx-tethys/icon";
|
|
11
12
|
import * as i5 from "../../../../components/nav-split-line/nav-split-line.component";
|
|
12
|
-
import * as i6 from "
|
|
13
|
-
import * as i7 from "
|
|
13
|
+
import * as i6 from "ngx-tethys/button";
|
|
14
|
+
import * as i7 from "@angular/common";
|
|
15
|
+
import * as i8 from "ngx-tethys/tooltip";
|
|
14
16
|
export class TheTableToolbarComponent {
|
|
15
|
-
constructor(ngZone, colorSelectService, popoverRef) {
|
|
17
|
+
constructor(ngZone, colorSelectService, thyPopover, popoverRef) {
|
|
16
18
|
this.ngZone = ngZone;
|
|
17
19
|
this.colorSelectService = colorSelectService;
|
|
20
|
+
this.thyPopover = thyPopover;
|
|
18
21
|
this.popoverRef = popoverRef;
|
|
19
22
|
this.cellMenuList = [
|
|
20
23
|
{
|
|
@@ -119,16 +122,32 @@ export class TheTableToolbarComponent {
|
|
|
119
122
|
});
|
|
120
123
|
});
|
|
121
124
|
}
|
|
125
|
+
openTableOptionMenu(event) {
|
|
126
|
+
event.preventDefault();
|
|
127
|
+
event.stopPropagation();
|
|
128
|
+
this.thyPopover.open(TheTableOptionsComponent, {
|
|
129
|
+
origin: event.currentTarget,
|
|
130
|
+
initialState: {
|
|
131
|
+
tableStore: this.tableStore,
|
|
132
|
+
editor: this.editor
|
|
133
|
+
},
|
|
134
|
+
insideClosable: false,
|
|
135
|
+
hasBackdrop: false,
|
|
136
|
+
placement: 'bottomLeft',
|
|
137
|
+
originActiveClass: 'table-options-active',
|
|
138
|
+
panelClass: 'table-options-pannel'
|
|
139
|
+
});
|
|
140
|
+
}
|
|
122
141
|
}
|
|
123
|
-
TheTableToolbarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheTableToolbarComponent, deps: [{ token: i0.NgZone }, { token: i1.TheColorSelectService }, { token: i2.ThyPopoverRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
124
|
-
TheTableToolbarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.15", type: TheTableToolbarComponent, selector: "the-table-toolbar", inputs: { tableStore: "tableStore", isActiveSelect: "isActiveSelect" }, ngImport: i0, template: "<thy-icon-nav>\n <ng-container *ngFor=\"let item of cellMenuList\">\n <a href=\"javascript:;\" thyIconNavLink *ngIf=\"!item.invisibility\" [thyTooltip]=\"item.name\" (mousedown)=\"item.actionHandle()\">\n <thy-icon [thyIconName]=\"item.icon\"></thy-icon>\n </a>\n </ng-container>\n <nav-split-line *ngIf=\"!isActiveSelect && isShowSplitLine\"></nav-split-line>\n <a href=\"javascript:;\" thyIconNavLink thyTooltip=\"\u5355\u5143\u683C\u80CC\u666F\" (mousedown)=\"openSelectColor($event)\">\n <thy-icon thyIconName=\"background-tt\" thyIconType=\"twotone\" [thyTwotoneColor]=\"selectedColor\"></thy-icon>\n </a>\n <nav-split-line *ngIf=\"deleteIcon\"></nav-split-line>\n <a\n *ngIf=\"deleteIcon\"\n href=\"javascript:;\"\n thyIconNavLink\n [thyTooltip]=\"iconName\"\n class=\"danger\"\n [thyIconNavLinkIcon]=\"deleteIcon\"\n (mousedown)=\"onDelete($event)\"\n (mouseenter)=\"onEnterDelete($event)\"\n (mouseleave)=\"onLeaveDelete($event)\"\n ></a>\n</thy-icon-nav>\n", components: [{ type: i3.ThyIconNavComponent, selector: "thy-icon-nav", inputs: ["thyType"] }, { type: i3.ThyIconNavLinkComponent, selector: "[thyIconNavLink]", inputs: ["thyIconNavLinkIcon", "thyIconNavLinkActive"] }, { type: i4.ThyIconComponent, selector: "thy-icon", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { type: i5.NavSplitLineComponent, selector: "nav-split-line", inputs: ["mode"] }], directives: [{ type:
|
|
142
|
+
TheTableToolbarComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheTableToolbarComponent, deps: [{ token: i0.NgZone }, { token: i1.TheColorSelectService }, { token: i2.ThyPopover }, { token: i2.ThyPopoverRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
143
|
+
TheTableToolbarComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.15", type: TheTableToolbarComponent, selector: "the-table-toolbar", inputs: { tableStore: "tableStore", isActiveSelect: "isActiveSelect" }, ngImport: i0, template: "<thy-icon-nav>\n <ng-container *ngFor=\"let item of cellMenuList\">\n <a href=\"javascript:;\" thyIconNavLink *ngIf=\"!item.invisibility\" [thyTooltip]=\"item.name\" (mousedown)=\"item.actionHandle()\">\n <thy-icon [thyIconName]=\"item.icon\"></thy-icon>\n </a>\n </ng-container>\n <nav-split-line *ngIf=\"!isActiveSelect && isShowSplitLine\"></nav-split-line>\n <a href=\"javascript:;\" thyIconNavLink thyTooltip=\"\u5355\u5143\u683C\u80CC\u666F\" (mousedown)=\"openSelectColor($event)\">\n <thy-icon thyIconName=\"background-tt\" thyIconType=\"twotone\" [thyTwotoneColor]=\"selectedColor\"></thy-icon>\n </a>\n <nav-split-line *ngIf=\"tableStore.isSelectedTable\"></nav-split-line>\n <button\n thyButton=\"default\"\n *ngIf=\"tableStore.isSelectedTable\"\n class=\"mr-2\"\n thySize=\"md\"\n class=\"table-options\"\n (mousedown)=\"openTableOptionMenu($event)\"\n >\n <span>\u8868\u683C\u9009\u9879</span>\n <thy-icon thyIconName=\"caret-down\"></thy-icon>\n </button>\n <nav-split-line *ngIf=\"deleteIcon\"></nav-split-line>\n <a\n *ngIf=\"deleteIcon\"\n href=\"javascript:;\"\n thyIconNavLink\n [thyTooltip]=\"iconName\"\n class=\"danger\"\n [thyIconNavLinkIcon]=\"deleteIcon\"\n (mousedown)=\"onDelete($event)\"\n (mouseenter)=\"onEnterDelete($event)\"\n (mouseleave)=\"onLeaveDelete($event)\"\n ></a>\n</thy-icon-nav>\n", components: [{ type: i3.ThyIconNavComponent, selector: "thy-icon-nav", inputs: ["thyType"] }, { type: i3.ThyIconNavLinkComponent, selector: "[thyIconNavLink]", inputs: ["thyIconNavLinkIcon", "thyIconNavLinkActive"] }, { type: i4.ThyIconComponent, selector: "thy-icon", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { type: i5.NavSplitLineComponent, selector: "nav-split-line", inputs: ["mode"] }, { type: i6.ThyButtonComponent, selector: "thy-button,[thy-button],[thyButton]", inputs: ["thyButton", "thyType", "thyLoading", "thyLoadingText", "thySize", "thyIcon", "thySquare", "thyBlock"] }], directives: [{ type: i7.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i8.ThyTooltipDirective, selector: "[thyTooltip],[thy-tooltip]", inputs: ["thyTooltip", "thyTooltipPlacement", "thyTooltipClass", "thyTooltipShowDelay", "thyTooltipHideDelay", "thyTooltipTrigger", "thyTooltipDisabled", "thyTooltipTemplateContext", "thyTooltipOffset", "thyTooltipPin"], exportAs: ["thyTooltip"] }] });
|
|
125
144
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheTableToolbarComponent, decorators: [{
|
|
126
145
|
type: Component,
|
|
127
146
|
args: [{
|
|
128
147
|
selector: 'the-table-toolbar',
|
|
129
148
|
templateUrl: 'table-toolbar.component.html'
|
|
130
149
|
}]
|
|
131
|
-
}], ctorParameters: function () { return [{ type: i0.NgZone }, { type: i1.TheColorSelectService }, { type: i2.ThyPopoverRef }]; }, propDecorators: { tableStore: [{
|
|
150
|
+
}], ctorParameters: function () { return [{ type: i0.NgZone }, { type: i1.TheColorSelectService }, { type: i2.ThyPopover }, { type: i2.ThyPopoverRef }]; }, propDecorators: { tableStore: [{
|
|
132
151
|
type: Input
|
|
133
152
|
}], isActiveSelect: [{
|
|
134
153
|
type: Input
|
|
@@ -139,4 +158,4 @@ export var DeleteIcon;
|
|
|
139
158
|
DeleteIcon[DeleteIcon["table-delete-columns"] = 1] = "table-delete-columns";
|
|
140
159
|
DeleteIcon[DeleteIcon["trash"] = 2] = "trash";
|
|
141
160
|
})(DeleteIcon || (DeleteIcon = {}));
|
|
142
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-toolbar.component.js","sourceRoot":"","sources":["../../../../../../../packages/src/plugins/table/components/toolbar/table-toolbar.component.ts","../../../../../../../packages/src/plugins/table/components/toolbar/table-toolbar.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAU,KAAK,EAAqB,MAAM,eAAe,CAAC;AAI5E,OAAO,EAAa,gBAAgB,EAAE,0BAA0B,EAAE,sBAAsB,EAAE,MAAM,oCAAoC,CAAC;AAErI,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AACnD,OAAO,EAAE,uBAAuB,EAAE,MAAM,wCAAwC,CAAC;AAEjF,OAAO,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;;;;;;;;;AAMjD,MAAM,OAAO,wBAAwB;IAgDjC,YACY,MAAc,EACd,kBAAyC,EACzC,UAAmD;QAFnD,WAAM,GAAN,MAAM,CAAQ;QACd,uBAAkB,GAAlB,kBAAkB,CAAuB;QACzC,eAAU,GAAV,UAAU,CAAyC;QApC/D,iBAAY,GAAiB;YACzB;gBACI,GAAG,EAAE,aAAa;gBAClB,IAAI,EAAE,OAAO;gBACb,YAAY,EAAE,KAAK;gBACnB,IAAI,EAAE,mBAAmB;gBACzB,YAAY,EAAE,GAAG,EAAE;oBACf,KAAK,CAAC,cAAc,EAAE,CAAC;oBACvB,KAAK,CAAC,eAAe,EAAE,CAAC;oBACxB,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;oBACvC,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;oBACxB,IAAI,CAAC,UAAU,CAAC,kBAAkB,EAAE,CAAC;gBACzC,CAAC;aACJ;YACD;gBACI,GAAG,EAAE,aAAa;gBAClB,IAAI,EAAE,OAAO;gBACb,YAAY,EAAE,KAAK;gBACnB,IAAI,EAAE,qBAAqB;gBAC3B,YAAY,EAAE,GAAG,EAAE;oBACf,KAAK,CAAC,cAAc,EAAE,CAAC;oBACvB,KAAK,CAAC,eAAe,EAAE,CAAC;oBACxB,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;oBACvB,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;oBACxB,IAAI,CAAC,UAAU,CAAC,kBAAkB,EAAE,CAAC;gBACzC,CAAC;aACJ;SACJ,CAAC;IAUC,CAAC;IAzCJ,IAAI,MAAM;QACN,OAAO,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC;IACrD,CAAC;IA+BD,IAAI,eAAe;QACf,OAAO,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;IAC3E,CAAC;IAQD,QAAQ;QACJ,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC;QACnD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAClC,uBAAuB,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;QAC5G,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,8BAA8B,EAAE,CAAC;IAC1E,CAAC;IAED,WAAW;QACP,IAAI,CAAC,kBAAkB,CAAC,gBAAgB,EAAE,CAAC;IAC/C,CAAC;IAED,WAAW,CAAC,GAAW;QACnB,QAAQ,GAAG,EAAE;YACT,KAAK,OAAO;gBACR,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC;gBACvB,MAAM;YACV,KAAK,sBAAsB;gBACvB,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC;gBACvB,MAAM;YACV,KAAK,mBAAmB;gBACpB,IAAI,CAAC,QAAQ,GAAG,MAAM,CAAC;gBACvB,MAAM;SACb;IACL,CAAC;IAED,aAAa;QACT,IAAI,IAAI,CAAC,UAAU,CAAC,eAAe,EAAE;YACjC,OAAO,UAAU,CAAC,KAAK,CAAC;SAC3B;QACD,IAAI,IAAI,CAAC,UAAU,CAAC,iBAAiB,CAAC,MAAM,GAAG,CAAC,EAAE;YAC9C,OAAO,UAAU,CAAC,mBAAmB,CAAC,CAAC;SAC1C;QACD,IAAI,IAAI,CAAC,UAAU,CAAC,oBAAoB,CAAC,MAAM,GAAG,CAAC,EAAE;YACjD,OAAO,UAAU,CAAC,sBAAsB,CAAC,CAAC;SAC7C;QACD,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,QAAQ,CAAC,KAAiB;QACtB,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,IAAI,CAAC,UAAU,CAAC,kBAAkB,EAAE,CAAC;QACrC,IAAI,CAAC,UAAU,CAAC,mBAAmB,EAAE,CAAC;QACtC,IAAI,CAAC,UAAU,CAAC,kBAAkB,EAAE,CAAC;QACrC,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;IAC5B,CAAC;IAED,aAAa,CAAC,KAAiB;QAC3B,IAAI,CAAC,UAAU,CAAC,iBAAiB,EAAE,CAAC;IACxC,CAAC;IAED,aAAa,CAAC,KAAiB;QAC3B,IAAI,CAAC,UAAU,CAAC,mBAAmB,EAAE,CAAC;IAC1C,CAAC;IAED,eAAe,CAAC,KAAiB;QAC7B,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,MAAM,OAAO,GAAI,KAAK,CAAC,MAAsB,CAAC,OAAO,CAAC,oBAAoB,CAAC,CAAC;QAC5E,MAAM,QAAQ,GAAG,WAAW,CAAC,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACzD,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE;YACjB,IAAI,CAAC,kBAAkB,CAAC,iBAAiB,CACrC,OAAsB,EACtB,IAAI,CAAC,aAAa,EAClB,gBAAgB,EAChB;gBACI,kBAAkB,EAAE,CAAC;gBACrB,UAAU,EAAE,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE;gBACpC,YAAY,EAAE,QAAQ,CAAC,CAAC,CAAE,0BAA0B,CAAC,CAAC,CAAC,sBAAsB;aAChF,EACD,CAAC,QAAmB,EAAE,EAAE;gBACpB,IAAI,CAAC,QAAQ,KAAK,0BAA0B,IAAI,QAAQ,CAAC,IAAI,CAAC,QAAQ,KAAK,sBAAsB,IAAI,CAAC,QAAQ,CAAC,EAAE;oBAC7G,IAAI,CAAC,UAAU,CAAC,+BAA+B,CAAC,IAAI,CAAC,CAAC;iBACzD;qBAAM;oBACH,IAAI,CAAC,UAAU,CAAC,+BAA+B,CAAC,QAAQ,CAAC,CAAC;iBAC7D;gBACD,IAAI,CAAC,aAAa,GAAG,QAAQ,CAAC;YAClC,CAAC,CACJ,CAAC;QACN,CAAC,CAAC,CAAC;IACP,CAAC;;sHArIQ,wBAAwB;0GAAxB,wBAAwB,iICfrC,8jCAuBA;4FDRa,wBAAwB;kBAJpC,SAAS;mBAAC;oBACP,QAAQ,EAAE,mBAAmB;oBAC7B,WAAW,EAAE,8BAA8B;iBAC9C;6JAQY,UAAU;sBAAlB,KAAK;gBAEG,cAAc;sBAAtB,KAAK;;AA+HV,MAAM,CAAN,IAAY,UAIX;AAJD,WAAY,UAAU;IAClB,qEAAmB,CAAA;IACnB,2EAAsB,CAAA;IACtB,6CAAO,CAAA;AACX,CAAC,EAJW,UAAU,KAAV,UAAU,QAIrB","sourcesContent":["import { Component, OnInit, Input, NgZone, OnDestroy } from '@angular/core';\nimport { ThyPopoverRef } from 'ngx-tethys/popover';\nimport { Editor } from 'slate';\nimport { TableStore } from '../../table.store';\nimport { ColorType, BackgroundColors, TableHeaderBackgroundColor, SpecialBackgroundColor } from '../../../../constants/color-select';\nimport { TheColorSelectService } from '../../../../services/color-select.service';\nimport { splitCell } from '../../utils/split-cell';\nimport { setCellMenuInvisibility } from '../../utils/set-menu-cell-invisibility';\nimport { MenuEntity } from '../../table.types';\nimport { TableEditor } from '../../table.editor';\n\n@Component({\n    selector: 'the-table-toolbar',\n    templateUrl: 'table-toolbar.component.html'\n})\nexport class TheTableToolbarComponent implements OnInit, OnDestroy {\n    selectedColor: string;\n\n    deleteIcon: string;\n\n    iconName: string;\n\n    @Input() tableStore: TableStore;\n\n    @Input() isActiveSelect: boolean;\n\n    get editor(): Editor {\n        return this.tableStore && this.tableStore.editor;\n    }\n\n    cellMenuList: MenuEntity[] = [\n        {\n            key: 'merge-cells',\n            name: '合并单元格',\n            invisibility: false,\n            icon: 'table-merge-cells',\n            actionHandle: () => {\n                event.preventDefault();\n                event.stopPropagation();\n                this.tableStore.mergeCell(this.editor);\n                this.popoverRef.close();\n                this.tableStore.clearSelectedCells();\n            }\n        },\n        {\n            key: 'split-cells',\n            name: '拆分单元格',\n            invisibility: false,\n            icon: 'table-unmerge-cells',\n            actionHandle: () => {\n                event.preventDefault();\n                event.stopPropagation();\n                splitCell(this.editor);\n                this.popoverRef.close();\n                this.tableStore.clearSelectedCells();\n            }\n        }\n    ];\n\n    get isShowSplitLine() {\n        return this.cellMenuList.filter(item => !item.invisibility).length > 1;\n    }\n\n    constructor(\n        private ngZone: NgZone,\n        private colorSelectService: TheColorSelectService,\n        private popoverRef: ThyPopoverRef<TheTableToolbarComponent>\n    ) {}\n\n    ngOnInit() {\n        this.deleteIcon = DeleteIcon[this.getDeleteIcon()];\n        this.getIconName(this.deleteIcon);\n        setCellMenuInvisibility(this.editor, this.cellMenuList, this.tableStore.selectedCells, this.isActiveSelect);\n        this.selectedColor = this.tableStore.getSelectedCellBackgroundColor();\n    }\n\n    ngOnDestroy() {\n        this.colorSelectService.closeColorSelect();\n    }\n\n    getIconName(key: string) {\n        switch (key) {\n            case 'trash':\n                this.iconName = '删除表格';\n                break;\n            case 'table-delete-columns':\n                this.iconName = '删除整列';\n                break;\n            case 'table-delete-rows':\n                this.iconName = '删除整行';\n                break;\n        }\n    }\n\n    getDeleteIcon() {\n        if (this.tableStore.isSelectedTable) {\n            return DeleteIcon.trash;\n        }\n        if (this.tableStore.selectedRowsIndex.length > 0) {\n            return DeleteIcon['table-delete-rows'];\n        }\n        if (this.tableStore.selectedColumnsIndex.length > 0) {\n            return DeleteIcon['table-delete-columns'];\n        }\n        return null;\n    }\n\n    onDelete(event: MouseEvent) {\n        event.preventDefault();\n        this.tableStore.removeColumnOrRows();\n        this.tableStore.clearDangerousCells();\n        this.tableStore.clearSelectedCells();\n        this.popoverRef.close();\n    }\n\n    onEnterDelete(event: MouseEvent) {\n        this.tableStore.setDangerousCells();\n    }\n\n    onLeaveDelete(event: MouseEvent) {\n        this.tableStore.clearDangerousCells();\n    }\n\n    openSelectColor(event: MouseEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n        const element = (event.target as HTMLElement).closest('.thy-icon-nav-link');\n        const isHeader = TableEditor.isActiveHeader(this.editor);\n        this.ngZone.run(() => {\n            this.colorSelectService.toggleColorSelect(\n                element as HTMLElement,\n                this.selectedColor,\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.selectedColor = newColor;\n                }\n            );\n        });\n    }\n}\n\nexport enum DeleteIcon {\n    'table-delete-rows',\n    'table-delete-columns',\n    'trash'\n}\n","<thy-icon-nav>\n    <ng-container *ngFor=\"let item of cellMenuList\">\n        <a href=\"javascript:;\" thyIconNavLink *ngIf=\"!item.invisibility\" [thyTooltip]=\"item.name\" (mousedown)=\"item.actionHandle()\">\n            <thy-icon [thyIconName]=\"item.icon\"></thy-icon>\n        </a>\n    </ng-container>\n    <nav-split-line *ngIf=\"!isActiveSelect && isShowSplitLine\"></nav-split-line>\n    <a href=\"javascript:;\" thyIconNavLink thyTooltip=\"单元格背景\" (mousedown)=\"openSelectColor($event)\">\n        <thy-icon thyIconName=\"background-tt\" thyIconType=\"twotone\" [thyTwotoneColor]=\"selectedColor\"></thy-icon>\n    </a>\n    <nav-split-line *ngIf=\"deleteIcon\"></nav-split-line>\n    <a\n        *ngIf=\"deleteIcon\"\n        href=\"javascript:;\"\n        thyIconNavLink\n        [thyTooltip]=\"iconName\"\n        class=\"danger\"\n        [thyIconNavLinkIcon]=\"deleteIcon\"\n        (mousedown)=\"onDelete($event)\"\n        (mouseenter)=\"onEnterDelete($event)\"\n        (mouseleave)=\"onLeaveDelete($event)\"\n    ></a>\n</thy-icon-nav>\n"]}
|
|
161
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-toolbar.component.js","sourceRoot":"","sources":["../../../../../../../packages/src/plugins/table/components/toolbar/table-toolbar.component.ts","../../../../../../../packages/src/plugins/table/components/toolbar/table-toolbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, NgZone, OnDestroy } from '@angular/core';\nimport { ThyPopover, ThyPopoverRef } from 'ngx-tethys/popover';\nimport { Editor } from 'slate';\nimport { TableStore } from '../../table.store';\nimport { ColorType, BackgroundColors, TableHeaderBackgroundColor, SpecialBackgroundColor } from '../../../../constants/color-select';\nimport { TheColorSelectService } from '../../../../services/color-select.service';\nimport { splitCell } from '../../utils/split-cell';\nimport { setCellMenuInvisibility } from '../../utils/set-menu-cell-invisibility';\nimport { MenuEntity } from '../../table.types';\nimport { TableEditor } from '../../table.editor';\nimport { TheTableOptionsComponent } from './table-options.component';\n\n@Component({\n    selector: 'the-table-toolbar',\n    templateUrl: 'table-toolbar.component.html'\n})\nexport class TheTableToolbarComponent implements OnInit, OnDestroy {\n    selectedColor: string;\n\n    deleteIcon: string;\n\n    iconName: string;\n\n    @Input() tableStore: TableStore;\n\n    @Input() isActiveSelect: boolean;\n\n    get editor(): Editor {\n        return this.tableStore && this.tableStore.editor;\n    }\n\n    cellMenuList: MenuEntity[] = [\n        {\n            key: 'merge-cells',\n            name: '合并单元格',\n            invisibility: false,\n            icon: 'table-merge-cells',\n            actionHandle: () => {\n                event.preventDefault();\n                event.stopPropagation();\n                this.tableStore.mergeCell(this.editor);\n                this.popoverRef.close();\n                this.tableStore.clearSelectedCells();\n            }\n        },\n        {\n            key: 'split-cells',\n            name: '拆分单元格',\n            invisibility: false,\n            icon: 'table-unmerge-cells',\n            actionHandle: () => {\n                event.preventDefault();\n                event.stopPropagation();\n                splitCell(this.editor);\n                this.popoverRef.close();\n                this.tableStore.clearSelectedCells();\n            }\n        }\n    ];\n\n    get isShowSplitLine() {\n        return this.cellMenuList.filter(item => !item.invisibility).length > 1;\n    }\n\n    constructor(\n        private ngZone: NgZone,\n        private colorSelectService: TheColorSelectService,\n        private thyPopover: ThyPopover,\n        private popoverRef: ThyPopoverRef<TheTableToolbarComponent>\n    ) {}\n\n    ngOnInit() {\n        this.deleteIcon = DeleteIcon[this.getDeleteIcon()];\n        this.getIconName(this.deleteIcon);\n        setCellMenuInvisibility(this.editor, this.cellMenuList, this.tableStore.selectedCells, this.isActiveSelect);\n        this.selectedColor = this.tableStore.getSelectedCellBackgroundColor();\n    }\n\n    ngOnDestroy() {\n        this.colorSelectService.closeColorSelect();\n    }\n\n    getIconName(key: string) {\n        switch (key) {\n            case 'trash':\n                this.iconName = '删除表格';\n                break;\n            case 'table-delete-columns':\n                this.iconName = '删除整列';\n                break;\n            case 'table-delete-rows':\n                this.iconName = '删除整行';\n                break;\n        }\n    }\n\n    getDeleteIcon() {\n        if (this.tableStore.isSelectedTable) {\n            return DeleteIcon.trash;\n        }\n        if (this.tableStore.selectedRowsIndex.length > 0) {\n            return DeleteIcon['table-delete-rows'];\n        }\n        if (this.tableStore.selectedColumnsIndex.length > 0) {\n            return DeleteIcon['table-delete-columns'];\n        }\n        return null;\n    }\n\n    onDelete(event: MouseEvent) {\n        event.preventDefault();\n        this.tableStore.removeColumnOrRows();\n        this.tableStore.clearDangerousCells();\n        this.tableStore.clearSelectedCells();\n        this.popoverRef.close();\n    }\n\n    onEnterDelete(event: MouseEvent) {\n        this.tableStore.setDangerousCells();\n    }\n\n    onLeaveDelete(event: MouseEvent) {\n        this.tableStore.clearDangerousCells();\n    }\n\n    openSelectColor(event: MouseEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n        const element = (event.target as HTMLElement).closest('.thy-icon-nav-link');\n        const isHeader = TableEditor.isActiveHeader(this.editor);\n        this.ngZone.run(() => {\n            this.colorSelectService.toggleColorSelect(\n                element as HTMLElement,\n                this.selectedColor,\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.selectedColor = newColor;\n                }\n            );\n        });\n    }\n\n    openTableOptionMenu(event: Event) {\n        event.preventDefault();\n        event.stopPropagation();\n        this.thyPopover.open(TheTableOptionsComponent, {\n            origin: event.currentTarget as HTMLElement,\n            initialState: {\n                tableStore: this.tableStore,\n                editor: this.editor\n            },\n            insideClosable: false,\n            hasBackdrop: false,\n            placement: 'bottomLeft',\n            originActiveClass: 'table-options-active',\n            panelClass: 'table-options-pannel'\n        });\n    }\n}\n\nexport enum DeleteIcon {\n    'table-delete-rows',\n    'table-delete-columns',\n    'trash'\n}\n","<thy-icon-nav>\n    <ng-container *ngFor=\"let item of cellMenuList\">\n        <a href=\"javascript:;\" thyIconNavLink *ngIf=\"!item.invisibility\" [thyTooltip]=\"item.name\" (mousedown)=\"item.actionHandle()\">\n            <thy-icon [thyIconName]=\"item.icon\"></thy-icon>\n        </a>\n    </ng-container>\n    <nav-split-line *ngIf=\"!isActiveSelect && isShowSplitLine\"></nav-split-line>\n    <a href=\"javascript:;\" thyIconNavLink thyTooltip=\"单元格背景\" (mousedown)=\"openSelectColor($event)\">\n        <thy-icon thyIconName=\"background-tt\" thyIconType=\"twotone\" [thyTwotoneColor]=\"selectedColor\"></thy-icon>\n    </a>\n    <nav-split-line *ngIf=\"tableStore.isSelectedTable\"></nav-split-line>\n    <button\n        thyButton=\"default\"\n        *ngIf=\"tableStore.isSelectedTable\"\n        class=\"mr-2\"\n        thySize=\"md\"\n        class=\"table-options\"\n        (mousedown)=\"openTableOptionMenu($event)\"\n    >\n        <span>表格选项</span>\n        <thy-icon thyIconName=\"caret-down\"></thy-icon>\n    </button>\n    <nav-split-line *ngIf=\"deleteIcon\"></nav-split-line>\n    <a\n        *ngIf=\"deleteIcon\"\n        href=\"javascript:;\"\n        thyIconNavLink\n        [thyTooltip]=\"iconName\"\n        class=\"danger\"\n        [thyIconNavLinkIcon]=\"deleteIcon\"\n        (mousedown)=\"onDelete($event)\"\n        (mouseenter)=\"onEnterDelete($event)\"\n        (mouseleave)=\"onLeaveDelete($event)\"\n    ></a>\n</thy-icon-nav>\n"]}
|
|
@@ -61,7 +61,7 @@ export class TableService {
|
|
|
61
61
|
return tableElement.querySelector('.the-table-corner-controls');
|
|
62
62
|
}
|
|
63
63
|
if (selectedColumnsIndex.length > 0 && row === 0) {
|
|
64
|
-
return tableElement.querySelectorAll('.the-table-col-controls
|
|
64
|
+
return tableElement.querySelectorAll('.the-table-col-controls')[col];
|
|
65
65
|
}
|
|
66
66
|
if (selectedRowsIndex.length > 0 && col === 0) {
|
|
67
67
|
return tableElement.querySelectorAll('.the-table-row-controls-button-wrap')[row];
|
|
@@ -99,4 +99,4 @@ TableService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version
|
|
|
99
99
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TableService, decorators: [{
|
|
100
100
|
type: Injectable
|
|
101
101
|
}], ctorParameters: function () { return [{ type: i1.ThyPopover }, { type: i2.Overlay }, { type: i3.TableStore }, { type: i4.TheTableContextMenuService }, { type: i0.NgZone }, { type: i5.TheContextService }]; } });
|
|
102
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.service.js","sourceRoot":"","sources":["../../../../../packages/src/plugins/table/table.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, NgZone } from '@angular/core';\nimport { ThyPlacement } from 'ngx-tethys/core';\nimport { ThyPopover, ThyPopoverRef } from 'ngx-tethys/popover';\nimport { TheTableToolbarComponent } from './components/toolbar/table-toolbar.component';\nimport { Overlay } from '@angular/cdk/overlay';\nimport { TableStore } from './table.store';\nimport { TheTableContextMenuService } from '../../services/table-contextmenu.service';\nimport { TheContextService } from '../../services/context.service';\nimport { fromEvent, merge } from 'rxjs';\nimport { filter, take } from 'rxjs/operators';\nimport { isVirtualKey } from './utils/is-virtual-key';\n\n@Injectable()\nexport class TableService {\n    backdropClosable = false;\n\n    hasBackdrop = false;\n\n    insideClosable = false;\n\n    placement: ThyPlacement = 'topLeft';\n\n    offset = 8;\n\n    toolbarRef: ThyPopoverRef<any>;\n\n    get isOpened() {\n        return this.toolbarRef && this.toolbarRef.componentInstance;\n    }\n\n    constructor(\n        private thyPopover: ThyPopover,\n        private overlay: Overlay,\n        private tableStore: TableStore,\n        private theTableContextMenuService: TheTableContextMenuService,\n        private ngZone: NgZone,\n        private theContextService: TheContextService\n    ) {}\n\n    openToolbar(origin: HTMLElement, isActiveSelect?: boolean) {\n        this.theTableContextMenuService.closeContextMenu();\n\n        if (this.isOpened) {\n            if (this.toolbarRef.containerInstance.config.origin === origin) {\n                return;\n            }\n            this.toolbarRef.close();\n        }\n        this.toolbarRef = this.thyPopover.open(TheTableToolbarComponent, {\n            initialState: {\n                tableStore: this.tableStore,\n                isActiveSelect\n            },\n            viewContainerRef: this.theContextService.getOptions().viewContainerRef,\n            origin: this.getOrigin(origin),\n            backdropClosable: this.backdropClosable,\n            placement: this.placement,\n            offset: this.offset,\n            hasBackdrop: this.hasBackdrop,\n            insideClosable: this.insideClosable,\n            panelClass: 'the-table-toolbar-wrap',\n            scrollStrategy: this.overlay.scrollStrategies.reposition(),\n            manualClosure: true\n        });\n        this._listenCellClearEvent();\n    }\n\n    getOrigin(origin: HTMLElement): HTMLElement {\n        if (origin instanceof HTMLTableCellElement && origin.tagName !== 'TH') {\n            const { selectedRowsIndex, selectedColumnsIndex, focusCellPath, isSelectedTable, focusCellElement } = this.tableStore;\n            const [row, col] = focusCellPath.slice(-2);\n            const tableElement = focusCellElement.closest('.the-table-container') as HTMLElement;\n            if (isSelectedTable && col === 0 && row === 0) {\n                return tableElement.querySelector('.the-table-corner-controls');\n            }\n            if (selectedColumnsIndex.length > 0 && row === 0) {\n                return tableElement.querySelectorAll('.the-table-col-controls-inner')[col] as HTMLElement;\n            }\n            if (selectedRowsIndex.length > 0 && col === 0) {\n                return tableElement.querySelectorAll('.the-table-row-controls-button-wrap')[row] as HTMLElement;\n            }\n        }\n        return origin;\n    }\n\n    closeToolbar() {\n        if (this.isOpened) {\n            this.ngZone.run(() => {\n                this.toolbarRef.close();\n            });\n            return this.toolbarRef.afterClosed();\n        }\n    }\n\n    _listenCellClearEvent() {\n        const onMouseObservable = merge(\n            fromEvent<MouseEvent>(document, 'mousedown').pipe(filter((e: MouseEvent) => e.button !== 2)),\n            fromEvent<KeyboardEvent>(document, 'keydown').pipe(\n                filter((e: KeyboardEvent) => {\n                    return !isVirtualKey(e);\n                })\n            )\n        )\n            .pipe(take(1))\n            .subscribe((e: MouseEvent) => {\n                if (this.tableStore.selectedCells && this.tableStore.selectedCells.length > 0) {\n                    if (e.type === 'keydown') {\n                        this.tableStore.clearSelectedCellsContent();\n                    }\n                    this.tableStore.clearSelectedCells();\n                    this.closeToolbar();\n                    onMouseObservable.unsubscribe();\n                }\n            });\n    }\n}\n"]}
|
|
102
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.service.js","sourceRoot":"","sources":["../../../../../packages/src/plugins/table/table.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, NgZone } from '@angular/core';\nimport { ThyPlacement } from 'ngx-tethys/core';\nimport { ThyPopover, ThyPopoverRef } from 'ngx-tethys/popover';\nimport { TheTableToolbarComponent } from './components/toolbar/table-toolbar.component';\nimport { Overlay } from '@angular/cdk/overlay';\nimport { TableStore } from './table.store';\nimport { TheTableContextMenuService } from '../../services/table-contextmenu.service';\nimport { TheContextService } from '../../services/context.service';\nimport { fromEvent, merge } from 'rxjs';\nimport { filter, take } from 'rxjs/operators';\nimport { isVirtualKey } from './utils/is-virtual-key';\n\n@Injectable()\nexport class TableService {\n    backdropClosable = false;\n\n    hasBackdrop = false;\n\n    insideClosable = false;\n\n    placement: ThyPlacement = 'topLeft';\n\n    offset = 8;\n\n    toolbarRef: ThyPopoverRef<any>;\n\n    get isOpened() {\n        return this.toolbarRef && this.toolbarRef.componentInstance;\n    }\n\n    constructor(\n        private thyPopover: ThyPopover,\n        private overlay: Overlay,\n        private tableStore: TableStore,\n        private theTableContextMenuService: TheTableContextMenuService,\n        private ngZone: NgZone,\n        private theContextService: TheContextService\n    ) {}\n\n    openToolbar(origin: HTMLElement, isActiveSelect?: boolean) {\n        this.theTableContextMenuService.closeContextMenu();\n\n        if (this.isOpened) {\n            if (this.toolbarRef.containerInstance.config.origin === origin) {\n                return;\n            }\n            this.toolbarRef.close();\n        }\n        this.toolbarRef = this.thyPopover.open(TheTableToolbarComponent, {\n            initialState: {\n                tableStore: this.tableStore,\n                isActiveSelect\n            },\n            viewContainerRef: this.theContextService.getOptions().viewContainerRef,\n            origin: this.getOrigin(origin),\n            backdropClosable: this.backdropClosable,\n            placement: this.placement,\n            offset: this.offset,\n            hasBackdrop: this.hasBackdrop,\n            insideClosable: this.insideClosable,\n            panelClass: 'the-table-toolbar-wrap',\n            scrollStrategy: this.overlay.scrollStrategies.reposition(),\n            manualClosure: true\n        });\n        this._listenCellClearEvent();\n    }\n\n    getOrigin(origin: HTMLElement): HTMLElement {\n        if (origin instanceof HTMLTableCellElement && origin.tagName !== 'TH') {\n            const { selectedRowsIndex, selectedColumnsIndex, focusCellPath, isSelectedTable, focusCellElement } = this.tableStore;\n            const [row, col] = focusCellPath.slice(-2);\n            const tableElement = focusCellElement.closest('.the-table-container') as HTMLElement;\n            if (isSelectedTable && col === 0 && row === 0) {\n                return tableElement.querySelector('.the-table-corner-controls');\n            }\n            if (selectedColumnsIndex.length > 0 && row === 0) {\n                return tableElement.querySelectorAll('.the-table-col-controls')[col] as HTMLElement;\n            }\n            if (selectedRowsIndex.length > 0 && col === 0) {\n                return tableElement.querySelectorAll('.the-table-row-controls-button-wrap')[row] as HTMLElement;\n            }\n        }\n        return origin;\n    }\n\n    closeToolbar() {\n        if (this.isOpened) {\n            this.ngZone.run(() => {\n                this.toolbarRef.close();\n            });\n            return this.toolbarRef.afterClosed();\n        }\n    }\n\n    _listenCellClearEvent() {\n        const onMouseObservable = merge(\n            fromEvent<MouseEvent>(document, 'mousedown').pipe(filter((e: MouseEvent) => e.button !== 2)),\n            fromEvent<KeyboardEvent>(document, 'keydown').pipe(\n                filter((e: KeyboardEvent) => {\n                    return !isVirtualKey(e);\n                })\n            )\n        )\n            .pipe(take(1))\n            .subscribe((e: MouseEvent) => {\n                if (this.tableStore.selectedCells && this.tableStore.selectedCells.length > 0) {\n                    if (e.type === 'keydown') {\n                        this.tableStore.clearSelectedCellsContent();\n                    }\n                    this.tableStore.clearSelectedCells();\n                    this.closeToolbar();\n                    onMouseObservable.unsubscribe();\n                }\n            });\n    }\n}\n"]}
|