@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.
- package/components/listbox/listbox.d.ts +85 -0
- package/components/listbox/listbox.type.d.ts +5 -0
- package/components/plugin-menu/plugin-menu.component.d.ts +39 -0
- package/components/plugin-menu/plugin-menu.component.scss +50 -0
- package/components/table-select/table-select.component.d.ts +2 -2
- package/components/table-select/table-select.component.scss +1 -1
- package/components/toolbar/toolbar.component.d.ts +4 -3
- package/components/toolbar-dropdown/toolbar-dropdown.component.d.ts +5 -1
- package/components/toolbar-dropdown/toolbar-dropdown.component.scss +0 -11
- package/components/toolbar-group/toolbar-group.component.d.ts +1 -1
- package/components/toolbar-group/toolbar-group.component.scss +2 -3
- package/components/toolbar-item/toolbar-item.component.d.ts +2 -7
- package/constants/index.d.ts +1 -0
- package/constants/node-types.d.ts +2 -1
- package/constants/plugin-menu.d.ts +24 -0
- package/constants/toolbar.d.ts +0 -5
- package/core/utils/index.d.ts +1 -0
- package/core/utils/plugin-menu.d.ts +10 -0
- package/editor.component.d.ts +6 -2
- package/editor.module.d.ts +53 -49
- package/esm2020/components/listbox/listbox.mjs +341 -0
- package/esm2020/components/listbox/listbox.type.mjs +5 -0
- package/esm2020/components/plugin-menu/plugin-menu.component.mjs +102 -0
- package/esm2020/components/table-select/table-select.component.mjs +7 -11
- package/esm2020/components/toolbar/toolbar.component.mjs +31 -29
- package/esm2020/components/toolbar-dropdown/toolbar-dropdown.component.mjs +25 -6
- package/esm2020/components/toolbar-group/toolbar-group.component.mjs +5 -5
- package/esm2020/components/toolbar-item/toolbar-item.component.mjs +29 -70
- package/esm2020/constants/index.mjs +2 -1
- package/esm2020/constants/node-types.mjs +2 -1
- package/esm2020/constants/plugin-menu.mjs +272 -0
- package/esm2020/constants/toolbar.mjs +5 -23
- package/esm2020/core/create-toolbar.mjs +5 -6
- package/esm2020/core/utils/index.mjs +2 -1
- package/esm2020/core/utils/plugin-menu.mjs +33 -0
- package/esm2020/editor.component.mjs +26 -23
- package/esm2020/editor.module.mjs +38 -9
- package/esm2020/interfaces/editor.mjs +1 -1
- package/esm2020/interfaces/plugins/index.mjs +2 -1
- package/esm2020/interfaces/plugins/plugin-key.mjs +2 -1
- package/esm2020/interfaces/plugins/plugin-menu.mjs +19 -0
- package/esm2020/interfaces/plugins/plugins.mjs +1 -1
- package/esm2020/interfaces/toolbar.mjs +1 -1
- package/esm2020/plugins/blockquote/blockquote.plugin.mjs +15 -1
- package/esm2020/plugins/code/code.component.mjs +3 -4
- package/esm2020/plugins/code/code.plugin.mjs +15 -1
- package/esm2020/plugins/color/toolbar-item.component.mjs +2 -2
- package/esm2020/plugins/common/common.plugin.mjs +20 -0
- package/esm2020/plugins/deserializers/deserialize-html.plugin.mjs +11 -3
- package/esm2020/plugins/deserializers/deserialize-md.plugin.mjs +11 -3
- package/esm2020/plugins/heading/heading.plugin.mjs +49 -2
- package/esm2020/plugins/hr/hr.plugin.mjs +15 -1
- package/esm2020/plugins/image/image.editor.mjs +17 -1
- package/esm2020/plugins/image/image.plugin.mjs +15 -1
- package/esm2020/plugins/indent/indent.plugin.mjs +3 -2
- package/esm2020/plugins/index.mjs +3 -1
- package/esm2020/plugins/link/link.plugin.mjs +15 -2
- package/esm2020/plugins/list/list.plugin.mjs +26 -2
- package/esm2020/plugins/quick-insert/components/quick-insert.component.mjs +43 -19
- package/esm2020/plugins/quick-insert/quick-insert.editor.mjs +41 -26
- package/esm2020/plugins/quick-insert/quick-insert.plugin.mjs +62 -35
- package/esm2020/plugins/table/table.plugin.mjs +16 -1
- package/esm2020/plugins/table/toolbar-item.component.mjs +4 -3
- package/esm2020/public-api.mjs +3 -1
- package/esm2020/services/toolbar.service.mjs +4 -5
- package/esm2020/utils/blob.mjs +16 -0
- package/esm2020/utils/fragment.mjs +9 -1
- package/esm2020/utils/index.mjs +2 -1
- package/esm2020/utils/weak-maps.mjs +2 -2
- package/fesm2015/worktile-theia.mjs +1555 -595
- package/fesm2015/worktile-theia.mjs.map +1 -1
- package/fesm2020/worktile-theia.mjs +1546 -588
- package/fesm2020/worktile-theia.mjs.map +1 -1
- package/interfaces/editor.d.ts +2 -0
- package/interfaces/plugins/index.d.ts +1 -0
- package/interfaces/plugins/plugin-key.d.ts +2 -1
- package/interfaces/plugins/plugin-menu.d.ts +26 -0
- package/interfaces/plugins/plugins.d.ts +6 -1
- package/interfaces/toolbar.d.ts +1 -3
- package/package.json +1 -1
- package/plugins/code/code.component.d.ts +1 -2
- package/plugins/common/common.plugin.d.ts +1 -0
- package/plugins/image/image.editor.d.ts +2 -0
- package/plugins/link/link.component.scss +0 -12
- package/plugins/quick-insert/components/quick-insert.component.d.ts +8 -7
- package/plugins/quick-insert/components/quick-insert.component.scss +0 -4
- package/plugins/quick-insert/quick-insert.editor.d.ts +7 -4
- package/plugins/quick-insert/quick-insert.plugin.d.ts +2 -2
- package/public-api.d.ts +2 -0
- package/services/toolbar.service.d.ts +1 -1
- package/styles/index.scss +1 -1
- package/utils/blob.d.ts +1 -0
- package/utils/fragment.d.ts +1 -0
- package/utils/index.d.ts +1 -0
- package/utils/weak-maps.d.ts +1 -1
- package/esm2020/plugins/quick-insert/components/quick-toolbar/quick-toolbar.component.mjs +0 -80
- package/plugins/quick-insert/components/quick-toolbar/quick-toolbar.component.d.ts +0 -28
- 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
|
|
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"
|
|
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
|
-
}],
|
|
46
|
-
type:
|
|
47
|
-
args: ['document: mousedown', ['$event']]
|
|
42
|
+
}], beforeInsert: [{
|
|
43
|
+
type: Input
|
|
48
44
|
}] } });
|
|
49
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtc2VsZWN0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3NyYy9jb21wb25lbnRzL3RhYmxlLXNlbGVjdC90YWJsZS1zZWxlY3QuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvc3JjL2NvbXBvbmVudHMvdGFibGUtc2VsZWN0L3RhYmxlLXNlbGVjdC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBd0IsTUFBTSxlQUFlLENBQUM7QUFFdkUsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLDZDQUE2QyxDQUFDO0FBRTFFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQzs7OztBQU0vRCxNQUFNLE9BQU8sdUJBQXVCO0lBYWhDLFlBQW9CLFVBQWtEO1FBQWxELGVBQVUsR0FBVixVQUFVLENBQXdDO1FBUjdELGlCQUFZLEdBQUcsR0FBRyxFQUFFLEdBQUUsQ0FBQyxDQUFDO1FBRWpDLGNBQVMsR0FBRyxJQUFJLEtBQUssQ0FBQyxFQUFFLENBQUMsQ0FBQztRQUUxQixnQkFBVyxHQUFHLENBQUMsQ0FBQyxDQUFDO1FBRWpCLGdCQUFXLEdBQUcsQ0FBQyxDQUFDLENBQUM7SUFFd0QsQ0FBQztJQUUxRSxRQUFRLEtBQVUsQ0FBQztJQUVuQixhQUFhLENBQUMsUUFBUSxFQUFFLFFBQVE7UUFDNUIsSUFBSSxDQUFDLFdBQVcsR0FBRyxRQUFRLENBQUM7UUFDNUIsSUFBSSxDQUFDLFdBQVcsR0FBRyxRQUFRLENBQUM7SUFDaEMsQ0FBQztJQUVELFlBQVksQ0FBQyxLQUFpQjtRQUMxQixLQUFLLENBQUMsY0FBYyxFQUFFLENBQUM7UUFDdkIsS0FBSyxDQUFDLGVBQWUsRUFBRSxDQUFDO1FBQ3hCLElBQUksQ0FBQyxZQUFZLEVBQUUsQ0FBQztRQUNwQixNQUFNLElBQUksR0FBRyxJQUFJLFlBQVksQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUM7UUFDakQsV0FBVyxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsTUFBTSxFQUFFLElBQUksQ0FBQyxXQUFXLEdBQUcsQ0FBQyxFQUFFLElBQUksQ0FBQyxXQUFXLEdBQUcsQ0FBQyxDQUFDLENBQUM7UUFDM0UsSUFBSSxJQUFJLENBQUMsVUFBVSxFQUFFO1lBQ2pCLElBQUksQ0FBQyxVQUFVLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDeEIsSUFBSSxDQUFDLFdBQVcsR0FBRyxDQUFDLENBQUMsQ0FBQztZQUN0QixJQUFJLENBQUMsV0FBVyxHQUFHLENBQUMsQ0FBQyxDQUFDO1NBQ3pCO0lBQ0wsQ0FBQzs7b0hBakNRLHVCQUF1Qjt3R0FBdkIsdUJBQXVCLDhJQ1ZwQyw2akJBV0E7MkZERGEsdUJBQXVCO2tCQUpuQyxTQUFTOytCQUNJLGNBQWM7b0dBSWYsWUFBWTtzQkFBcEIsS0FBSztnQkFFRyxNQUFNO3NCQUFkLEtBQUs7Z0JBRUcsWUFBWTtzQkFBcEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uSW5pdCwgSG9zdExpc3RlbmVyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUaHlQb3BvdmVyUmVmIH0gZnJvbSAnbmd4LXRldGh5cy9wb3BvdmVyJztcbmltcG9ydCB7IGluc2VydFRhYmxlIH0gZnJvbSAnLi4vLi4vcGx1Z2lucy90YWJsZS90cmFuc2Zvcm1zL2luc2VydC10YWJsZSc7XG5pbXBvcnQgeyBUaGVFZGl0b3IgfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzJztcbmltcG9ydCB7IFRhYmxlT3B0aW9ucyB9IGZyb20gJy4uLy4uL3BsdWdpbnMvdGFibGUvdGFibGUudHlwZXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ3RhYmxlLXNlbGVjdCcsXG4gICAgdGVtcGxhdGVVcmw6ICcuL3RhYmxlLXNlbGVjdC5jb21wb25lbnQuaHRtbCdcbn0pXG5leHBvcnQgY2xhc3MgVGhlVGFibGVTZWxlY3RDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICAgIEBJbnB1dCgpIG9wdGlvbnNQYXJhbTogVGFibGVPcHRpb25zO1xuXG4gICAgQElucHV0KCkgZWRpdG9yOiBUaGVFZGl0b3I7XG5cbiAgICBASW5wdXQoKSBiZWZvcmVJbnNlcnQgPSAoKSA9PiB7fTtcblxuICAgIHRhYmxlRGF0YSA9IG5ldyBBcnJheSgxMCk7XG5cbiAgICBtYXhSb3dJbmRleCA9IC0xO1xuXG4gICAgbWF4Q29sSW5kZXggPSAtMTtcblxuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgcG9wb3ZlclJlZjogVGh5UG9wb3ZlclJlZjxUaGVUYWJsZVNlbGVjdENvbXBvbmVudD4pIHt9XG5cbiAgICBuZ09uSW5pdCgpOiB2b2lkIHt9XG5cbiAgICBvblNlbGVjdENlbGxzKHJvd0luZGV4LCBjb2xJbmRleCkge1xuICAgICAgICB0aGlzLm1heFJvd0luZGV4ID0gcm93SW5kZXg7XG4gICAgICAgIHRoaXMubWF4Q29sSW5kZXggPSBjb2xJbmRleDtcbiAgICB9XG5cbiAgICBleGVjdXRlVGFibGUoZXZlbnQ6IE1vdXNlRXZlbnQpIHtcbiAgICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcbiAgICAgICAgZXZlbnQuc3RvcFByb3BhZ2F0aW9uKCk7XG4gICAgICAgIHRoaXMuYmVmb3JlSW5zZXJ0KCk7XG4gICAgICAgIGNvbnN0IG9wdHMgPSBuZXcgVGFibGVPcHRpb25zKHRoaXMub3B0aW9uc1BhcmFtKTtcbiAgICAgICAgaW5zZXJ0VGFibGUob3B0cywgdGhpcy5lZGl0b3IsIHRoaXMubWF4Um93SW5kZXggKyAxLCB0aGlzLm1heENvbEluZGV4ICsgMSk7XG4gICAgICAgIGlmICh0aGlzLnBvcG92ZXJSZWYpIHtcbiAgICAgICAgICAgIHRoaXMucG9wb3ZlclJlZi5jbG9zZSgpO1xuICAgICAgICAgICAgdGhpcy5tYXhDb2xJbmRleCA9IC0xO1xuICAgICAgICAgICAgdGhpcy5tYXhSb3dJbmRleCA9IC0xO1xuICAgICAgICB9XG4gICAgfVxufVxuIiwiPGRpdiBjbGFzcz1cInRhYmxlLXNlbGVjdG9yLWNvbnRhaW5lclwiPlxuICAgIDxkaXYgKm5nRm9yPVwibGV0IGl0ZW0gb2YgdGFibGVEYXRhOyBsZXQgcm93SW5kZXggPSBpbmRleFwiIGNsYXNzPVwic2VsZWN0b3Itcm93XCIgKG1vdXNlZG93bik9XCJleGVjdXRlVGFibGUoJGV2ZW50KVwiPlxuICAgICAgICA8c3BhblxuICAgICAgICAgICAgKm5nRm9yPVwibGV0IGl0ZW0gb2YgdGFibGVEYXRhOyBsZXQgY29sSW5kZXggPSBpbmRleFwiXG4gICAgICAgICAgICBbbmdDbGFzc109XCJ7ICdhY3RpdmUtY2VsbCc6IHJvd0luZGV4IDw9IG1heFJvd0luZGV4ICYmIGNvbEluZGV4IDw9IG1heENvbEluZGV4LCAnc2VsZWN0b3ItY2VsbCc6IHRydWUgfVwiXG4gICAgICAgICAgICAobW91c2VlbnRlcik9XCJvblNlbGVjdENlbGxzKHJvd0luZGV4LCBjb2xJbmRleClcIlxuICAgICAgICA+XG4gICAgICAgIDwvc3Bhbj5cbiAgICA8L2Rpdj5cbiAgICA8c3BhbiBjbGFzcz1cInNlbGVjdG9yLXRleHRcIj57eyBtYXhSb3dJbmRleCArIDEgfX0geCB7eyBtYXhDb2xJbmRleCArIDEgfX08L3NwYW4+XG48L2Rpdj5cbiJdfQ==
|