@worktile/theia 14.1.8 → 14.2.0

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 (98) hide show
  1. package/components/listbox/listbox.d.ts +85 -0
  2. package/components/listbox/listbox.type.d.ts +5 -0
  3. package/components/plugin-menu/plugin-menu.component.d.ts +39 -0
  4. package/components/plugin-menu/plugin-menu.component.scss +50 -0
  5. package/components/table-select/table-select.component.d.ts +2 -2
  6. package/components/table-select/table-select.component.scss +1 -1
  7. package/components/toolbar/toolbar.component.d.ts +4 -3
  8. package/components/toolbar-dropdown/toolbar-dropdown.component.d.ts +5 -1
  9. package/components/toolbar-dropdown/toolbar-dropdown.component.scss +0 -11
  10. package/components/toolbar-group/toolbar-group.component.d.ts +1 -1
  11. package/components/toolbar-group/toolbar-group.component.scss +2 -3
  12. package/components/toolbar-item/toolbar-item.component.d.ts +2 -7
  13. package/constants/index.d.ts +1 -0
  14. package/constants/node-types.d.ts +2 -1
  15. package/constants/plugin-menu.d.ts +24 -0
  16. package/constants/toolbar.d.ts +0 -5
  17. package/core/utils/index.d.ts +1 -0
  18. package/core/utils/plugin-menu.d.ts +10 -0
  19. package/editor.component.d.ts +6 -2
  20. package/editor.module.d.ts +53 -49
  21. package/esm2020/components/listbox/listbox.mjs +341 -0
  22. package/esm2020/components/listbox/listbox.type.mjs +5 -0
  23. package/esm2020/components/plugin-menu/plugin-menu.component.mjs +102 -0
  24. package/esm2020/components/table-select/table-select.component.mjs +7 -11
  25. package/esm2020/components/toolbar/toolbar.component.mjs +31 -29
  26. package/esm2020/components/toolbar-dropdown/toolbar-dropdown.component.mjs +25 -6
  27. package/esm2020/components/toolbar-group/toolbar-group.component.mjs +5 -5
  28. package/esm2020/components/toolbar-item/toolbar-item.component.mjs +29 -70
  29. package/esm2020/constants/index.mjs +2 -1
  30. package/esm2020/constants/node-types.mjs +2 -1
  31. package/esm2020/constants/plugin-menu.mjs +272 -0
  32. package/esm2020/constants/toolbar.mjs +5 -23
  33. package/esm2020/core/create-toolbar.mjs +5 -6
  34. package/esm2020/core/utils/index.mjs +2 -1
  35. package/esm2020/core/utils/plugin-menu.mjs +33 -0
  36. package/esm2020/editor.component.mjs +26 -23
  37. package/esm2020/editor.module.mjs +38 -9
  38. package/esm2020/interfaces/editor.mjs +1 -1
  39. package/esm2020/interfaces/plugins/index.mjs +2 -1
  40. package/esm2020/interfaces/plugins/plugin-key.mjs +2 -1
  41. package/esm2020/interfaces/plugins/plugin-menu.mjs +19 -0
  42. package/esm2020/interfaces/plugins/plugins.mjs +1 -1
  43. package/esm2020/interfaces/toolbar.mjs +1 -1
  44. package/esm2020/plugins/blockquote/blockquote.plugin.mjs +15 -1
  45. package/esm2020/plugins/code/code.component.mjs +3 -4
  46. package/esm2020/plugins/code/code.plugin.mjs +15 -1
  47. package/esm2020/plugins/color/toolbar-item.component.mjs +2 -2
  48. package/esm2020/plugins/common/common.plugin.mjs +20 -0
  49. package/esm2020/plugins/deserializers/deserialize-html.plugin.mjs +11 -3
  50. package/esm2020/plugins/deserializers/deserialize-md.plugin.mjs +11 -3
  51. package/esm2020/plugins/heading/heading.plugin.mjs +49 -2
  52. package/esm2020/plugins/hr/hr.plugin.mjs +15 -1
  53. package/esm2020/plugins/image/image.editor.mjs +17 -1
  54. package/esm2020/plugins/image/image.plugin.mjs +15 -1
  55. package/esm2020/plugins/indent/indent.plugin.mjs +3 -2
  56. package/esm2020/plugins/index.mjs +3 -1
  57. package/esm2020/plugins/link/link.plugin.mjs +15 -2
  58. package/esm2020/plugins/list/list.plugin.mjs +26 -2
  59. package/esm2020/plugins/quick-insert/components/quick-insert.component.mjs +43 -19
  60. package/esm2020/plugins/quick-insert/quick-insert.editor.mjs +41 -26
  61. package/esm2020/plugins/quick-insert/quick-insert.plugin.mjs +62 -35
  62. package/esm2020/plugins/table/table.plugin.mjs +16 -1
  63. package/esm2020/plugins/table/toolbar-item.component.mjs +4 -3
  64. package/esm2020/public-api.mjs +3 -1
  65. package/esm2020/services/toolbar.service.mjs +4 -5
  66. package/esm2020/utils/blob.mjs +16 -0
  67. package/esm2020/utils/fragment.mjs +9 -1
  68. package/esm2020/utils/index.mjs +2 -1
  69. package/esm2020/utils/weak-maps.mjs +2 -2
  70. package/fesm2015/worktile-theia.mjs +1555 -595
  71. package/fesm2015/worktile-theia.mjs.map +1 -1
  72. package/fesm2020/worktile-theia.mjs +1546 -588
  73. package/fesm2020/worktile-theia.mjs.map +1 -1
  74. package/interfaces/editor.d.ts +2 -0
  75. package/interfaces/plugins/index.d.ts +1 -0
  76. package/interfaces/plugins/plugin-key.d.ts +2 -1
  77. package/interfaces/plugins/plugin-menu.d.ts +26 -0
  78. package/interfaces/plugins/plugins.d.ts +6 -1
  79. package/interfaces/toolbar.d.ts +1 -3
  80. package/package.json +1 -1
  81. package/plugins/code/code.component.d.ts +1 -2
  82. package/plugins/common/common.plugin.d.ts +1 -0
  83. package/plugins/image/image.editor.d.ts +2 -0
  84. package/plugins/link/link.component.scss +0 -12
  85. package/plugins/quick-insert/components/quick-insert.component.d.ts +8 -7
  86. package/plugins/quick-insert/components/quick-insert.component.scss +0 -4
  87. package/plugins/quick-insert/quick-insert.editor.d.ts +7 -4
  88. package/plugins/quick-insert/quick-insert.plugin.d.ts +2 -2
  89. package/public-api.d.ts +2 -0
  90. package/services/toolbar.service.d.ts +1 -1
  91. package/styles/index.scss +1 -1
  92. package/utils/blob.d.ts +1 -0
  93. package/utils/fragment.d.ts +1 -0
  94. package/utils/index.d.ts +1 -0
  95. package/utils/weak-maps.d.ts +1 -1
  96. package/esm2020/plugins/quick-insert/components/quick-toolbar/quick-toolbar.component.mjs +0 -80
  97. package/plugins/quick-insert/components/quick-toolbar/quick-toolbar.component.d.ts +0 -28
  98. package/plugins/quick-insert/components/quick-toolbar/quick-toolbar.component.scss +0 -23
@@ -0,0 +1,341 @@
1
+ import { DOWN_ARROW, LEFT_ARROW, RIGHT_ARROW, UP_ARROW } from '@angular/cdk/keycodes';
2
+ import { Optional, SkipSelf } from '@angular/core';
3
+ import { ContentChildren, Directive, EventEmitter, HostBinding, Inject, Input, Output } from '@angular/core';
4
+ import { fromEvent } from 'rxjs';
5
+ import { THE_LISTBOX_TOKEN, THE_LISTBOX_PARENT_OPTION_TOKEN, THE_LISTBOX_PARENT_GROUP_TOKEN } from './listbox.type';
6
+ import * as i0 from "@angular/core";
7
+ export class TheListboxOptionDirective {
8
+ constructor(parentOption, parentGroup, elementRef) {
9
+ this.parentOption = parentOption;
10
+ this.parentGroup = parentGroup;
11
+ this.elementRef = elementRef;
12
+ this._active = false;
13
+ this.className = 'the-listbox-option';
14
+ }
15
+ get hasChild() {
16
+ return this._options.length > 0;
17
+ }
18
+ get firstChild() {
19
+ return this._options.first;
20
+ }
21
+ ngOnInit() { }
22
+ ngAfterContentInit() { }
23
+ getGroups() {
24
+ const groups = [];
25
+ this._options.forEach(option => {
26
+ if (option.parentOption && option.parentOption === this && !groups.includes(option.parentGroup)) {
27
+ groups.push(option.parentGroup);
28
+ }
29
+ });
30
+ return groups;
31
+ }
32
+ setActive(active) {
33
+ this._active = active;
34
+ if (active) {
35
+ this.elementRef.nativeElement.classList.add('active');
36
+ }
37
+ else {
38
+ this.elementRef.nativeElement.classList.remove('active');
39
+ }
40
+ }
41
+ getActive() {
42
+ return this._active;
43
+ }
44
+ }
45
+ TheListboxOptionDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: TheListboxOptionDirective, deps: [{ token: THE_LISTBOX_PARENT_OPTION_TOKEN, optional: true, skipSelf: true }, { token: THE_LISTBOX_PARENT_GROUP_TOKEN }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
46
+ TheListboxOptionDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.0", type: TheListboxOptionDirective, selector: "[theListboxOpton]", host: { properties: { "class": "this.className" } }, providers: [
47
+ {
48
+ provide: THE_LISTBOX_PARENT_OPTION_TOKEN,
49
+ useExisting: TheListboxOptionDirective
50
+ }
51
+ ], queries: [{ propertyName: "_options", predicate: TheListboxOptionDirective, descendants: true }], exportAs: ["theListboxOpton"], ngImport: i0 });
52
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: TheListboxOptionDirective, decorators: [{
53
+ type: Directive,
54
+ args: [{
55
+ selector: '[theListboxOpton]',
56
+ exportAs: 'theListboxOpton',
57
+ providers: [
58
+ {
59
+ provide: THE_LISTBOX_PARENT_OPTION_TOKEN,
60
+ useExisting: TheListboxOptionDirective
61
+ }
62
+ ]
63
+ }]
64
+ }], ctorParameters: function () { return [{ type: TheListboxOptionDirective, decorators: [{
65
+ type: Inject,
66
+ args: [THE_LISTBOX_PARENT_OPTION_TOKEN]
67
+ }, {
68
+ type: Optional
69
+ }, {
70
+ type: SkipSelf
71
+ }] }, { type: TheListboxGroupDirective, decorators: [{
72
+ type: Inject,
73
+ args: [THE_LISTBOX_PARENT_GROUP_TOKEN]
74
+ }] }, { type: i0.ElementRef }]; }, propDecorators: { className: [{
75
+ type: HostBinding,
76
+ args: ['class']
77
+ }], _options: [{
78
+ type: ContentChildren,
79
+ args: [TheListboxOptionDirective, { descendants: true }]
80
+ }] } });
81
+ export class TheListboxGroupDirective {
82
+ constructor(parentOption, theListBox) {
83
+ this.parentOption = parentOption;
84
+ this.theListBox = theListBox;
85
+ this.className = 'the-listbox-group';
86
+ this.options = [];
87
+ /**
88
+ * 大于 1 表示水平分组,小于等于 1 表示垂直分组
89
+ */
90
+ this.horizontalColumn = 1;
91
+ }
92
+ ngOnInit() { }
93
+ ngAfterContentInit() {
94
+ this.filterOptions();
95
+ }
96
+ filterOptions() {
97
+ this.options = this._options.filter(_option => {
98
+ if (_option.parentGroup && _option.parentGroup === this) {
99
+ return true;
100
+ }
101
+ else {
102
+ return false;
103
+ }
104
+ });
105
+ }
106
+ getSiblingGroups() {
107
+ if (this.parentOption) {
108
+ return this.parentOption.getGroups();
109
+ }
110
+ else {
111
+ return this.theListBox.groups;
112
+ }
113
+ }
114
+ getFirst() {
115
+ return this.options[0];
116
+ }
117
+ getLast() {
118
+ return this.options[this.options.length - 1];
119
+ }
120
+ }
121
+ TheListboxGroupDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: TheListboxGroupDirective, deps: [{ token: THE_LISTBOX_PARENT_OPTION_TOKEN, optional: true, skipSelf: true }, { token: THE_LISTBOX_TOKEN }], target: i0.ɵɵFactoryTarget.Directive });
122
+ TheListboxGroupDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.0", type: TheListboxGroupDirective, selector: "[theListboxGroup]", inputs: { horizontalColumn: "horizontalColumn" }, host: { properties: { "class": "this.className" } }, providers: [
123
+ {
124
+ provide: THE_LISTBOX_PARENT_GROUP_TOKEN,
125
+ useExisting: TheListboxGroupDirective
126
+ }
127
+ ], queries: [{ propertyName: "_options", predicate: TheListboxOptionDirective, descendants: true }], exportAs: ["theListboxGroup"], ngImport: i0 });
128
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: TheListboxGroupDirective, decorators: [{
129
+ type: Directive,
130
+ args: [{
131
+ selector: '[theListboxGroup]',
132
+ exportAs: 'theListboxGroup',
133
+ providers: [
134
+ {
135
+ provide: THE_LISTBOX_PARENT_GROUP_TOKEN,
136
+ useExisting: TheListboxGroupDirective
137
+ }
138
+ ]
139
+ }]
140
+ }], ctorParameters: function () { return [{ type: TheListboxOptionDirective, decorators: [{
141
+ type: Inject,
142
+ args: [THE_LISTBOX_PARENT_OPTION_TOKEN]
143
+ }, {
144
+ type: Optional
145
+ }, {
146
+ type: SkipSelf
147
+ }] }, { type: TheListboxDirective, decorators: [{
148
+ type: Inject,
149
+ args: [THE_LISTBOX_TOKEN]
150
+ }] }]; }, propDecorators: { className: [{
151
+ type: HostBinding,
152
+ args: ['class']
153
+ }], _options: [{
154
+ type: ContentChildren,
155
+ args: [TheListboxOptionDirective, { descendants: true }]
156
+ }], horizontalColumn: [{
157
+ type: Input
158
+ }] } });
159
+ export class TheListboxDirective {
160
+ constructor(ngZone, elementRef) {
161
+ this.ngZone = ngZone;
162
+ this.elementRef = elementRef;
163
+ this.className = 'the-listbox-container';
164
+ this.groups = [];
165
+ this.theActiveOptionChange = new EventEmitter();
166
+ }
167
+ ngOnInit() { }
168
+ ngAfterContentInit() {
169
+ this.filterGroups();
170
+ if (this.groups.length > 0) {
171
+ this.setActiveItem(null, this.groups[0].getFirst(), 'init');
172
+ }
173
+ this._optionChangesSubscription = this._groups.changes.subscribe(() => {
174
+ this.filterGroups();
175
+ this.setActiveItem(null, this.groups[0].getFirst(), 'init');
176
+ });
177
+ this.ngZone.runOutsideAngular(() => {
178
+ this._keyboardSubscription = fromEvent(this.keyboardContainer || this.elementRef.nativeElement, 'keydown').subscribe(event => {
179
+ this.handleKeydown(event);
180
+ });
181
+ });
182
+ }
183
+ filterGroups() {
184
+ this.groups = this._groups.filter(group => {
185
+ if (!group.parentOption) {
186
+ return true;
187
+ }
188
+ else {
189
+ return false;
190
+ }
191
+ });
192
+ }
193
+ handleKeydown(event) {
194
+ const { keyCode } = event;
195
+ switch (keyCode) {
196
+ case DOWN_ARROW:
197
+ this.setNextLineActive();
198
+ event.preventDefault();
199
+ break;
200
+ case UP_ARROW:
201
+ this.setPreviousLineActive();
202
+ event.preventDefault();
203
+ break;
204
+ case RIGHT_ARROW:
205
+ this.setNextItemActive();
206
+ event.preventDefault();
207
+ break;
208
+ case LEFT_ARROW:
209
+ this.setPreviousItemActive();
210
+ event.preventDefault();
211
+ break;
212
+ }
213
+ }
214
+ /**
215
+ * ←
216
+ */
217
+ setPreviousItemActive() {
218
+ if (this.activeOption.parentOption) {
219
+ this.setActiveItem(this.activeOption, this.activeOption.parentOption, 'parent');
220
+ }
221
+ else {
222
+ const groupOptions = this.activeOption.parentGroup.options;
223
+ let optionIndex = groupOptions.indexOf(this.activeOption);
224
+ let newOptionIndex = optionIndex - 1;
225
+ if (newOptionIndex >= 0) {
226
+ this.setActiveItem(this.activeOption, groupOptions[newOptionIndex], 'turn');
227
+ }
228
+ else {
229
+ this.enterPreviousGroup();
230
+ }
231
+ }
232
+ }
233
+ /**
234
+ * ↓ 键
235
+ */
236
+ setNextLineActive() {
237
+ const groupOptions = this.activeOption.parentGroup.options;
238
+ let optionIndex = groupOptions.indexOf(this.activeOption);
239
+ let newOptionIndex = optionIndex + this.activeOption.parentGroup.horizontalColumn;
240
+ if (newOptionIndex <= groupOptions.length - 1) {
241
+ this.setActiveItem(this.activeOption, groupOptions[newOptionIndex], 'turn');
242
+ }
243
+ else {
244
+ this.enterNextGroup();
245
+ }
246
+ }
247
+ /**
248
+ * → 键
249
+ */
250
+ setNextItemActive() {
251
+ if (this.activeOption.hasChild) {
252
+ this.setActiveItem(this.activeOption, this.activeOption.firstChild, 'child');
253
+ }
254
+ else {
255
+ const groupOptions = this.activeOption.parentGroup.options;
256
+ let optionIndex = groupOptions.indexOf(this.activeOption);
257
+ let newOptionIndex = optionIndex + 1;
258
+ if (newOptionIndex <= groupOptions.length - 1) {
259
+ this.setActiveItem(this.activeOption, groupOptions[newOptionIndex], 'turn');
260
+ }
261
+ else {
262
+ this.enterNextGroup();
263
+ }
264
+ }
265
+ }
266
+ /**
267
+ * ↑ 键
268
+ */
269
+ setPreviousLineActive() {
270
+ const groupOptions = this.activeOption.parentGroup.options;
271
+ let optionIndex = groupOptions.indexOf(this.activeOption);
272
+ let newOptionIndex = optionIndex - this.activeOption.parentGroup.horizontalColumn;
273
+ if (newOptionIndex >= 0) {
274
+ this.setActiveItem(this.activeOption, groupOptions[newOptionIndex], 'turn');
275
+ }
276
+ else {
277
+ this.enterPreviousGroup();
278
+ }
279
+ }
280
+ enterNextGroup() {
281
+ const groups = this.activeOption.parentGroup.getSiblingGroups();
282
+ const groupIndex = groups.indexOf(this.activeOption.parentGroup);
283
+ let newGroupIndex = groupIndex + 1;
284
+ if (newGroupIndex > groups.length - 1) {
285
+ newGroupIndex = 0;
286
+ }
287
+ this.setActiveItem(this.activeOption, groups[newGroupIndex].getFirst(), 'turn');
288
+ }
289
+ enterPreviousGroup() {
290
+ const groups = this.activeOption.parentGroup.getSiblingGroups();
291
+ const groupIndex = groups.indexOf(this.activeOption.parentGroup);
292
+ let newGroupIndex = groupIndex - 1;
293
+ if (newGroupIndex < 0) {
294
+ newGroupIndex = groups.length - 1;
295
+ }
296
+ this.setActiveItem(this.activeOption, groups[newGroupIndex].getLast(), 'turn');
297
+ }
298
+ setActiveItem(previous, option, type) {
299
+ if (previous) {
300
+ previous.setActive(false);
301
+ }
302
+ option.setActive(true);
303
+ this.activeOption = option;
304
+ this.theActiveOptionChange.emit({ option, type });
305
+ }
306
+ ngOnDestroy() {
307
+ this._optionChangesSubscription.unsubscribe();
308
+ this._keyboardSubscription.unsubscribe();
309
+ }
310
+ }
311
+ TheListboxDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: TheListboxDirective, deps: [{ token: i0.NgZone }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
312
+ TheListboxDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.0", type: TheListboxDirective, selector: "[theListBox]", inputs: { keyboardContainer: "keyboardContainer" }, outputs: { theActiveOptionChange: "theActiveOptionChange" }, host: { properties: { "class": "this.className" } }, providers: [
313
+ {
314
+ provide: THE_LISTBOX_TOKEN,
315
+ useExisting: TheListboxDirective
316
+ }
317
+ ], queries: [{ propertyName: "_groups", predicate: TheListboxGroupDirective, descendants: true }], exportAs: ["theListBox"], ngImport: i0 });
318
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: TheListboxDirective, decorators: [{
319
+ type: Directive,
320
+ args: [{
321
+ selector: '[theListBox]',
322
+ exportAs: 'theListBox',
323
+ providers: [
324
+ {
325
+ provide: THE_LISTBOX_TOKEN,
326
+ useExisting: TheListboxDirective
327
+ }
328
+ ]
329
+ }]
330
+ }], ctorParameters: function () { return [{ type: i0.NgZone }, { type: i0.ElementRef }]; }, propDecorators: { className: [{
331
+ type: HostBinding,
332
+ args: ['class']
333
+ }], _groups: [{
334
+ type: ContentChildren,
335
+ args: [TheListboxGroupDirective, { descendants: true }]
336
+ }], keyboardContainer: [{
337
+ type: Input
338
+ }], theActiveOptionChange: [{
339
+ type: Output
340
+ }] } });
341
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"listbox.js","sourceRoot":"","sources":["../../../../../packages/src/components/listbox/listbox.ts"],"names":[],"mappings":"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","sourcesContent":["import { DOWN_ARROW, LEFT_ARROW, RIGHT_ARROW, UP_ARROW } from '@angular/cdk/keycodes';\nimport { NgZone, Optional, SkipSelf } from '@angular/core';\nimport {\n    AfterContentInit,\n    ContentChildren,\n    Directive,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    Inject,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output,\n    QueryList\n} from '@angular/core';\nimport { fromEvent } from 'rxjs';\nimport { Subscription } from 'rxjs/internal/Subscription';\nimport {\n    TheListboxChangeEventType,\n    THE_LISTBOX_TOKEN,\n    THE_LISTBOX_PARENT_OPTION_TOKEN,\n    THE_LISTBOX_PARENT_GROUP_TOKEN\n} from './listbox.type';\n\n@Directive({\n    selector: '[theListboxOpton]',\n    exportAs: 'theListboxOpton',\n    providers: [\n        {\n            provide: THE_LISTBOX_PARENT_OPTION_TOKEN,\n            useExisting: TheListboxOptionDirective\n        }\n    ]\n})\nexport class TheListboxOptionDirective implements OnInit, AfterContentInit {\n    private _active = false;\n\n    @HostBinding('class') className = 'the-listbox-option';\n\n    @ContentChildren(TheListboxOptionDirective, { descendants: true }) public _options: QueryList<TheListboxOptionDirective>;\n\n    get hasChild() {\n        return this._options.length > 0;\n    }\n\n    get firstChild() {\n        return this._options.first;\n    }\n\n    constructor(\n        @Inject(THE_LISTBOX_PARENT_OPTION_TOKEN) @Optional() @SkipSelf() public parentOption: TheListboxOptionDirective,\n        @Inject(THE_LISTBOX_PARENT_GROUP_TOKEN) public parentGroup: TheListboxGroupDirective,\n        private elementRef: ElementRef<HTMLElement>\n    ) {}\n\n    ngOnInit(): void {}\n\n    ngAfterContentInit(): void {}\n\n    getGroups() {\n        const groups: TheListboxGroupDirective[] = [];\n        this._options.forEach(option => {\n            if (option.parentOption && option.parentOption === this && !groups.includes(option.parentGroup)) {\n                groups.push(option.parentGroup);\n            }\n        });\n        return groups;\n    }\n\n    setActive(active: boolean) {\n        this._active = active;\n        if (active) {\n            this.elementRef.nativeElement.classList.add('active');\n        } else {\n            this.elementRef.nativeElement.classList.remove('active');\n        }\n    }\n\n    getActive() {\n        return this._active;\n    }\n}\n\n@Directive({\n    selector: '[theListboxGroup]',\n    exportAs: 'theListboxGroup',\n    providers: [\n        {\n            provide: THE_LISTBOX_PARENT_GROUP_TOKEN,\n            useExisting: TheListboxGroupDirective\n        }\n    ]\n})\nexport class TheListboxGroupDirective implements OnInit, AfterContentInit {\n    @HostBinding('class') className = 'the-listbox-group';\n\n    options: TheListboxOptionDirective[] = [];\n\n    @ContentChildren(TheListboxOptionDirective, { descendants: true }) public _options: QueryList<TheListboxOptionDirective>;\n\n    /**\n     * 大于 1 表示水平分组，小于等于 1 表示垂直分组\n     */\n    @Input() horizontalColumn = 1;\n\n    constructor(\n        @Inject(THE_LISTBOX_PARENT_OPTION_TOKEN) @Optional() @SkipSelf() public parentOption: TheListboxOptionDirective,\n        @Inject(THE_LISTBOX_TOKEN) public theListBox: TheListboxDirective\n    ) {}\n\n    ngOnInit(): void {}\n\n    ngAfterContentInit(): void {\n        this.filterOptions();\n    }\n\n    filterOptions() {\n        this.options = this._options.filter(_option => {\n            if (_option.parentGroup && _option.parentGroup === this) {\n                return true;\n            } else {\n                return false;\n            }\n        });\n    }\n\n    getSiblingGroups() {\n        if (this.parentOption) {\n            return this.parentOption.getGroups();\n        } else {\n            return this.theListBox.groups;\n        }\n    }\n\n    getFirst() {\n        return this.options[0];\n    }\n\n    getLast() {\n        return this.options[this.options.length - 1];\n    }\n}\n\n@Directive({\n    selector: '[theListBox]',\n    exportAs: 'theListBox',\n    providers: [\n        {\n            provide: THE_LISTBOX_TOKEN,\n            useExisting: TheListboxDirective\n        }\n    ]\n})\nexport class TheListboxDirective implements OnInit, AfterContentInit, OnDestroy {\n    @HostBinding('class') className = 'the-listbox-container';\n\n    private _optionChangesSubscription: Subscription;\n\n    private _keyboardSubscription: Subscription;\n\n    public activeOption: TheListboxOptionDirective;\n\n    public groups: TheListboxGroupDirective[] = [];\n\n    @ContentChildren(TheListboxGroupDirective, { descendants: true }) protected _groups: QueryList<TheListboxGroupDirective>;\n\n    @Input() keyboardContainer: HTMLElement;\n\n    @Output() theActiveOptionChange = new EventEmitter<TheListboxChangeEvent>();\n\n    constructor(private ngZone: NgZone, private elementRef: ElementRef<HTMLElement>) {}\n\n    ngOnInit(): void {}\n\n    ngAfterContentInit(): void {\n        this.filterGroups();\n        if (this.groups.length > 0) {\n            this.setActiveItem(null, this.groups[0].getFirst(), 'init');\n        }\n        this._optionChangesSubscription = this._groups.changes.subscribe(() => {\n            this.filterGroups();\n            this.setActiveItem(null, this.groups[0].getFirst(), 'init');\n        });\n        this.ngZone.runOutsideAngular(() => {\n            this._keyboardSubscription = fromEvent<KeyboardEvent>(\n                this.keyboardContainer || this.elementRef.nativeElement,\n                'keydown'\n            ).subscribe(event => {\n                this.handleKeydown(event);\n            });\n        });\n    }\n\n    filterGroups() {\n        this.groups = this._groups.filter(group => {\n            if (!group.parentOption) {\n                return true;\n            } else {\n                return false;\n            }\n        });\n    }\n\n    handleKeydown(event: KeyboardEvent) {\n        const { keyCode } = event;\n        switch (keyCode) {\n            case DOWN_ARROW:\n                this.setNextLineActive();\n                event.preventDefault();\n                break;\n            case UP_ARROW:\n                this.setPreviousLineActive();\n                event.preventDefault();\n                break;\n            case RIGHT_ARROW:\n                this.setNextItemActive();\n                event.preventDefault();\n                break;\n            case LEFT_ARROW:\n                this.setPreviousItemActive();\n                event.preventDefault();\n                break;\n        }\n    }\n\n    /**\n     * ←\n     */\n    setPreviousItemActive() {\n        if (this.activeOption.parentOption) {\n            this.setActiveItem(this.activeOption, this.activeOption.parentOption, 'parent');\n        } else {\n            const groupOptions = this.activeOption.parentGroup.options;\n            let optionIndex = groupOptions.indexOf(this.activeOption);\n            let newOptionIndex = optionIndex - 1;\n            if (newOptionIndex >= 0) {\n                this.setActiveItem(this.activeOption, groupOptions[newOptionIndex], 'turn');\n            } else {\n                this.enterPreviousGroup();\n            }\n        }\n    }\n\n    /**\n     * ↓ 键\n     */\n    setNextLineActive() {\n        const groupOptions = this.activeOption.parentGroup.options;\n        let optionIndex = groupOptions.indexOf(this.activeOption);\n        let newOptionIndex = optionIndex + this.activeOption.parentGroup.horizontalColumn;\n        if (newOptionIndex <= groupOptions.length - 1) {\n            this.setActiveItem(this.activeOption, groupOptions[newOptionIndex], 'turn');\n        } else {\n            this.enterNextGroup();\n        }\n    }\n\n    /**\n     * → 键\n     */\n    setNextItemActive() {\n        if (this.activeOption.hasChild) {\n            this.setActiveItem(this.activeOption, this.activeOption.firstChild, 'child');\n        } else {\n            const groupOptions = this.activeOption.parentGroup.options;\n            let optionIndex = groupOptions.indexOf(this.activeOption);\n            let newOptionIndex = optionIndex + 1;\n            if (newOptionIndex <= groupOptions.length - 1) {\n                this.setActiveItem(this.activeOption, groupOptions[newOptionIndex], 'turn');\n            } else {\n                this.enterNextGroup();\n            }\n        }\n    }\n\n    /**\n     * ↑ 键\n     */\n    setPreviousLineActive() {\n        const groupOptions = this.activeOption.parentGroup.options;\n        let optionIndex = groupOptions.indexOf(this.activeOption);\n        let newOptionIndex = optionIndex - this.activeOption.parentGroup.horizontalColumn;\n        if (newOptionIndex >= 0) {\n            this.setActiveItem(this.activeOption, groupOptions[newOptionIndex], 'turn');\n        } else {\n            this.enterPreviousGroup();\n        }\n    }\n\n    enterNextGroup() {\n        const groups = this.activeOption.parentGroup.getSiblingGroups();\n        const groupIndex = groups.indexOf(this.activeOption.parentGroup);\n        let newGroupIndex = groupIndex + 1;\n        if (newGroupIndex > groups.length - 1) {\n            newGroupIndex = 0;\n        }\n        this.setActiveItem(this.activeOption, groups[newGroupIndex].getFirst(), 'turn');\n    }\n\n    enterPreviousGroup() {\n        const groups = this.activeOption.parentGroup.getSiblingGroups();\n        const groupIndex = groups.indexOf(this.activeOption.parentGroup);\n        let newGroupIndex = groupIndex - 1;\n        if (newGroupIndex < 0) {\n            newGroupIndex = groups.length - 1;\n        }\n        this.setActiveItem(this.activeOption, groups[newGroupIndex].getLast(), 'turn');\n    }\n\n    setActiveItem(previous: TheListboxOptionDirective | null, option: TheListboxOptionDirective, type: TheListboxChangeEventType) {\n        if (previous) {\n            previous.setActive(false);\n        }\n        option.setActive(true);\n        this.activeOption = option;\n        this.theActiveOptionChange.emit({ option, type });\n    }\n\n    ngOnDestroy(): void {\n        this._optionChangesSubscription.unsubscribe();\n        this._keyboardSubscription.unsubscribe();\n    }\n}\n\nexport interface TheListboxChangeEvent {\n    option: TheListboxOptionDirective;\n    type: TheListboxChangeEventType;\n}\n"]}
@@ -0,0 +1,5 @@
1
+ import { InjectionToken } from '@angular/core';
2
+ export const THE_LISTBOX_PARENT_OPTION_TOKEN = new InjectionToken('THE_LISTBOX_PARENT_OPTION_TOKEN');
3
+ export const THE_LISTBOX_PARENT_GROUP_TOKEN = new InjectionToken('THE_LISTBOX_PARENT_GROUP_TOKEN');
4
+ export const THE_LISTBOX_TOKEN = new InjectionToken('THE_LISTBOX_TOKEN');
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlzdGJveC50eXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvc3JjL2NvbXBvbmVudHMvbGlzdGJveC9saXN0Ym94LnR5cGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUvQyxNQUFNLENBQUMsTUFBTSwrQkFBK0IsR0FBRyxJQUFJLGNBQWMsQ0FBQyxpQ0FBaUMsQ0FBQyxDQUFDO0FBRXJHLE1BQU0sQ0FBQyxNQUFNLDhCQUE4QixHQUFHLElBQUksY0FBYyxDQUFDLGdDQUFnQyxDQUFDLENBQUM7QUFFbkcsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsSUFBSSxjQUFjLENBQUMsbUJBQW1CLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGlvblRva2VuIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCBjb25zdCBUSEVfTElTVEJPWF9QQVJFTlRfT1BUSU9OX1RPS0VOID0gbmV3IEluamVjdGlvblRva2VuKCdUSEVfTElTVEJPWF9QQVJFTlRfT1BUSU9OX1RPS0VOJyk7XG5cbmV4cG9ydCBjb25zdCBUSEVfTElTVEJPWF9QQVJFTlRfR1JPVVBfVE9LRU4gPSBuZXcgSW5qZWN0aW9uVG9rZW4oJ1RIRV9MSVNUQk9YX1BBUkVOVF9HUk9VUF9UT0tFTicpO1xuXG5leHBvcnQgY29uc3QgVEhFX0xJU1RCT1hfVE9LRU4gPSBuZXcgSW5qZWN0aW9uVG9rZW4oJ1RIRV9MSVNUQk9YX1RPS0VOJyk7XG5cbmV4cG9ydCB0eXBlIFRoZUxpc3Rib3hDaGFuZ2VFdmVudFR5cGUgPSAndHVybicgfCAnY2hpbGQnIHwgJ3BhcmVudCcgfCAnaW5pdCc7XG4iXX0=
@@ -0,0 +1,102 @@
1
+ import { Component, Input, HostBinding } from '@angular/core';
2
+ import { mixinUnsubscribe, MixinBase } from 'ngx-tethys/core';
3
+ import { Editor, Node } from 'slate';
4
+ import { AngularEditor } from 'slate-angular';
5
+ import { buildPluginMenu, buildPluginMenuItemMap } from '../../core/utils/plugin-menu';
6
+ import { DefaultPluginMenu, ThePluginMenuItemType } from '../../constants/plugin-menu';
7
+ import { ThePluginMenu } from '../../interfaces/plugins/plugin-menu';
8
+ import { getPluginOptions } from '../../core';
9
+ import { PluginKeys } from '../../interfaces';
10
+ import { QuickInsertEditor } from '../../plugins/public-api';
11
+ import * as i0 from "@angular/core";
12
+ import * as i1 from "@angular/common";
13
+ import * as i2 from "ngx-tethys/icon";
14
+ import * as i3 from "ngx-tethys/tooltip";
15
+ import * as i4 from "ngx-tethys/action";
16
+ import * as i5 from "ngx-tethys/divider";
17
+ import * as i6 from "ngx-tethys/dropdown";
18
+ import * as i7 from "ngx-tethys/empty";
19
+ import * as i8 from "../table-select/table-select.component";
20
+ export class ThePluginMenuComponent extends mixinUnsubscribe(MixinBase) {
21
+ constructor(elementRef, cdr) {
22
+ super();
23
+ this.elementRef = elementRef;
24
+ this.cdr = cdr;
25
+ this.ThePluginMenu = ThePluginMenu;
26
+ this.groupMenu = [];
27
+ this.iconMenu = [];
28
+ this.ThePluginMenuItemType = ThePluginMenuItemType;
29
+ this.thyMessage = '暂无数据';
30
+ this.searchGroup = {
31
+ groupName: '搜索结果'
32
+ };
33
+ this.expandPopoverOptions = {
34
+ placement: 'rightTop',
35
+ width: '266px'
36
+ };
37
+ this.containerClassName = `the-plugin-menu-container`;
38
+ this.removeKeywords = () => {
39
+ const hotkey = getPluginOptions(this.editor, PluginKeys.quickInsert)?.hotkey;
40
+ const node = Node.get(this.editor, this.editor.selection.anchor.path);
41
+ if (node && node.text.includes(hotkey)) {
42
+ Editor.deleteBackward(this.editor, { unit: 'block' });
43
+ }
44
+ };
45
+ }
46
+ ngOnInit() {
47
+ this.editorElement = AngularEditor.toDOMNode(this.editor, this.editor);
48
+ let currentMenu = DefaultPluginMenu;
49
+ const menuItemsMap = buildPluginMenuItemMap(this.editor);
50
+ this.pluginMenu = this.editor.options.menu ? this.editor.options.menu : buildPluginMenu(menuItemsMap, currentMenu);
51
+ this.buildMenus();
52
+ }
53
+ buildMenus() {
54
+ if (this.keyWords) {
55
+ this.iconMenu = [];
56
+ this.groupMenu = this.pluginMenu.filter((item) => {
57
+ return item?.keywords && item?.keywords.includes(this.keyWords);
58
+ });
59
+ if (this.groupMenu.length > 0) {
60
+ this.groupMenu.unshift(this.searchGroup);
61
+ }
62
+ }
63
+ else {
64
+ this.iconMenu = this.pluginMenu.filter((item) => {
65
+ return item?.type === ThePluginMenuItemType.icon;
66
+ });
67
+ this.groupMenu = this.pluginMenu.filter((item) => {
68
+ return item?.type !== ThePluginMenuItemType.icon;
69
+ });
70
+ }
71
+ this.cdr.detectChanges();
72
+ }
73
+ executeItem(event, menuItem) {
74
+ event.preventDefault();
75
+ event.stopPropagation();
76
+ this.removeKeywords();
77
+ const toolbarItem = this.pluginMenu.find((item) => item.key === menuItem.key);
78
+ if (toolbarItem.execute) {
79
+ toolbarItem.execute(this.editor);
80
+ }
81
+ QuickInsertEditor.closeMenu(this.editor);
82
+ }
83
+ updateKeywords(keywords) {
84
+ this.keyWords = keywords.toLowerCase().trim();
85
+ this.buildMenus();
86
+ }
87
+ ngOnDestroy() {
88
+ super.ngOnDestroy();
89
+ }
90
+ }
91
+ ThePluginMenuComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ThePluginMenuComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
92
+ ThePluginMenuComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: ThePluginMenuComponent, selector: "the-plugin-menu", inputs: { editor: "editor" }, host: { properties: { "class": "this.containerClassName" } }, usesInheritance: true, ngImport: i0, template: "<div *ngIf=\"groupMenu.length > 0; else thyEmpty\" class=\"thy-dropdown-menu py-2\">\n <div class=\"icon-menu d-flex px-5 py-1\">\n <ng-container *ngFor=\"let item of iconMenu\">\n <a\n *ngIf=\"item.type === ThePluginMenuItemType.icon\"\n href=\"javascript:;\"\n class=\"mt-2\"\n thyAction\n [thyActionIcon]=\"item.icon\"\n [thyTooltip]=\"item.name\"\n (mousedown)=\"executeItem($event, item)\"\n ></a>\n </ng-container>\n </div>\n\n <thy-divider *ngIf=\"this.iconMenu?.length\" class=\"my-2\"></thy-divider>\n\n <ng-container *ngFor=\"let item of groupMenu\">\n <ng-container *ngIf=\"ThePluginMenu.isMenuItem(item) && !item.isExpanded\">\n <div thyDropdownMenuItem class=\"insert-menu-item mb-1 py-0\" (mousedown)=\"executeItem($event, item)\">\n <div class=\"menu-icon mr-2\">\n <thy-icon [thyIconName]=\"item.menuIcon\"></thy-icon>\n </div>\n <div class=\"menu-content d-flex align-items-center\">\n <div class=\"menu-item-title w-100\">\n <span *ngIf=\"!item?.isExpanded\" class=\"menu-item-display-key font-size-sm text-placeholder\">\n {{ item.displayKey }}</span\n >\n {{ item.name }}\n </div>\n <div class=\"text-muted font-size-sm\">{{ item.description }}</div>\n </div>\n </div>\n </ng-container>\n <ng-container *ngIf=\"ThePluginMenu.isMenuItem(item) && item.isExpanded\" #hasExpanded>\n <div\n [thyDropdown]=\"expand\"\n thyTrigger=\"hover\"\n thyDropdownMenuItem\n [thyPopoverOptions]=\"expandPopoverOptions\"\n class=\"insert-menu-item mb-1 py-0\"\n (mousedown)=\"executeItem($event, item)\"\n >\n <div class=\"menu-icon mr-2\">\n <thy-icon [thyIconName]=\"item.menuIcon\"></thy-icon>\n </div>\n <div class=\"menu-content d-flex align-items-center\">\n <div class=\"menu-item-title w-100\">\n <span *ngIf=\"!item?.isExpanded\" class=\"menu-item-display-key font-size-sm text-placeholder\">\n {{ item.displayKey }}</span\n >\n {{ item.name }}\n </div>\n <div class=\"text-muted font-size-sm\">{{ item.description }}</div>\n </div>\n <div *ngIf=\"item?.isExpanded\">\n <thy-icon class=\"text-muted\" thyIconName=\"angle-right\"></thy-icon>\n </div>\n </div>\n <thy-dropdown-menu class=\"expand-menu\" #expand>\n <div class=\"the-plugin-menu-container\">\n <div *ngFor=\"let child of item.children\" thyDropdownMenuItem class=\"insert-menu-item mb-1 py-0\">\n <div class=\"menu-icon mr-2\">\n <thy-icon [thyIconName]=\"child.menuIcon\"></thy-icon>\n </div>\n <div class=\"menu-content d-flex align-items-center\">\n <div class=\"menu-item-title w-100\">\n <span class=\"menu-item-display-key font-size-sm text-placeholder\"> {{ child.displayKey }}</span>\n {{ child.name }}\n </div>\n <div class=\"text-muted font-size-sm\">{{ child.description }}</div>\n </div>\n </div>\n </div>\n <table-select\n *ngIf=\"item.key === 'table'\"\n class=\"plugin-menu-table the-table-selector-panel\"\n [editor]=\"editor\"\n [beforeInsert]=\"removeKeywords\"\n ></table-select>\n </thy-dropdown-menu>\n </ng-container>\n\n <ng-container *ngIf=\"!ThePluginMenu.isMenuItem(item)\" #menuGroup>\n <thy-dropdown-menu-group class=\"font-size-sm\" [thyTitle]=\"item.groupName\"></thy-dropdown-menu-group>\n </ng-container>\n </ng-container>\n</div>\n\n<ng-template #thyEmpty>\n <div class=\"empty d-flex align-items-center justify-content-center\">\n <thy-empty [thyMessage]=\"thyMessage\"></thy-empty>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.ThyIconComponent, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "directive", type: i3.ThyTooltipDirective, selector: "[thyTooltip],[thy-tooltip]", inputs: ["thyTooltip", "thyTooltipPlacement", "thyTooltipClass", "thyTooltipShowDelay", "thyTooltipHideDelay", "thyTooltipTrigger", "thyTooltipDisabled", "thyTooltipTemplateContext", "thyTooltipOffset", "thyTooltipPin"], exportAs: ["thyTooltip"] }, { kind: "component", type: i4.ThyActionComponent, selector: "thy-action, [thyAction]", inputs: ["thyType", "thyIcon", "thyActionIcon", "thyActive", "thyActionActive", "thyTheme", "thyHoverIcon", "thyDisabled"] }, { kind: "component", type: i5.ThyDividerComponent, selector: "thy-divider", inputs: ["thyVertical", "thyStyle", "thyColor", "thyText", "thyTextDirection", "thyDeeper"] }, { kind: "directive", type: i6.ThyDropdownDirective, selector: "[thyDropdown]", inputs: ["thyDropdownMenu", "thyDropdown", "thyTrigger", "thyActiveClass", "thyPopoverOptions"], outputs: ["thyActiveChange"] }, { kind: "component", type: i6.ThyDropdownMenuComponent, selector: "thy-dropdown-menu", inputs: ["thyWidth"] }, { kind: "component", type: i6.ThyDropdownMenuGroupComponent, selector: "thy-dropdown-menu-group", inputs: ["thyTitle"] }, { kind: "directive", type: i6.ThyDropdownMenuItemDirective, selector: "[thyDropdownMenuItem]", inputs: ["thyType", "thyDisabled"] }, { kind: "component", type: i7.ThyEmptyComponent, selector: "thy-empty", inputs: ["thyMessage", "thyTranslationKey", "thyTranslationValues", "thyEntityName", "thyEntityNameTranslateKey", "thyIconName", "thySize", "thyMarginTop", "thyTopAuto", "thyContainer", "thyImageUrl", "thyImageLoading", "thyImageFetchPriority", "thyDescription"] }, { kind: "component", type: i8.TheTableSelectComponent, selector: "table-select", inputs: ["optionsParam", "editor", "beforeInsert"] }] });
93
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ThePluginMenuComponent, decorators: [{
94
+ type: Component,
95
+ args: [{ selector: 'the-plugin-menu', template: "<div *ngIf=\"groupMenu.length > 0; else thyEmpty\" class=\"thy-dropdown-menu py-2\">\n <div class=\"icon-menu d-flex px-5 py-1\">\n <ng-container *ngFor=\"let item of iconMenu\">\n <a\n *ngIf=\"item.type === ThePluginMenuItemType.icon\"\n href=\"javascript:;\"\n class=\"mt-2\"\n thyAction\n [thyActionIcon]=\"item.icon\"\n [thyTooltip]=\"item.name\"\n (mousedown)=\"executeItem($event, item)\"\n ></a>\n </ng-container>\n </div>\n\n <thy-divider *ngIf=\"this.iconMenu?.length\" class=\"my-2\"></thy-divider>\n\n <ng-container *ngFor=\"let item of groupMenu\">\n <ng-container *ngIf=\"ThePluginMenu.isMenuItem(item) && !item.isExpanded\">\n <div thyDropdownMenuItem class=\"insert-menu-item mb-1 py-0\" (mousedown)=\"executeItem($event, item)\">\n <div class=\"menu-icon mr-2\">\n <thy-icon [thyIconName]=\"item.menuIcon\"></thy-icon>\n </div>\n <div class=\"menu-content d-flex align-items-center\">\n <div class=\"menu-item-title w-100\">\n <span *ngIf=\"!item?.isExpanded\" class=\"menu-item-display-key font-size-sm text-placeholder\">\n {{ item.displayKey }}</span\n >\n {{ item.name }}\n </div>\n <div class=\"text-muted font-size-sm\">{{ item.description }}</div>\n </div>\n </div>\n </ng-container>\n <ng-container *ngIf=\"ThePluginMenu.isMenuItem(item) && item.isExpanded\" #hasExpanded>\n <div\n [thyDropdown]=\"expand\"\n thyTrigger=\"hover\"\n thyDropdownMenuItem\n [thyPopoverOptions]=\"expandPopoverOptions\"\n class=\"insert-menu-item mb-1 py-0\"\n (mousedown)=\"executeItem($event, item)\"\n >\n <div class=\"menu-icon mr-2\">\n <thy-icon [thyIconName]=\"item.menuIcon\"></thy-icon>\n </div>\n <div class=\"menu-content d-flex align-items-center\">\n <div class=\"menu-item-title w-100\">\n <span *ngIf=\"!item?.isExpanded\" class=\"menu-item-display-key font-size-sm text-placeholder\">\n {{ item.displayKey }}</span\n >\n {{ item.name }}\n </div>\n <div class=\"text-muted font-size-sm\">{{ item.description }}</div>\n </div>\n <div *ngIf=\"item?.isExpanded\">\n <thy-icon class=\"text-muted\" thyIconName=\"angle-right\"></thy-icon>\n </div>\n </div>\n <thy-dropdown-menu class=\"expand-menu\" #expand>\n <div class=\"the-plugin-menu-container\">\n <div *ngFor=\"let child of item.children\" thyDropdownMenuItem class=\"insert-menu-item mb-1 py-0\">\n <div class=\"menu-icon mr-2\">\n <thy-icon [thyIconName]=\"child.menuIcon\"></thy-icon>\n </div>\n <div class=\"menu-content d-flex align-items-center\">\n <div class=\"menu-item-title w-100\">\n <span class=\"menu-item-display-key font-size-sm text-placeholder\"> {{ child.displayKey }}</span>\n {{ child.name }}\n </div>\n <div class=\"text-muted font-size-sm\">{{ child.description }}</div>\n </div>\n </div>\n </div>\n <table-select\n *ngIf=\"item.key === 'table'\"\n class=\"plugin-menu-table the-table-selector-panel\"\n [editor]=\"editor\"\n [beforeInsert]=\"removeKeywords\"\n ></table-select>\n </thy-dropdown-menu>\n </ng-container>\n\n <ng-container *ngIf=\"!ThePluginMenu.isMenuItem(item)\" #menuGroup>\n <thy-dropdown-menu-group class=\"font-size-sm\" [thyTitle]=\"item.groupName\"></thy-dropdown-menu-group>\n </ng-container>\n </ng-container>\n</div>\n\n<ng-template #thyEmpty>\n <div class=\"empty d-flex align-items-center justify-content-center\">\n <thy-empty [thyMessage]=\"thyMessage\"></thy-empty>\n </div>\n</ng-template>\n" }]
96
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { containerClassName: [{
97
+ type: HostBinding,
98
+ args: ['class']
99
+ }], editor: [{
100
+ type: Input
101
+ }] } });
102
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"plugin-menu.component.js","sourceRoot":"","sources":["../../../../../packages/src/components/plugin-menu/plugin-menu.component.ts","../../../../../packages/src/components/plugin-menu/plugin-menu.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, OnDestroy, ElementRef, ChangeDetectorRef, HostBinding } from '@angular/core';\nimport { mixinUnsubscribe, MixinBase } from 'ngx-tethys/core';\nimport { Editor, Node, Text } from 'slate';\nimport { AngularEditor } from 'slate-angular';\nimport { buildPluginMenu, buildPluginMenuItemMap } from '../../core/utils/plugin-menu';\nimport { DefaultPluginMenu, ThePluginMenuItemType } from '../../constants/plugin-menu';\nimport { ThePluginMenu, ThePluginMenuGroup, ThePluginMenuItem, ThePluginMenuItemConfig } from '../../interfaces/plugins/plugin-menu';\nimport { getPluginOptions } from '../../core';\nimport { QuickInsertPluginOptions } from '../../plugins/quick-insert/quick-insert.plugin';\nimport { PluginKeys } from '../../interfaces';\nimport { QuickInsertEditor } from '../../plugins/public-api';\n\n@Component({\n    selector: 'the-plugin-menu',\n    templateUrl: 'plugin-menu.component.html'\n})\nexport class ThePluginMenuComponent extends mixinUnsubscribe(MixinBase) implements OnInit, OnDestroy {\n    editorElement: HTMLElement;\n\n    ThePluginMenu = ThePluginMenu;\n\n    pluginMenu: ThePluginMenu;\n\n    groupMenu: ThePluginMenu = [];\n\n    iconMenu: ThePluginMenu = [];\n\n    ThePluginMenuItemType = ThePluginMenuItemType;\n\n    keyWords: string;\n\n    thyMessage = '暂无数据';\n\n    searchGroup: ThePluginMenuGroup = {\n        groupName: '搜索结果'\n    };\n\n    expandPopoverOptions = {\n        placement: 'rightTop',\n        width: '266px'\n    };\n\n    @HostBinding('class') containerClassName = `the-plugin-menu-container`;\n\n    @Input() editor: Editor;\n\n    constructor(public elementRef: ElementRef, public cdr: ChangeDetectorRef) {\n        super();\n    }\n\n    ngOnInit() {\n        this.editorElement = AngularEditor.toDOMNode(this.editor, this.editor);\n        let currentMenu = DefaultPluginMenu;\n        const menuItemsMap = buildPluginMenuItemMap(this.editor);\n        this.pluginMenu = this.editor.options.menu ? this.editor.options.menu : buildPluginMenu(menuItemsMap, currentMenu);\n        this.buildMenus();\n    }\n\n    buildMenus() {\n        if (this.keyWords) {\n            this.iconMenu = [];\n            this.groupMenu = this.pluginMenu.filter((item: any) => {\n                return item?.keywords && item?.keywords.includes(this.keyWords);\n            });\n\n            if (this.groupMenu.length > 0) {\n                this.groupMenu.unshift(this.searchGroup);\n            }\n        } else {\n            this.iconMenu = this.pluginMenu.filter((item: any) => {\n                return item?.type === ThePluginMenuItemType.icon;\n            });\n            this.groupMenu = this.pluginMenu.filter((item: any) => {\n                return item?.type !== ThePluginMenuItemType.icon;\n            });\n        }\n\n        this.cdr.detectChanges();\n    }\n\n    executeItem(event: MouseEvent, menuItem: ThePluginMenuItem) {\n        event.preventDefault();\n        event.stopPropagation();\n        this.removeKeywords();\n        const toolbarItem: any = this.pluginMenu.find((item: ThePluginMenuItem) => item.key === menuItem.key);\n        if (toolbarItem.execute) {\n            toolbarItem.execute(this.editor);\n        }\n        QuickInsertEditor.closeMenu(this.editor);\n    }\n\n    removeKeywords = () => {\n        const hotkey = getPluginOptions<QuickInsertPluginOptions>(this.editor, PluginKeys.quickInsert)?.hotkey;\n        const node = Node.get(this.editor, this.editor.selection.anchor.path) as Text;\n        if (node && node.text.includes(hotkey)) {\n            Editor.deleteBackward(this.editor, { unit: 'block' });\n        }\n    };\n\n    updateKeywords(keywords: string) {\n        this.keyWords = keywords.toLowerCase().trim();\n        this.buildMenus();\n    }\n\n    ngOnDestroy() {\n        super.ngOnDestroy();\n    }\n}\n","<div *ngIf=\"groupMenu.length > 0; else thyEmpty\" class=\"thy-dropdown-menu py-2\">\n    <div class=\"icon-menu d-flex px-5 py-1\">\n        <ng-container *ngFor=\"let item of iconMenu\">\n            <a\n                *ngIf=\"item.type === ThePluginMenuItemType.icon\"\n                href=\"javascript:;\"\n                class=\"mt-2\"\n                thyAction\n                [thyActionIcon]=\"item.icon\"\n                [thyTooltip]=\"item.name\"\n                (mousedown)=\"executeItem($event, item)\"\n            ></a>\n        </ng-container>\n    </div>\n\n    <thy-divider *ngIf=\"this.iconMenu?.length\" class=\"my-2\"></thy-divider>\n\n    <ng-container *ngFor=\"let item of groupMenu\">\n        <ng-container *ngIf=\"ThePluginMenu.isMenuItem(item) && !item.isExpanded\">\n            <div thyDropdownMenuItem class=\"insert-menu-item mb-1 py-0\" (mousedown)=\"executeItem($event, item)\">\n                <div class=\"menu-icon mr-2\">\n                    <thy-icon [thyIconName]=\"item.menuIcon\"></thy-icon>\n                </div>\n                <div class=\"menu-content d-flex align-items-center\">\n                    <div class=\"menu-item-title w-100\">\n                        <span *ngIf=\"!item?.isExpanded\" class=\"menu-item-display-key font-size-sm text-placeholder\">\n                            {{ item.displayKey }}</span\n                        >\n                        {{ item.name }}\n                    </div>\n                    <div class=\"text-muted font-size-sm\">{{ item.description }}</div>\n                </div>\n            </div>\n        </ng-container>\n        <ng-container *ngIf=\"ThePluginMenu.isMenuItem(item) && item.isExpanded\" #hasExpanded>\n            <div\n                [thyDropdown]=\"expand\"\n                thyTrigger=\"hover\"\n                thyDropdownMenuItem\n                [thyPopoverOptions]=\"expandPopoverOptions\"\n                class=\"insert-menu-item mb-1 py-0\"\n                (mousedown)=\"executeItem($event, item)\"\n            >\n                <div class=\"menu-icon mr-2\">\n                    <thy-icon [thyIconName]=\"item.menuIcon\"></thy-icon>\n                </div>\n                <div class=\"menu-content d-flex align-items-center\">\n                    <div class=\"menu-item-title w-100\">\n                        <span *ngIf=\"!item?.isExpanded\" class=\"menu-item-display-key font-size-sm text-placeholder\">\n                            {{ item.displayKey }}</span\n                        >\n                        {{ item.name }}\n                    </div>\n                    <div class=\"text-muted font-size-sm\">{{ item.description }}</div>\n                </div>\n                <div *ngIf=\"item?.isExpanded\">\n                    <thy-icon class=\"text-muted\" thyIconName=\"angle-right\"></thy-icon>\n                </div>\n            </div>\n            <thy-dropdown-menu class=\"expand-menu\" #expand>\n                <div class=\"the-plugin-menu-container\">\n                    <div *ngFor=\"let child of item.children\" thyDropdownMenuItem class=\"insert-menu-item mb-1 py-0\">\n                        <div class=\"menu-icon mr-2\">\n                            <thy-icon [thyIconName]=\"child.menuIcon\"></thy-icon>\n                        </div>\n                        <div class=\"menu-content d-flex align-items-center\">\n                            <div class=\"menu-item-title w-100\">\n                                <span class=\"menu-item-display-key font-size-sm text-placeholder\"> {{ child.displayKey }}</span>\n                                {{ child.name }}\n                            </div>\n                            <div class=\"text-muted font-size-sm\">{{ child.description }}</div>\n                        </div>\n                    </div>\n                </div>\n                <table-select\n                    *ngIf=\"item.key === 'table'\"\n                    class=\"plugin-menu-table the-table-selector-panel\"\n                    [editor]=\"editor\"\n                    [beforeInsert]=\"removeKeywords\"\n                ></table-select>\n            </thy-dropdown-menu>\n        </ng-container>\n\n        <ng-container *ngIf=\"!ThePluginMenu.isMenuItem(item)\" #menuGroup>\n            <thy-dropdown-menu-group class=\"font-size-sm\" [thyTitle]=\"item.groupName\"></thy-dropdown-menu-group>\n        </ng-container>\n    </ng-container>\n</div>\n\n<ng-template #thyEmpty>\n    <div class=\"empty d-flex align-items-center justify-content-center\">\n        <thy-empty [thyMessage]=\"thyMessage\"></thy-empty>\n    </div>\n</ng-template>\n"]}
@@ -1,4 +1,4 @@
1
- import { Component, Input, HostListener } from '@angular/core';
1
+ import { Component, Input } from '@angular/core';
2
2
  import { insertTable } from '../../plugins/table/transforms/insert-table';
3
3
  import { TableOptions } from '../../plugins/table/table.types';
4
4
  import * as i0 from "@angular/core";
@@ -7,15 +7,11 @@ import * as i2 from "@angular/common";
7
7
  export class TheTableSelectComponent {
8
8
  constructor(popoverRef) {
9
9
  this.popoverRef = popoverRef;
10
+ this.beforeInsert = () => { };
10
11
  this.tableData = new Array(10);
11
12
  this.maxRowIndex = -1;
12
13
  this.maxColIndex = -1;
13
14
  }
14
- handleDocumentMouseDown(event) {
15
- if (!document.querySelector('.table-selector-container').contains(event.target)) {
16
- this.popoverRef.close();
17
- }
18
- }
19
15
  ngOnInit() { }
20
16
  onSelectCells(rowIndex, colIndex) {
21
17
  this.maxRowIndex = rowIndex;
@@ -24,6 +20,7 @@ export class TheTableSelectComponent {
24
20
  executeTable(event) {
25
21
  event.preventDefault();
26
22
  event.stopPropagation();
23
+ this.beforeInsert();
27
24
  const opts = new TableOptions(this.optionsParam);
28
25
  insertTable(opts, this.editor, this.maxRowIndex + 1, this.maxColIndex + 1);
29
26
  if (this.popoverRef) {
@@ -34,7 +31,7 @@ export class TheTableSelectComponent {
34
31
  }
35
32
  }
36
33
  TheTableSelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: TheTableSelectComponent, deps: [{ token: i1.ThyPopoverRef }], target: i0.ɵɵFactoryTarget.Component });
37
- TheTableSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: TheTableSelectComponent, selector: "table-select", inputs: { optionsParam: "optionsParam", editor: "editor" }, host: { listeners: { "document: mousedown": "handleDocumentMouseDown($event)" } }, ngImport: i0, template: "<div class=\"table-selector-container\">\n <div *ngFor=\"let item of tableData; let rowIndex = index\" class=\"selector-row\" (mousedown)=\"executeTable($event)\">\n <span\n *ngFor=\"let item of tableData; let colIndex = index\"\n [ngClass]=\"{ 'active-cell': rowIndex <= maxRowIndex && colIndex <= maxColIndex, 'selector-cell': true }\"\n (mouseenter)=\"onSelectCells(rowIndex, colIndex)\"\n >\n </span>\n </div>\n <span class=\"selector-text\">{{ maxRowIndex + 1 }} x {{ maxColIndex + 1 }}</span>\n</div>\n", dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
34
+ TheTableSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: TheTableSelectComponent, selector: "table-select", inputs: { optionsParam: "optionsParam", editor: "editor", beforeInsert: "beforeInsert" }, ngImport: i0, template: "<div class=\"table-selector-container\">\n <div *ngFor=\"let item of tableData; let rowIndex = index\" class=\"selector-row\" (mousedown)=\"executeTable($event)\">\n <span\n *ngFor=\"let item of tableData; let colIndex = index\"\n [ngClass]=\"{ 'active-cell': rowIndex <= maxRowIndex && colIndex <= maxColIndex, 'selector-cell': true }\"\n (mouseenter)=\"onSelectCells(rowIndex, colIndex)\"\n >\n </span>\n </div>\n <span class=\"selector-text\">{{ maxRowIndex + 1 }} x {{ maxColIndex + 1 }}</span>\n</div>\n", dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] });
38
35
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: TheTableSelectComponent, decorators: [{
39
36
  type: Component,
40
37
  args: [{ selector: 'table-select', template: "<div class=\"table-selector-container\">\n <div *ngFor=\"let item of tableData; let rowIndex = index\" class=\"selector-row\" (mousedown)=\"executeTable($event)\">\n <span\n *ngFor=\"let item of tableData; let colIndex = index\"\n [ngClass]=\"{ 'active-cell': rowIndex <= maxRowIndex && colIndex <= maxColIndex, 'selector-cell': true }\"\n (mouseenter)=\"onSelectCells(rowIndex, colIndex)\"\n >\n </span>\n </div>\n <span class=\"selector-text\">{{ maxRowIndex + 1 }} x {{ maxColIndex + 1 }}</span>\n</div>\n" }]
@@ -42,8 +39,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
42
39
  type: Input
43
40
  }], editor: [{
44
41
  type: Input
45
- }], handleDocumentMouseDown: [{
46
- type: HostListener,
47
- args: ['document: mousedown', ['$event']]
42
+ }], beforeInsert: [{
43
+ type: Input
48
44
  }] } });
49
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtc2VsZWN0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3NyYy9jb21wb25lbnRzL3RhYmxlLXNlbGVjdC90YWJsZS1zZWxlY3QuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvc3JjL2NvbXBvbmVudHMvdGFibGUtc2VsZWN0L3RhYmxlLXNlbGVjdC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxZQUFZLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFdkUsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLDZDQUE2QyxDQUFDO0FBRTFFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQzs7OztBQU0vRCxNQUFNLE9BQU8sdUJBQXVCO0lBZWhDLFlBQW9CLFVBQWtEO1FBQWxELGVBQVUsR0FBVixVQUFVLENBQXdDO1FBWHRFLGNBQVMsR0FBRyxJQUFJLEtBQUssQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUMxQixnQkFBVyxHQUFHLENBQUMsQ0FBQyxDQUFDO1FBQ2pCLGdCQUFXLEdBQUcsQ0FBQyxDQUFDLENBQUM7SUFTd0QsQ0FBQztJQU4xRSx1QkFBdUIsQ0FBQyxLQUFpQjtRQUNyQyxJQUFJLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQywyQkFBMkIsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsTUFBcUIsQ0FBQyxFQUFFO1lBQzVGLElBQUksQ0FBQyxVQUFVLENBQUMsS0FBSyxFQUFFLENBQUM7U0FDM0I7SUFDTCxDQUFDO0lBSUQsUUFBUSxLQUFVLENBQUM7SUFFbkIsYUFBYSxDQUFDLFFBQVEsRUFBRSxRQUFRO1FBQzVCLElBQUksQ0FBQyxXQUFXLEdBQUcsUUFBUSxDQUFDO1FBQzVCLElBQUksQ0FBQyxXQUFXLEdBQUcsUUFBUSxDQUFDO0lBQ2hDLENBQUM7SUFFRCxZQUFZLENBQUMsS0FBaUI7UUFDMUIsS0FBSyxDQUFDLGNBQWMsRUFBRSxDQUFDO1FBQ3ZCLEtBQUssQ0FBQyxlQUFlLEVBQUUsQ0FBQztRQUN4QixNQUFNLElBQUksR0FBRyxJQUFJLFlBQVksQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUM7UUFDakQsV0FBVyxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxXQUFXLEdBQUcsQ0FBQyxFQUFFLElBQUksQ0FBQyxXQUFXLEdBQUcsQ0FBQyxDQUFDLENBQUM7UUFDM0UsSUFBSSxJQUFJLENBQUMsVUFBVSxFQUFFO1lBQ2pCLElBQUksQ0FBQyxVQUFVLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDeEIsSUFBSSxDQUFDLFdBQVcsR0FBRyxDQUFDLENBQUMsQ0FBQztZQUN0QixJQUFJLENBQUMsV0FBVyxHQUFHLENBQUMsQ0FBQyxDQUFDO1NBQ3pCO0lBQ0wsQ0FBQzs7b0hBbENRLHVCQUF1Qjt3R0FBdkIsdUJBQXVCLG1NQ1ZwQyw2akJBV0E7MkZERGEsdUJBQXVCO2tCQUpuQyxTQUFTOytCQUNJLGNBQWM7b0dBSWYsWUFBWTtzQkFBcEIsS0FBSztnQkFDRyxNQUFNO3NCQUFkLEtBQUs7Z0JBT04sdUJBQXVCO3NCQUR0QixZQUFZO3VCQUFDLHFCQUFxQixFQUFFLENBQUMsUUFBUSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT25Jbml0LCBIb3N0TGlzdGVuZXIgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFRoeVBvcG92ZXJSZWYgfSBmcm9tICduZ3gtdGV0aHlzL3BvcG92ZXInO1xuaW1wb3J0IHsgaW5zZXJ0VGFibGUgfSBmcm9tICcuLi8uLi9wbHVnaW5zL3RhYmxlL3RyYW5zZm9ybXMvaW5zZXJ0LXRhYmxlJztcbmltcG9ydCB7IFRoZUVkaXRvciB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMnO1xuaW1wb3J0IHsgVGFibGVPcHRpb25zIH0gZnJvbSAnLi4vLi4vcGx1Z2lucy90YWJsZS90YWJsZS50eXBlcyc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAndGFibGUtc2VsZWN0JyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vdGFibGUtc2VsZWN0LmNvbXBvbmVudC5odG1sJ1xufSlcbmV4cG9ydCBjbGFzcyBUaGVUYWJsZVNlbGVjdENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gICAgQElucHV0KCkgb3B0aW9uc1BhcmFtOiBUYWJsZU9wdGlvbnM7XG4gICAgQElucHV0KCkgZWRpdG9yOiBUaGVFZGl0b3I7XG5cbiAgICB0YWJsZURhdGEgPSBuZXcgQXJyYXkoMTApO1xuICAgIG1heFJvd0luZGV4ID0gLTE7XG4gICAgbWF4Q29sSW5kZXggPSAtMTtcblxuICAgIEBIb3N0TGlzdGVuZXIoJ2RvY3VtZW50OiBtb3VzZWRvd24nLCBbJyRldmVudCddKVxuICAgIGhhbmRsZURvY3VtZW50TW91c2VEb3duKGV2ZW50OiBNb3VzZUV2ZW50KSB7XG4gICAgICAgIGlmICghZG9jdW1lbnQucXVlcnlTZWxlY3RvcignLnRhYmxlLXNlbGVjdG9yLWNvbnRhaW5lcicpLmNvbnRhaW5zKGV2ZW50LnRhcmdldCBhcyBIVE1MRWxlbWVudCkpIHtcbiAgICAgICAgICAgIHRoaXMucG9wb3ZlclJlZi5jbG9zZSgpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBwb3BvdmVyUmVmOiBUaHlQb3BvdmVyUmVmPFRoZVRhYmxlU2VsZWN0Q29tcG9uZW50Pikge31cblxuICAgIG5nT25Jbml0KCk6IHZvaWQge31cblxuICAgIG9uU2VsZWN0Q2VsbHMocm93SW5kZXgsIGNvbEluZGV4KSB7XG4gICAgICAgIHRoaXMubWF4Um93SW5kZXggPSByb3dJbmRleDtcbiAgICAgICAgdGhpcy5tYXhDb2xJbmRleCA9IGNvbEluZGV4O1xuICAgIH1cblxuICAgIGV4ZWN1dGVUYWJsZShldmVudDogTW91c2VFdmVudCkge1xuICAgICAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICAgICBldmVudC5zdG9wUHJvcGFnYXRpb24oKTtcbiAgICAgICAgY29uc3Qgb3B0cyA9IG5ldyBUYWJsZU9wdGlvbnModGhpcy5vcHRpb25zUGFyYW0pO1xuICAgICAgICBpbnNlcnRUYWJsZShvcHRzLCB0aGlzLmVkaXRvciwgdGhpcy5tYXhSb3dJbmRleCArIDEsIHRoaXMubWF4Q29sSW5kZXggKyAxKTtcbiAgICAgICAgaWYgKHRoaXMucG9wb3ZlclJlZikge1xuICAgICAgICAgICAgdGhpcy5wb3BvdmVyUmVmLmNsb3NlKCk7XG4gICAgICAgICAgICB0aGlzLm1heENvbEluZGV4ID0gLTE7XG4gICAgICAgICAgICB0aGlzLm1heFJvd0luZGV4ID0gLTE7XG4gICAgICAgIH1cbiAgICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwidGFibGUtc2VsZWN0b3ItY29udGFpbmVyXCI+XG4gICAgPGRpdiAqbmdGb3I9XCJsZXQgaXRlbSBvZiB0YWJsZURhdGE7IGxldCByb3dJbmRleCA9IGluZGV4XCIgY2xhc3M9XCJzZWxlY3Rvci1yb3dcIiAobW91c2Vkb3duKT1cImV4ZWN1dGVUYWJsZSgkZXZlbnQpXCI+XG4gICAgICAgIDxzcGFuXG4gICAgICAgICAgICAqbmdGb3I9XCJsZXQgaXRlbSBvZiB0YWJsZURhdGE7IGxldCBjb2xJbmRleCA9IGluZGV4XCJcbiAgICAgICAgICAgIFtuZ0NsYXNzXT1cInsgJ2FjdGl2ZS1jZWxsJzogcm93SW5kZXggPD0gbWF4Um93SW5kZXggJiYgY29sSW5kZXggPD0gbWF4Q29sSW5kZXgsICdzZWxlY3Rvci1jZWxsJzogdHJ1ZSB9XCJcbiAgICAgICAgICAgIChtb3VzZWVudGVyKT1cIm9uU2VsZWN0Q2VsbHMocm93SW5kZXgsIGNvbEluZGV4KVwiXG4gICAgICAgID5cbiAgICAgICAgPC9zcGFuPlxuICAgIDwvZGl2PlxuICAgIDxzcGFuIGNsYXNzPVwic2VsZWN0b3ItdGV4dFwiPnt7IG1heFJvd0luZGV4ICsgMSB9fSB4IHt7IG1heENvbEluZGV4ICsgMSB9fTwvc3Bhbj5cbjwvZGl2PlxuIl19
45
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtc2VsZWN0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3NyYy9jb21wb25lbnRzL3RhYmxlLXNlbGVjdC90YWJsZS1zZWxlY3QuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvc3JjL2NvbXBvbmVudHMvdGFibGUtc2VsZWN0L3RhYmxlLXNlbGVjdC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBd0IsTUFBTSxlQUFlLENBQUM7QUFFdkUsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLDZDQUE2QyxDQUFDO0FBRTFFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQzs7OztBQU0vRCxNQUFNLE9BQU8sdUJBQXVCO0lBYWhDLFlBQW9CLFVBQWtEO1FBQWxELGVBQVUsR0FBVixVQUFVLENBQXdDO1FBUjdELGlCQUFZLEdBQUcsR0FBRyxFQUFFLEdBQUUsQ0FBQyxDQUFDO1FBRWpDLGNBQVMsR0FBRyxJQUFJLEtBQUssQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUUxQixnQkFBVyxHQUFHLENBQUMsQ0FBQyxDQUFDO1FBRWpCLGdCQUFXLEdBQUcsQ0FBQyxDQUFDLENBQUM7SUFFd0QsQ0FBQztJQUUxRSxRQUFRLEtBQVUsQ0FBQztJQUVuQixhQUFhLENBQUMsUUFBUSxFQUFFLFFBQVE7UUFDNUIsSUFBSSxDQUFDLFdBQVcsR0FBRyxRQUFRLENBQUM7UUFDNUIsSUFBSSxDQUFDLFdBQVcsR0FBRyxRQUFRLENBQUM7SUFDaEMsQ0FBQztJQUVELFlBQVksQ0FBQyxLQUFpQjtRQUMxQixLQUFLLENBQUMsY0FBYyxFQUFFLENBQUM7UUFDdkIsS0FBSyxDQUFDLGVBQWUsRUFBRSxDQUFDO1FBQ3hCLElBQUksQ0FBQyxZQUFZLEVBQUUsQ0FBQztRQUNwQixNQUFNLElBQUksR0FBRyxJQUFJLFlBQVksQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUM7UUFDakQsV0FBVyxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxXQUFXLEdBQUcsQ0FBQyxFQUFFLElBQUksQ0FBQyxXQUFXLEdBQUcsQ0FBQyxDQUFDLENBQUM7UUFDM0UsSUFBSSxJQUFJLENBQUMsVUFBVSxFQUFFO1lBQ2pCLElBQUksQ0FBQyxVQUFVLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDeEIsSUFBSSxDQUFDLFdBQVcsR0FBRyxDQUFDLENBQUMsQ0FBQztZQUN0QixJQUFJLENBQUMsV0FBVyxHQUFHLENBQUMsQ0FBQyxDQUFDO1NBQ3pCO0lBQ0wsQ0FBQzs7b0hBakNRLHVCQUF1Qjt3R0FBdkIsdUJBQXVCLDhJQ1ZwQyw2akJBV0E7MkZERGEsdUJBQXVCO2tCQUpuQyxTQUFTOytCQUNJLGNBQWM7b0dBSWYsWUFBWTtzQkFBcEIsS0FBSztnQkFFRyxNQUFNO3NCQUFkLEtBQUs7Z0JBRUcsWUFBWTtzQkFBcEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uSW5pdCwgSG9zdExpc3RlbmVyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUaHlQb3BvdmVyUmVmIH0gZnJvbSAnbmd4LXRldGh5cy9wb3BvdmVyJztcbmltcG9ydCB7IGluc2VydFRhYmxlIH0gZnJvbSAnLi4vLi4vcGx1Z2lucy90YWJsZS90cmFuc2Zvcm1zL2luc2VydC10YWJsZSc7XG5pbXBvcnQgeyBUaGVFZGl0b3IgfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzJztcbmltcG9ydCB7IFRhYmxlT3B0aW9ucyB9IGZyb20gJy4uLy4uL3BsdWdpbnMvdGFibGUvdGFibGUudHlwZXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ3RhYmxlLXNlbGVjdCcsXG4gICAgdGVtcGxhdGVVcmw6ICcuL3RhYmxlLXNlbGVjdC5jb21wb25lbnQuaHRtbCdcbn0pXG5leHBvcnQgY2xhc3MgVGhlVGFibGVTZWxlY3RDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICAgIEBJbnB1dCgpIG9wdGlvbnNQYXJhbTogVGFibGVPcHRpb25zO1xuXG4gICAgQElucHV0KCkgZWRpdG9yOiBUaGVFZGl0b3I7XG5cbiAgICBASW5wdXQoKSBiZWZvcmVJbnNlcnQgPSAoKSA9PiB7fTtcblxuICAgIHRhYmxlRGF0YSA9IG5ldyBBcnJheSgxMCk7XG5cbiAgICBtYXhSb3dJbmRleCA9IC0xO1xuXG4gICAgbWF4Q29sSW5kZXggPSAtMTtcblxuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgcG9wb3ZlclJlZjogVGh5UG9wb3ZlclJlZjxUaGVUYWJsZVNlbGVjdENvbXBvbmVudD4pIHt9XG5cbiAgICBuZ09uSW5pdCgpOiB2b2lkIHt9XG5cbiAgICBvblNlbGVjdENlbGxzKHJvd0luZGV4LCBjb2xJbmRleCkge1xuICAgICAgICB0aGlzLm1heFJvd0luZGV4ID0gcm93SW5kZXg7XG4gICAgICAgIHRoaXMubWF4Q29sSW5kZXggPSBjb2xJbmRleDtcbiAgICB9XG5cbiAgICBleGVjdXRlVGFibGUoZXZlbnQ6IE1vdXNlRXZlbnQpIHtcbiAgICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgZXZlbnQuc3RvcFByb3BhZ2F0aW9uKCk7XG4gICAgICAgIHRoaXMuYmVmb3JlSW5zZXJ0KCk7XG4gICAgICAgIGNvbnN0IG9wdHMgPSBuZXcgVGFibGVPcHRpb25zKHRoaXMub3B0aW9uc1BhcmFtKTtcbiAgICAgICAgaW5zZXJ0VGFibGUob3B0cywgdGhpcy5lZGl0b3IsIHRoaXMubWF4Um93SW5kZXggKyAxLCB0aGlzLm1heENvbEluZGV4ICsgMSk7XG4gICAgICAgIGlmICh0aGlzLnBvcG92ZXJSZWYpIHtcbiAgICAgICAgICAgIHRoaXMucG9wb3ZlclJlZi5jbG9zZSgpO1xuICAgICAgICAgICAgdGhpcy5tYXhDb2xJbmRleCA9IC0xO1xuICAgICAgICAgICAgdGhpcy5tYXhSb3dJbmRleCA9IC0xO1xuICAgICAgICB9XG4gICAgfVxufVxuIiwiPGRpdiBjbGFzcz1cInRhYmxlLXNlbGVjdG9yLWNvbnRhaW5lclwiPlxuICAgIDxkaXYgKm5nRm9yPVwibGV0IGl0ZW0gb2YgdGFibGVEYXRhOyBsZXQgcm93SW5kZXggPSBpbmRleFwiIGNsYXNzPVwic2VsZWN0b3Itcm93XCIgKG1vdXNlZG93bik9XCJleGVjdXRlVGFibGUoJGV2ZW50KVwiPlxuICAgICAgICA8c3BhblxuICAgICAgICAgICAgKm5nRm9yPVwibGV0IGl0ZW0gb2YgdGFibGVEYXRhOyBsZXQgY29sSW5kZXggPSBpbmRleFwiXG4gICAgICAgICAgICBbbmdDbGFzc109XCJ7ICdhY3RpdmUtY2VsbCc6IHJvd0luZGV4IDw9IG1heFJvd0luZGV4ICYmIGNvbEluZGV4IDw9IG1heENvbEluZGV4LCAnc2VsZWN0b3ItY2VsbCc6IHRydWUgfVwiXG4gICAgICAgICAgICAobW91c2VlbnRlcik9XCJvblNlbGVjdENlbGxzKHJvd0luZGV4LCBjb2xJbmRleClcIlxuICAgICAgICA+XG4gICAgICAgIDwvc3Bhbj5cbiAgICA8L2Rpdj5cbiAgICA8c3BhbiBjbGFzcz1cInNlbGVjdG9yLXRleHRcIj57eyBtYXhSb3dJbmRleCArIDEgfX0geCB7eyBtYXhDb2xJbmRleCArIDEgfX08L3NwYW4+XG48L2Rpdj5cbiJdfQ==