el-header-and-footer 0.0.1
Sign up to get free protection for your applications and to get access to all the features.
- package/README.md +24 -0
- package/el-header-and-footer.d.ts +5 -0
- package/esm2020/el-header-and-footer.mjs +5 -0
- package/esm2020/lib/el-header-and-footer.component.mjs +1046 -0
- package/esm2020/lib/el-header-and-footer.module.mjs +49 -0
- package/esm2020/lib/el-header-and-footer.service.mjs +14 -0
- package/esm2020/public-api.mjs +7 -0
- package/fesm2015/el-header-and-footer.mjs +1116 -0
- package/fesm2015/el-header-and-footer.mjs.map +1 -0
- package/fesm2020/el-header-and-footer.mjs +1113 -0
- package/fesm2020/el-header-and-footer.mjs.map +1 -0
- package/lib/el-header-and-footer.component.d.ts +142 -0
- package/lib/el-header-and-footer.module.d.ts +13 -0
- package/lib/el-header-and-footer.service.d.ts +6 -0
- package/package.json +31 -0
- package/public-api.d.ts +3 -0
@@ -0,0 +1,1046 @@
|
|
1
|
+
import { Component, EventEmitter, forwardRef, Input, Output, ViewChild } from '@angular/core';
|
2
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
3
|
+
import { NgbDropdown } from '@ng-bootstrap/ng-bootstrap';
|
4
|
+
import * as i0 from "@angular/core";
|
5
|
+
import * as i1 from "@angular/router";
|
6
|
+
import * as i2 from "@angular/platform-browser";
|
7
|
+
import * as i3 from "ngx-color/sketch";
|
8
|
+
import * as i4 from "@ng-bootstrap/ng-bootstrap";
|
9
|
+
import * as i5 from "@angular/common";
|
10
|
+
export class ElHeaderAndFooterComponent {
|
11
|
+
constructor(router, route, renderer, sanitizer) {
|
12
|
+
this.router = router;
|
13
|
+
this.route = route;
|
14
|
+
this.renderer = renderer;
|
15
|
+
this.sanitizer = sanitizer;
|
16
|
+
this.editorId = '';
|
17
|
+
this.editorText = '';
|
18
|
+
this.editorFrom = '';
|
19
|
+
this.clear = false;
|
20
|
+
this.toolbarMode = 'fixed';
|
21
|
+
this.editorTextChange = new EventEmitter();
|
22
|
+
this.editorActionResponse = new EventEmitter();
|
23
|
+
this.value = '';
|
24
|
+
this.editorTextClear = new EventEmitter();
|
25
|
+
this.showToolbar = false;
|
26
|
+
this.toolbarTop = 0;
|
27
|
+
this.toolbarLeft = 0;
|
28
|
+
this.fonts = ['Arial', 'Courier New', 'Georgia', 'Times New Roman', 'Verdana'];
|
29
|
+
this.fontSizes = [10, 12, 14, 16, 18, 20, 24, 28, 32, 36];
|
30
|
+
this.selectedFont = 'Arial';
|
31
|
+
this.selectedFontSize = 14;
|
32
|
+
this.isTableSelected = false;
|
33
|
+
this.tableAdded = false;
|
34
|
+
this.selectedTable = null;
|
35
|
+
this.isPlaceholderVisible = true;
|
36
|
+
this.selectedCell = null;
|
37
|
+
this.isBoldActive = false;
|
38
|
+
this.isItalicActive = false;
|
39
|
+
this.isUnderlineActive = false;
|
40
|
+
this.isStrikethroughActive = false;
|
41
|
+
this.isSubscriptActive = false;
|
42
|
+
this.isSuperscriptActive = false;
|
43
|
+
this.selectedFormatBlock = 'normal';
|
44
|
+
this.undoStack = [];
|
45
|
+
this.redoStack = [];
|
46
|
+
this.history = [];
|
47
|
+
this.historyIndex = -1;
|
48
|
+
this.selectedImage = null;
|
49
|
+
this.imageEditUrl = '';
|
50
|
+
this.imagePositionX = 0;
|
51
|
+
this.imagePositionY = 0;
|
52
|
+
this.imageResizeStartX = 0;
|
53
|
+
this.imageResizeStartY = 0;
|
54
|
+
this.imageResizeStartWidth = 0;
|
55
|
+
this.imageResizeStartHeight = 0;
|
56
|
+
this.imageResizeDirection = null;
|
57
|
+
this.onChange = () => { };
|
58
|
+
this.onTouched = () => { };
|
59
|
+
this.color = '#ddd';
|
60
|
+
this.selectedItemIndex = null;
|
61
|
+
this.parsedTable = null;
|
62
|
+
this.isFullScreen = false;
|
63
|
+
this.today = '';
|
64
|
+
this.CanvasColor = '#fff';
|
65
|
+
}
|
66
|
+
ngOnChanges(changes) {
|
67
|
+
if (changes['bgColor']) {
|
68
|
+
const event = { color: { hex: this.bgColor } };
|
69
|
+
this.setCanvasBackgroundColor(event, this.editorId);
|
70
|
+
}
|
71
|
+
}
|
72
|
+
ngAfterViewInit() {
|
73
|
+
this.initEditor();
|
74
|
+
this.checkPlaceholder();
|
75
|
+
this.setupHistory();
|
76
|
+
}
|
77
|
+
ngOnInit() {
|
78
|
+
this.init_Func(this.editorText);
|
79
|
+
document.addEventListener('selectionchange', () => {
|
80
|
+
this.checkActiveStates();
|
81
|
+
this.checkFormatBlock(this.editorId);
|
82
|
+
});
|
83
|
+
this.addClickListenerToImages();
|
84
|
+
this.addClickListenerToElements();
|
85
|
+
// this.route.queryParams.subscribe(params => {
|
86
|
+
// const data = JSON.parse(params['data']);
|
87
|
+
// if (data.editedIMG) {
|
88
|
+
// const imgUrl = sessionStorage.getItem('editImageFromTemp');
|
89
|
+
// if (imgUrl) {
|
90
|
+
// this.replaceImageSrc(imgUrl, data.index.index)
|
91
|
+
// }
|
92
|
+
// sessionStorage.removeItem('editImageFromTemp');
|
93
|
+
// }
|
94
|
+
// })
|
95
|
+
}
|
96
|
+
writeValue(value) {
|
97
|
+
if (value !== undefined) {
|
98
|
+
this.editorText = value;
|
99
|
+
this.initEditor();
|
100
|
+
this.init_Func(this.editorText);
|
101
|
+
}
|
102
|
+
}
|
103
|
+
// private addClickListenerToImages() {
|
104
|
+
// const editor = document.getElementById('editor');
|
105
|
+
// if (editor) {
|
106
|
+
// editor.addEventListener('click', (event) => {
|
107
|
+
// const target = event.target as HTMLElement;
|
108
|
+
// if (target.tagName === 'IMG') {
|
109
|
+
// this.selectedImage = target as HTMLImageElement;
|
110
|
+
// this.imageEditUrl = this.selectedImage.src;
|
111
|
+
// // Position the edit button near the selected image
|
112
|
+
// } else {
|
113
|
+
// this.selectedImage = null;
|
114
|
+
// }
|
115
|
+
// });
|
116
|
+
// }
|
117
|
+
// }
|
118
|
+
addClickListenerToImages() {
|
119
|
+
const editor = document.getElementById(this.editorId);
|
120
|
+
if (editor) {
|
121
|
+
editor.addEventListener('click', (event) => {
|
122
|
+
const target = event.target;
|
123
|
+
if (target.tagName === 'IMG') {
|
124
|
+
this.selectedImage = target;
|
125
|
+
this.imageEditUrl = this.selectedImage.src;
|
126
|
+
// Get the index of the selected image
|
127
|
+
const images = editor.getElementsByTagName('img');
|
128
|
+
for (let i = 0; i < images.length; i++) {
|
129
|
+
if (images[i] === this.selectedImage) {
|
130
|
+
this.selectedItemIndex = i;
|
131
|
+
break;
|
132
|
+
}
|
133
|
+
}
|
134
|
+
if (this.toolbarMode === 'bubble') {
|
135
|
+
this.onTextSelect();
|
136
|
+
}
|
137
|
+
}
|
138
|
+
else {
|
139
|
+
this.selectedImage = null;
|
140
|
+
this.selectedItemIndex = null;
|
141
|
+
}
|
142
|
+
});
|
143
|
+
}
|
144
|
+
}
|
145
|
+
addClickListenerToElements() {
|
146
|
+
const editor = document.getElementById(this.editorId);
|
147
|
+
if (editor) {
|
148
|
+
editor.addEventListener('click', (event) => {
|
149
|
+
const target = event.target;
|
150
|
+
// Handle images
|
151
|
+
if (target.tagName === 'IMG') {
|
152
|
+
this.selectedImage = target;
|
153
|
+
this.imageEditUrl = this.selectedImage.src;
|
154
|
+
// Get the index of the selected image
|
155
|
+
const images = editor.getElementsByTagName('img');
|
156
|
+
for (let i = 0; i < images.length; i++) {
|
157
|
+
if (images[i] === this.selectedImage) {
|
158
|
+
this.selectedItemIndex = i;
|
159
|
+
break;
|
160
|
+
}
|
161
|
+
}
|
162
|
+
}
|
163
|
+
else {
|
164
|
+
this.selectedImage = null;
|
165
|
+
}
|
166
|
+
if (target.tagName === 'TD' || target.tagName === 'TH') {
|
167
|
+
this.selectedTable = target.closest('table');
|
168
|
+
const cells = this.selectedTable.getElementsByTagName(target.tagName);
|
169
|
+
for (let i = 0; i < cells.length; i++) {
|
170
|
+
if (cells[i] === target) {
|
171
|
+
this.selectedItemIndex = i;
|
172
|
+
break;
|
173
|
+
}
|
174
|
+
}
|
175
|
+
}
|
176
|
+
else {
|
177
|
+
this.selectedTable = null;
|
178
|
+
}
|
179
|
+
if (target.tagName === 'P' || target.tagName === 'SPAN' || target.tagName === 'DIV') {
|
180
|
+
const paragraphs = editor.getElementsByTagName(target.tagName);
|
181
|
+
for (let i = 0; i < paragraphs.length; i++) {
|
182
|
+
if (paragraphs[i] === target) {
|
183
|
+
this.selectedItemIndex = i;
|
184
|
+
break;
|
185
|
+
}
|
186
|
+
}
|
187
|
+
}
|
188
|
+
else {
|
189
|
+
}
|
190
|
+
});
|
191
|
+
}
|
192
|
+
}
|
193
|
+
replaceImageSrc(newSrc, index) {
|
194
|
+
const editor = document.getElementById(this.editorId);
|
195
|
+
if (editor) {
|
196
|
+
editor.focus();
|
197
|
+
const images = editor.getElementsByTagName('IMG');
|
198
|
+
if (index >= 0) {
|
199
|
+
images[index].setAttribute('src', newSrc);
|
200
|
+
}
|
201
|
+
else {
|
202
|
+
console.warn(`Index ${index} is out of bounds. Total images: ${images.length}`);
|
203
|
+
}
|
204
|
+
}
|
205
|
+
else {
|
206
|
+
console.error('Editor element not found');
|
207
|
+
}
|
208
|
+
}
|
209
|
+
initEditor() {
|
210
|
+
// Initialize editor content and listeners
|
211
|
+
const editor = document.getElementById(this.editorId);
|
212
|
+
if (editor) {
|
213
|
+
editor.innerHTML = this.editorText;
|
214
|
+
editor.addEventListener('input', () => {
|
215
|
+
this.onModelChange(editor.innerHTML);
|
216
|
+
});
|
217
|
+
}
|
218
|
+
this.checkPlaceholder();
|
219
|
+
}
|
220
|
+
registerOnChange(fn) {
|
221
|
+
this.onChange = fn;
|
222
|
+
}
|
223
|
+
registerOnTouched(fn) {
|
224
|
+
this.onTouched = fn;
|
225
|
+
}
|
226
|
+
setDisabledState(isDisabled) {
|
227
|
+
// Handle the disabled state if necessary
|
228
|
+
}
|
229
|
+
onModelChange(value) {
|
230
|
+
if (value) {
|
231
|
+
const VALUE = value;
|
232
|
+
this.editorText = this.mainCanvas(VALUE);
|
233
|
+
this.onChange(this.mainCanvas(VALUE));
|
234
|
+
this.editorTextChange.emit(this.mainCanvas(VALUE));
|
235
|
+
}
|
236
|
+
else {
|
237
|
+
this.selectedImage = null;
|
238
|
+
}
|
239
|
+
}
|
240
|
+
applyImageStyles(content) {
|
241
|
+
const div = document.createElement('div');
|
242
|
+
div.innerHTML = content;
|
243
|
+
const images = div.querySelectorAll('img');
|
244
|
+
images.forEach(img => {
|
245
|
+
if (img.style.maxWidth >= '700px') {
|
246
|
+
img.style.maxWidth = '700px';
|
247
|
+
// img.width = 300;
|
248
|
+
img.style.height = 'auto';
|
249
|
+
}
|
250
|
+
else {
|
251
|
+
img.style.maxWidth = '100%';
|
252
|
+
img.style.height = 'auto';
|
253
|
+
}
|
254
|
+
});
|
255
|
+
return div.innerHTML;
|
256
|
+
}
|
257
|
+
init_Func(html) {
|
258
|
+
if (html) {
|
259
|
+
let editor = document.getElementById(this.editorId);
|
260
|
+
if (editor) {
|
261
|
+
editor.focus();
|
262
|
+
this.setEditorContent(html);
|
263
|
+
// Set up a MutationObserver to handle content changes
|
264
|
+
this.setupMutationObserver(editor);
|
265
|
+
// Move the caret to the end after initial content setup
|
266
|
+
this.moveCaretToEnd(editor);
|
267
|
+
// editor.focus()
|
268
|
+
// editor.innerHTML = html;
|
269
|
+
// this.sanitizedContent = this.sanitizer.bypassSecurityTrustHtml(this.applyImageStyles(html));
|
270
|
+
// editor.innerHTML = this.sanitizedContent as string;
|
271
|
+
// editor.addEventListener('input', () => {
|
272
|
+
// if (editor) {
|
273
|
+
// editor.focus()
|
274
|
+
// this.onModelChange(editor.innerHTML);
|
275
|
+
// }
|
276
|
+
// });
|
277
|
+
}
|
278
|
+
}
|
279
|
+
else {
|
280
|
+
this.selectedImage = null;
|
281
|
+
}
|
282
|
+
}
|
283
|
+
setEditorContent(html) {
|
284
|
+
let editor = document.getElementById(this.editorId);
|
285
|
+
if (editor) {
|
286
|
+
// Sanitize and apply styles to the HTML
|
287
|
+
this.sanitizedContent = this.sanitizer.bypassSecurityTrustHtml(this.applyImageStyles(html));
|
288
|
+
editor.innerHTML = this.sanitizedContent;
|
289
|
+
}
|
290
|
+
}
|
291
|
+
setupMutationObserver(editor) {
|
292
|
+
const observer = new MutationObserver(() => {
|
293
|
+
// Move the caret to the end after content changes
|
294
|
+
this.moveCaretToEnd(editor);
|
295
|
+
// Update model with the current content
|
296
|
+
this.onModelChange(editor.innerHTML);
|
297
|
+
});
|
298
|
+
observer.observe(editor, { childList: true, subtree: true, characterData: true });
|
299
|
+
}
|
300
|
+
moveCaretToEnd(editor) {
|
301
|
+
const selection = window.getSelection();
|
302
|
+
const range = document.createRange();
|
303
|
+
if (editor.lastChild) {
|
304
|
+
range.selectNodeContents(editor);
|
305
|
+
range.collapse(false); // Collapse to the end
|
306
|
+
selection?.removeAllRanges();
|
307
|
+
selection?.addRange(range);
|
308
|
+
}
|
309
|
+
}
|
310
|
+
// format(command: string, value?: any) {
|
311
|
+
// document.execCommand(command, false, value ?? '');
|
312
|
+
// // if (command === 'underline') {
|
313
|
+
// // // Toggle underline
|
314
|
+
// // const isUnderlined = document.queryCommandState('underline');
|
315
|
+
// // document.execCommand('underline', false, isUnderlined ? 'false' : 'true');
|
316
|
+
// // } else {
|
317
|
+
// // document.execCommand(command, false, '');
|
318
|
+
// // }
|
319
|
+
// }
|
320
|
+
onFormatChange(data) {
|
321
|
+
const value = data;
|
322
|
+
this.selectedFormatBlock = value;
|
323
|
+
if (value) {
|
324
|
+
this.format('formatBlock', this.editorId, value);
|
325
|
+
}
|
326
|
+
}
|
327
|
+
format(command, editorId, value) {
|
328
|
+
const editor = document.getElementById(editorId);
|
329
|
+
if (editor) {
|
330
|
+
editor.focus();
|
331
|
+
if (command === 'subscript') {
|
332
|
+
this.isSubscriptActive = !this.isSubscriptActive;
|
333
|
+
document.execCommand('subscript', false, '');
|
334
|
+
}
|
335
|
+
else if (command === 'superscript') {
|
336
|
+
this.isSuperscriptActive = !this.isSuperscriptActive;
|
337
|
+
document.execCommand('superscript', false, '');
|
338
|
+
;
|
339
|
+
}
|
340
|
+
else {
|
341
|
+
document.execCommand(command, false, value ?? '');
|
342
|
+
if (value) {
|
343
|
+
const tag = value.toLowerCase().replace(/[<>]/g, '');
|
344
|
+
const toolbar = document.getElementById(editorId + 'toolbar');
|
345
|
+
if (toolbar) {
|
346
|
+
this.selectedFormatBlock = this.formatBlockDecode(tag);
|
347
|
+
}
|
348
|
+
}
|
349
|
+
}
|
350
|
+
}
|
351
|
+
this.checkActiveStates();
|
352
|
+
this.checkFormatBlock(editorId);
|
353
|
+
}
|
354
|
+
checkActiveStates() {
|
355
|
+
this.isBoldActive = document.queryCommandState('bold');
|
356
|
+
this.isItalicActive = document.queryCommandState('italic');
|
357
|
+
this.isUnderlineActive = document.queryCommandState('underline');
|
358
|
+
this.isStrikethroughActive = document.queryCommandState('strikethrough');
|
359
|
+
this.isSubscriptActive = document.queryCommandState('subscript');
|
360
|
+
this.isSuperscriptActive = document.queryCommandState('superscript');
|
361
|
+
}
|
362
|
+
checkFormatBlock(editorId) {
|
363
|
+
const editor = document.getElementById(editorId);
|
364
|
+
if (editor) {
|
365
|
+
const formatBlock = document.queryCommandValue('formatBlock');
|
366
|
+
const toolbar = document.getElementById(editorId + 'toolbar');
|
367
|
+
if (toolbar) {
|
368
|
+
this.selectedFormatBlock = this.formatBlockDecode(formatBlock);
|
369
|
+
}
|
370
|
+
// You can further handle the formatBlock value as needed
|
371
|
+
}
|
372
|
+
}
|
373
|
+
formatBlockDecode(data) {
|
374
|
+
switch (data) {
|
375
|
+
case 'h1':
|
376
|
+
return 'heading 1';
|
377
|
+
break;
|
378
|
+
case 'h2':
|
379
|
+
return 'heading 2';
|
380
|
+
break;
|
381
|
+
case 'h3':
|
382
|
+
return 'heading 3';
|
383
|
+
break;
|
384
|
+
case 'h4':
|
385
|
+
return 'heading 4';
|
386
|
+
break;
|
387
|
+
case 'h5':
|
388
|
+
return 'heading 5';
|
389
|
+
break;
|
390
|
+
case 'h6':
|
391
|
+
return 'heading 6';
|
392
|
+
break;
|
393
|
+
case 'p':
|
394
|
+
return 'normal';
|
395
|
+
break;
|
396
|
+
default:
|
397
|
+
return 'normal';
|
398
|
+
break;
|
399
|
+
}
|
400
|
+
}
|
401
|
+
changeFont(event) {
|
402
|
+
this.selectedFont = event;
|
403
|
+
document.execCommand('fontName', false, this.selectedFont);
|
404
|
+
}
|
405
|
+
insertCodeBlock() {
|
406
|
+
const code = `
|
407
|
+
<pre style="font-size: 12px;
|
408
|
+
color: white;
|
409
|
+
background-color: black;
|
410
|
+
overflow-x: auto;
|
411
|
+
margin-bottom: 5px;
|
412
|
+
margin-top: 5px;
|
413
|
+
padding: 5px 10px;">
|
414
|
+
<code style="display: block;
|
415
|
+
white-space: pre-wrap;
|
416
|
+
height: auto;
|
417
|
+
font-family: Menlo, Monaco, Consolas, 'Courier New', monospace;
|
418
|
+
font-size: 14px;" class="language-html">Insert code here...</code>
|
419
|
+
</pre>
|
420
|
+
`;
|
421
|
+
document.execCommand('insertHTML', false, code);
|
422
|
+
}
|
423
|
+
// changeFontSize(event: any) {
|
424
|
+
// document.execCommand('fontSize', false, '7');
|
425
|
+
// let editor = document.getElementById('editor');
|
426
|
+
// if (editor) {
|
427
|
+
// let fontElements = editor.getElementsByTagName('font');
|
428
|
+
// for (let i = 0; i < fontElements.length; i++) {
|
429
|
+
// if (fontElements[i].size == "7") {
|
430
|
+
// fontElements[i].removeAttribute("size");
|
431
|
+
// fontElements[i].style.fontSize = this.selectedFontSize + 'px';
|
432
|
+
// }
|
433
|
+
// }
|
434
|
+
// }
|
435
|
+
// }
|
436
|
+
changeFontSize(event) {
|
437
|
+
const selectedText = window.getSelection();
|
438
|
+
if (selectedText && selectedText.rangeCount > 0) {
|
439
|
+
const range = selectedText.getRangeAt(0);
|
440
|
+
const span = document.createElement('span');
|
441
|
+
span.style.fontSize = this.selectedFontSize + 'px';
|
442
|
+
range.surroundContents(span);
|
443
|
+
}
|
444
|
+
}
|
445
|
+
addLink() {
|
446
|
+
let url = prompt("Enter the link here: ", "http://");
|
447
|
+
if (url) {
|
448
|
+
document.execCommand("createLink", false, url);
|
449
|
+
}
|
450
|
+
}
|
451
|
+
insertsImage(editorId) {
|
452
|
+
const editor = document.getElementById(editorId);
|
453
|
+
if (editor) {
|
454
|
+
editor.focus();
|
455
|
+
let imageInput = document.getElementById('imageInput');
|
456
|
+
if (imageInput) {
|
457
|
+
imageInput.click();
|
458
|
+
}
|
459
|
+
}
|
460
|
+
}
|
461
|
+
handleImageUpload(event) {
|
462
|
+
const file = event.target.files[0];
|
463
|
+
if (file) {
|
464
|
+
const reader = new FileReader();
|
465
|
+
reader.onload = (e) => {
|
466
|
+
const img = new Image();
|
467
|
+
img.src = e.target.result;
|
468
|
+
img.onload = () => {
|
469
|
+
// Create the HTML string with the exact width and height
|
470
|
+
const imgHTML = `<img src="${img.src}" width="${img.width}" height="${img.height}">`;
|
471
|
+
// Insert the image into the editor
|
472
|
+
document.execCommand('insertHTML', false, imgHTML);
|
473
|
+
};
|
474
|
+
};
|
475
|
+
reader.readAsDataURL(file);
|
476
|
+
}
|
477
|
+
}
|
478
|
+
addTable(editorId) {
|
479
|
+
const tableWidth = 825; // Table width in pixels
|
480
|
+
const cols = 3; // Number of columns
|
481
|
+
const cellMinWidth = tableWidth / cols; // Calculate minimum width for each cell
|
482
|
+
let table = `<br /><table style="border-collapse: collapse; width: ${tableWidth}px; border: 1px solid black;">`;
|
483
|
+
for (let i = 0; i < 3; i++) { // Number of rows
|
484
|
+
table += '<tr>';
|
485
|
+
for (let j = 0; j < cols; j++) {
|
486
|
+
table += `<td style="border: 1px solid #000; word-wrap: break-word; word-break: break-all; white-space: normal; min-width: ${cellMinWidth}px;"> </td>`;
|
487
|
+
}
|
488
|
+
table += '</tr>';
|
489
|
+
}
|
490
|
+
table += '</table><br/ >';
|
491
|
+
// document.execCommand('insertHTML', false, table);
|
492
|
+
const editor = document.getElementById(editorId);
|
493
|
+
if (editor) {
|
494
|
+
editor.focus();
|
495
|
+
document.execCommand('insertHTML', false, table);
|
496
|
+
}
|
497
|
+
this.tableAdded = true;
|
498
|
+
this.checkTableSelection();
|
499
|
+
}
|
500
|
+
checkTableSelection(event) {
|
501
|
+
let target = event?.target;
|
502
|
+
if (target && (target.tagName === 'TD' || target.tagName === 'TH')) {
|
503
|
+
this.isTableSelected = true;
|
504
|
+
this.selectedTable = target.closest('table');
|
505
|
+
}
|
506
|
+
else {
|
507
|
+
this.isTableSelected = false;
|
508
|
+
this.selectedTable = null;
|
509
|
+
}
|
510
|
+
this.checkPlaceholder();
|
511
|
+
}
|
512
|
+
checkPlaceholder() {
|
513
|
+
// let editor = document.getElementById('editor');
|
514
|
+
// if (editor) {
|
515
|
+
// this.isPlaceholderVisible = editor.innerHTML === '' || editor.innerHTML === '<br>';
|
516
|
+
// if (this.isPlaceholderVisible) {
|
517
|
+
// // editor.innerHTML = '<span class="placeholder" style="background: transparent; color: #000000">Insert text here ...</span>';
|
518
|
+
// } else {
|
519
|
+
// let placeholder = editor.querySelector('.placeholder');
|
520
|
+
// if (placeholder) {
|
521
|
+
// editor.removeChild(placeholder);
|
522
|
+
// }
|
523
|
+
// }
|
524
|
+
// }
|
525
|
+
}
|
526
|
+
onFocus() {
|
527
|
+
// let editor = document.getElementById('editor');
|
528
|
+
// if (editor && this.isPlaceholderVisible) {
|
529
|
+
// editor.innerHTML = '';
|
530
|
+
// this.isPlaceholderVisible = false;
|
531
|
+
// }
|
532
|
+
}
|
533
|
+
// colorChange(newColor: string) {
|
534
|
+
// this.color = newColor;
|
535
|
+
// }
|
536
|
+
onBlur() {
|
537
|
+
this.checkPlaceholder();
|
538
|
+
}
|
539
|
+
addRow() {
|
540
|
+
if (this.selectedTable) {
|
541
|
+
let row = this.selectedTable.insertRow();
|
542
|
+
for (let i = 0; i < this.selectedTable.rows[0].cells.length; i++) {
|
543
|
+
let cell = row.insertCell(i);
|
544
|
+
cell.innerHTML = ' ';
|
545
|
+
cell.style.border = '1px solid black';
|
546
|
+
}
|
547
|
+
}
|
548
|
+
}
|
549
|
+
// deleteRow() {
|
550
|
+
// if (this.selectedTable) {
|
551
|
+
// this.selectedTable.deleteRow(-1);
|
552
|
+
// }
|
553
|
+
// }
|
554
|
+
// deleteRow() {
|
555
|
+
// if (this.selectedTable) {
|
556
|
+
// let rowIndex = this.selectedTable.rows.length - 1;
|
557
|
+
// if (window.getSelection) {
|
558
|
+
// let selection = window.getSelection();
|
559
|
+
// if (selection) {
|
560
|
+
// let row = selection.anchorNode?.parentElement?.closest('tr');
|
561
|
+
// if (row) {
|
562
|
+
// rowIndex = row.rowIndex;
|
563
|
+
// }
|
564
|
+
// }
|
565
|
+
// }
|
566
|
+
// this.selectedTable.deleteRow(rowIndex);
|
567
|
+
// }
|
568
|
+
// }
|
569
|
+
deleteRow() {
|
570
|
+
const selection = window.getSelection();
|
571
|
+
if (selection) {
|
572
|
+
if (!selection.rangeCount)
|
573
|
+
return;
|
574
|
+
const range = selection.getRangeAt(0);
|
575
|
+
const selectedNode = range.startContainer;
|
576
|
+
const row = selectedNode.parentElement?.closest('tr');
|
577
|
+
if (row) {
|
578
|
+
const table = row.closest('table');
|
579
|
+
if (table) {
|
580
|
+
table.deleteRow(row.rowIndex);
|
581
|
+
}
|
582
|
+
}
|
583
|
+
}
|
584
|
+
}
|
585
|
+
// addColumn() {
|
586
|
+
// if (this.selectedTable) {
|
587
|
+
// for (let i = 0; i < this.selectedTable.rows.length; i++) {
|
588
|
+
// let cell = this.selectedTable.rows[i].insertCell(-1);
|
589
|
+
// cell.innerHTML = ' ';
|
590
|
+
// cell.style.border = '1px solid black';
|
591
|
+
// }
|
592
|
+
// }
|
593
|
+
// }
|
594
|
+
addColumn() {
|
595
|
+
if (this.selectedTable) {
|
596
|
+
const columnCount = this.selectedTable.rows[0].cells.length + 1; // New column count
|
597
|
+
const tableWidth = this.selectedTable.offsetWidth;
|
598
|
+
const minWidth = tableWidth / columnCount;
|
599
|
+
for (let i = 0; i < this.selectedTable.rows.length; i++) {
|
600
|
+
let cell = this.selectedTable.rows[i].insertCell(-1);
|
601
|
+
cell.innerHTML = ' ';
|
602
|
+
cell.style.border = '1px solid black';
|
603
|
+
cell.style.minWidth = `${minWidth}px`;
|
604
|
+
cell.style.wordWrap = 'break-word';
|
605
|
+
cell.style.wordBreak = 'break-all';
|
606
|
+
cell.style.whiteSpace = 'normal';
|
607
|
+
}
|
608
|
+
// Update existing cells' minWidth
|
609
|
+
for (let i = 0; i < this.selectedTable.rows.length; i++) {
|
610
|
+
for (let j = 0; j < this.selectedTable.rows[i].cells.length; j++) {
|
611
|
+
this.selectedTable.rows[i].cells[j].style.minWidth = `${minWidth}px`;
|
612
|
+
}
|
613
|
+
}
|
614
|
+
}
|
615
|
+
}
|
616
|
+
deleteColumn() {
|
617
|
+
if (this.selectedTable) {
|
618
|
+
if (window.getSelection) {
|
619
|
+
let selection = window.getSelection();
|
620
|
+
if (selection) {
|
621
|
+
let cell = selection.anchorNode?.parentElement?.closest('td, th');
|
622
|
+
if (cell) {
|
623
|
+
let cellIndex = cell.cellIndex;
|
624
|
+
for (let i = 0; i < this.selectedTable.rows.length; i++) {
|
625
|
+
this.selectedTable.rows[i].deleteCell(cellIndex);
|
626
|
+
}
|
627
|
+
}
|
628
|
+
}
|
629
|
+
}
|
630
|
+
}
|
631
|
+
}
|
632
|
+
// deleteColumn() {
|
633
|
+
// if (this.selectedTable) {
|
634
|
+
// for (let i = 0; i < this.selectedTable.rows.length; i++) {
|
635
|
+
// this.selectedTable.rows[i].deleteCell(-1);
|
636
|
+
// }
|
637
|
+
// }
|
638
|
+
// }
|
639
|
+
adjustTableWidth(event) {
|
640
|
+
if (this.selectedTable) {
|
641
|
+
this.selectedTable.style.width = event.target.value + 'px';
|
642
|
+
}
|
643
|
+
}
|
644
|
+
adjustCellWidth(event) {
|
645
|
+
if (this.selectedTable) {
|
646
|
+
for (let i = 0; i < this.selectedTable.rows.length; i++) {
|
647
|
+
for (let j = 0; j < this.selectedTable.rows[i].cells.length; j++) {
|
648
|
+
this.selectedTable.rows[i].cells[j].style.width = event.target.value + 'px';
|
649
|
+
}
|
650
|
+
}
|
651
|
+
}
|
652
|
+
}
|
653
|
+
adjustCellHeight(event) {
|
654
|
+
if (this.selectedTable) {
|
655
|
+
for (let i = 0; i < this.selectedTable.rows.length; i++) {
|
656
|
+
for (let j = 0; j < this.selectedTable.rows[i].cells.length; j++) {
|
657
|
+
this.selectedTable.rows[i].cells[j].style.height = event.target.value + 'px';
|
658
|
+
}
|
659
|
+
}
|
660
|
+
}
|
661
|
+
}
|
662
|
+
setCaretToEnd(element) {
|
663
|
+
const range = document.createRange();
|
664
|
+
const sel = window.getSelection();
|
665
|
+
if (sel) {
|
666
|
+
range.selectNodeContents(element);
|
667
|
+
range.collapse(false);
|
668
|
+
sel.removeAllRanges();
|
669
|
+
sel.addRange(range);
|
670
|
+
}
|
671
|
+
}
|
672
|
+
openColorPicker(inputId) {
|
673
|
+
const inputElement = document.getElementById(inputId);
|
674
|
+
if (inputElement) {
|
675
|
+
inputElement.click();
|
676
|
+
}
|
677
|
+
}
|
678
|
+
setTextColor(event, editorId) {
|
679
|
+
const editor = document.getElementById(editorId);
|
680
|
+
if (editor) {
|
681
|
+
editor.focus();
|
682
|
+
const color = event.color.hex;
|
683
|
+
this.selectedTextColor = color;
|
684
|
+
document.execCommand('foreColor', true, color);
|
685
|
+
if (this.dropdown) {
|
686
|
+
this.dropdown.close();
|
687
|
+
}
|
688
|
+
}
|
689
|
+
}
|
690
|
+
setBackgroundColor(event, editorId) {
|
691
|
+
const editor = document.getElementById(editorId);
|
692
|
+
if (editor) {
|
693
|
+
editor.focus();
|
694
|
+
const color = event.color.hex;
|
695
|
+
this.backgroundColor = color;
|
696
|
+
document.execCommand('hiliteColor', true, color);
|
697
|
+
if (this.dropdown) {
|
698
|
+
this.dropdown.close();
|
699
|
+
}
|
700
|
+
}
|
701
|
+
}
|
702
|
+
// colorChanged(event: any) {
|
703
|
+
// this.color = event.color.hex;
|
704
|
+
// }
|
705
|
+
logEvent(event, trigger) {
|
706
|
+
const color = event;
|
707
|
+
this.setTextColor(color, this.editorId);
|
708
|
+
this.selectedTextColor = event;
|
709
|
+
document.execCommand('foreColor', false, event);
|
710
|
+
// this.logs.unshift([this.logs.length + 1, trigger, event]);
|
711
|
+
}
|
712
|
+
editImage() {
|
713
|
+
let data;
|
714
|
+
switch (this.editorFrom) {
|
715
|
+
case 'section-content':
|
716
|
+
data = { editIMG: true, from: 'htmlEditor', index: this.selectedItemIndex };
|
717
|
+
this.navigateToIMGEditor(data);
|
718
|
+
sessionStorage.setItem('editImageFromTemp', JSON.stringify(this.imageEditUrl));
|
719
|
+
sessionStorage.setItem('textEditor', this.editorText);
|
720
|
+
break;
|
721
|
+
case 'template':
|
722
|
+
data = { editIMG: true, from: 'templateEditor', index: this.selectedItemIndex };
|
723
|
+
this.navigateToIMGEditor(data);
|
724
|
+
// sessionStorage.setItem('editImageFromTemp2', JSON.stringify(this.imageEditUrl));
|
725
|
+
sessionStorage.setItem('templateEditor', this.editorText);
|
726
|
+
break;
|
727
|
+
default:
|
728
|
+
sessionStorage.removeItem('editImageFromTemp');
|
729
|
+
// sessionStorage.removeItem('editImageFromTemp2');
|
730
|
+
sessionStorage.removeItem('templateEditor');
|
731
|
+
sessionStorage.removeItem('textEditor');
|
732
|
+
break;
|
733
|
+
}
|
734
|
+
// if (this.editorFrom === 'section-content') {
|
735
|
+
// const data = {editIMG: true, from: 'htmlEditor', index: this.selectedItemIndex}
|
736
|
+
// this.navigateToIMGEditor(data)
|
737
|
+
// sessionStorage.setItem('editImageFromTemp', JSON.stringify(this.imageEditUrl))
|
738
|
+
// sessionStorage.setItem('textEditor', this.editorText)
|
739
|
+
// }
|
740
|
+
}
|
741
|
+
navigateToIMGEditor(data) {
|
742
|
+
this.router.navigate(['/admin/image-editor'], { queryParams: { data: JSON.stringify(data) } });
|
743
|
+
}
|
744
|
+
// onTextSelect(event: MouseEvent): void {
|
745
|
+
// if (this.toolbarMode === 'bubble') {
|
746
|
+
// const selection = window.getSelection();
|
747
|
+
// if (selection && selection.rangeCount > 0) {
|
748
|
+
// const range = selection.getRangeAt(0);
|
749
|
+
// if (!range.collapsed) {
|
750
|
+
// const rect = range.getBoundingClientRect();
|
751
|
+
// this.toolbarTop = rect.bottom + window.scrollY + 10;
|
752
|
+
// this.toolbarLeft = rect.left + window.scrollX + (rect.width / 2) - 50;
|
753
|
+
// this.showToolbar = true;
|
754
|
+
// } else {
|
755
|
+
// this.showToolbar = false;
|
756
|
+
// }
|
757
|
+
// }
|
758
|
+
// }
|
759
|
+
// }
|
760
|
+
onTextSelect(event) {
|
761
|
+
if (this.toolbarMode === 'bubble') {
|
762
|
+
const selection = window.getSelection();
|
763
|
+
if (selection && selection.rangeCount > 0) {
|
764
|
+
const range = selection.getRangeAt(0);
|
765
|
+
if (!range.collapsed) {
|
766
|
+
const rect = range.getBoundingClientRect();
|
767
|
+
const scrollY = document.documentElement.scrollTop;
|
768
|
+
const scrollX = document.documentElement.scrollLeft;
|
769
|
+
this.toolbarTop = rect.top + scrollY - 75;
|
770
|
+
this.toolbarLeft = rect.left + scrollX + (rect.width / 2) - 325;
|
771
|
+
this.showToolbar = true;
|
772
|
+
}
|
773
|
+
else {
|
774
|
+
this.showToolbar = false;
|
775
|
+
}
|
776
|
+
}
|
777
|
+
else {
|
778
|
+
this.showToolbar = false;
|
779
|
+
}
|
780
|
+
}
|
781
|
+
}
|
782
|
+
onPaste(event) {
|
783
|
+
event.preventDefault();
|
784
|
+
const clipboardData = event.clipboardData;
|
785
|
+
if (clipboardData) {
|
786
|
+
const pastedText = clipboardData.getData('text/plain');
|
787
|
+
if (this.isTableData(pastedText)) {
|
788
|
+
const html = this.convertTextToTable(pastedText);
|
789
|
+
this.insertHtmlAtCaret(html);
|
790
|
+
}
|
791
|
+
else {
|
792
|
+
this.insertHtmlAtCaret(pastedText);
|
793
|
+
}
|
794
|
+
}
|
795
|
+
}
|
796
|
+
isTableData(text) {
|
797
|
+
const rows = text.split('\n');
|
798
|
+
return rows.length > 1 && rows[0].split('\t').length > 1;
|
799
|
+
}
|
800
|
+
convertTextToTable(text) {
|
801
|
+
const rows = text.split('\n').filter(row => row.trim() !== '');
|
802
|
+
const tableRows = rows.map(row => {
|
803
|
+
const cells = row.split('\t').map(cell => `<td class="px-1 py-1 style="border: 1px solid #000">${cell}</td>`).join('');
|
804
|
+
return `<tr >${cells}</tr>`;
|
805
|
+
}).join('');
|
806
|
+
return `<table>${tableRows}</table>`;
|
807
|
+
}
|
808
|
+
insertHtmlAtCaret(html) {
|
809
|
+
const range = window.getSelection()?.getRangeAt(0);
|
810
|
+
if (range) {
|
811
|
+
range.deleteContents();
|
812
|
+
const tempDiv = document.createElement('div');
|
813
|
+
tempDiv.innerHTML = html;
|
814
|
+
const frag = document.createDocumentFragment();
|
815
|
+
let node;
|
816
|
+
while ((node = tempDiv.firstChild)) {
|
817
|
+
frag.appendChild(node);
|
818
|
+
}
|
819
|
+
range.insertNode(frag);
|
820
|
+
range.collapse(false);
|
821
|
+
}
|
822
|
+
}
|
823
|
+
openFullscreen() {
|
824
|
+
var elem = document.getElementById("textEditor");
|
825
|
+
this.isFullScreen = true;
|
826
|
+
if (elem.requestFullscreen) {
|
827
|
+
elem.requestFullscreen();
|
828
|
+
}
|
829
|
+
else if (elem.mozRequestFullScreen) {
|
830
|
+
elem.mozRequestFullScreen();
|
831
|
+
}
|
832
|
+
else if (elem.webkitRequestFullscreen) {
|
833
|
+
elem.webkitRequestFullscreen();
|
834
|
+
}
|
835
|
+
else if (elem.msRequestFullscreen) {
|
836
|
+
elem.msRequestFullscreen();
|
837
|
+
}
|
838
|
+
this.style = {
|
839
|
+
'min-height': '90vh',
|
840
|
+
'max-height': '90vh',
|
841
|
+
};
|
842
|
+
}
|
843
|
+
closeFullscreen() {
|
844
|
+
if (document.exitFullscreen) {
|
845
|
+
document.exitFullscreen();
|
846
|
+
this.isFullScreen = false;
|
847
|
+
this.style = {
|
848
|
+
'min-height': '400px',
|
849
|
+
'max-height': '400px',
|
850
|
+
};
|
851
|
+
}
|
852
|
+
}
|
853
|
+
openCanvasColorPicker(inputId) {
|
854
|
+
const inputElement = document.getElementById(inputId);
|
855
|
+
if (inputElement) {
|
856
|
+
inputElement.click();
|
857
|
+
}
|
858
|
+
}
|
859
|
+
setCanvasBackgroundColor(event, editorId) {
|
860
|
+
this.CanvasColor = event.color.hex;
|
861
|
+
const editor = document.getElementById(editorId);
|
862
|
+
if (editor) {
|
863
|
+
let color = '';
|
864
|
+
console.log('event bg color = ', event);
|
865
|
+
editor.style.backgroundColor = '#fff';
|
866
|
+
color = event.color.hex || event;
|
867
|
+
editor.style.backgroundColor = color;
|
868
|
+
this.mainCanvas();
|
869
|
+
// this.init_Func(`<div style="background-color: ${color};">${this.editorText}</div>`);
|
870
|
+
if (this.dropdown) {
|
871
|
+
this.dropdown.close();
|
872
|
+
}
|
873
|
+
}
|
874
|
+
}
|
875
|
+
getToday() {
|
876
|
+
const currentDate = new Date();
|
877
|
+
const day = currentDate.getDate();
|
878
|
+
const month = currentDate.getMonth() + 1;
|
879
|
+
const year = currentDate.getFullYear();
|
880
|
+
const formattedDate = `${year}-${month.toString().padStart(2, '0')}-${day.toString().padStart(2, '0')}`;
|
881
|
+
this.today = formattedDate;
|
882
|
+
// const label = `{(${this.today})}`;
|
883
|
+
const label = `{(date)}`;
|
884
|
+
const htmlContent = ` ${label} `;
|
885
|
+
const editor = document.getElementById(this.editorId);
|
886
|
+
if (editor) {
|
887
|
+
this.editorText += `<div> ${htmlContent} </div>`;
|
888
|
+
this.sanitizedContent = this.editorText;
|
889
|
+
}
|
890
|
+
else {
|
891
|
+
this.editorText += `<div> ${htmlContent} </div>`;
|
892
|
+
this.sanitizedContent = this.editorText;
|
893
|
+
}
|
894
|
+
}
|
895
|
+
insertPageNumber() {
|
896
|
+
const pageNumber = '{(page)}';
|
897
|
+
const editor = document.getElementById(this.editorId);
|
898
|
+
if (editor) {
|
899
|
+
this.editorText += `<div> ${pageNumber} </div>`;
|
900
|
+
this.sanitizedContent = this.editorText;
|
901
|
+
}
|
902
|
+
else {
|
903
|
+
this.editorText += `<div> ${pageNumber} </div>`;
|
904
|
+
this.sanitizedContent = this.editorText;
|
905
|
+
}
|
906
|
+
}
|
907
|
+
clearTextEditor() {
|
908
|
+
const editor = document.getElementById(this.editorId);
|
909
|
+
if (editor) {
|
910
|
+
this.editorTextClear.emit();
|
911
|
+
let data;
|
912
|
+
// data.color.hex = '#ffffff'
|
913
|
+
data = {
|
914
|
+
color: {
|
915
|
+
hex: '#353343'
|
916
|
+
}
|
917
|
+
};
|
918
|
+
editor.innerHTML = '';
|
919
|
+
this.setCanvasBackgroundColor(data, this.editorId);
|
920
|
+
}
|
921
|
+
}
|
922
|
+
setupHistory() {
|
923
|
+
this.saveState();
|
924
|
+
const editor = document.getElementById(this.editorId);
|
925
|
+
if (editor) {
|
926
|
+
editor.addEventListener('input', () => this.onInput());
|
927
|
+
}
|
928
|
+
}
|
929
|
+
onInput() {
|
930
|
+
this.saveState();
|
931
|
+
}
|
932
|
+
saveState() {
|
933
|
+
const editor = document.getElementById(this.editorId);
|
934
|
+
if (editor) {
|
935
|
+
const editorContent = editor.innerHTML;
|
936
|
+
if (this.historyIndex === this.history.length - 1) {
|
937
|
+
this.history.push(editorContent);
|
938
|
+
this.redoStack = [];
|
939
|
+
}
|
940
|
+
else {
|
941
|
+
this.history = this.history.slice(0, this.historyIndex + 1);
|
942
|
+
this.history.push(editorContent);
|
943
|
+
this.redoStack = [];
|
944
|
+
}
|
945
|
+
this.historyIndex++;
|
946
|
+
}
|
947
|
+
}
|
948
|
+
undo() {
|
949
|
+
if (this.historyIndex > 0) {
|
950
|
+
this.redoStack.push(this.history[this.historyIndex]);
|
951
|
+
this.historyIndex--;
|
952
|
+
const editor = document.getElementById(this.editorId);
|
953
|
+
if (editor) {
|
954
|
+
this.sanitizedContent = this.history[this.historyIndex];
|
955
|
+
}
|
956
|
+
}
|
957
|
+
}
|
958
|
+
redo() {
|
959
|
+
if (this.redoStack.length > 0) {
|
960
|
+
const redoContent = this.redoStack.pop();
|
961
|
+
this.history.push(redoContent);
|
962
|
+
this.historyIndex++;
|
963
|
+
const editor = document.getElementById(this.editorId);
|
964
|
+
if (editor) {
|
965
|
+
this.sanitizedContent = redoContent;
|
966
|
+
}
|
967
|
+
}
|
968
|
+
}
|
969
|
+
mainCanvas(data) {
|
970
|
+
let BG = '';
|
971
|
+
const editor = document.getElementById(this.editorId);
|
972
|
+
if (editor) {
|
973
|
+
editor.focus();
|
974
|
+
if (editor.style.backgroundColor === 'rgb(53, 51, 67)') {
|
975
|
+
BG = 'rgb(255, 255, 255)';
|
976
|
+
}
|
977
|
+
else {
|
978
|
+
BG = editor.style.backgroundColor;
|
979
|
+
}
|
980
|
+
return `<div style="background-color: ${BG}; padding: 10px 15px;">${data}</div>`;
|
981
|
+
}
|
982
|
+
else {
|
983
|
+
return `<div>${data}</div>`;
|
984
|
+
}
|
985
|
+
}
|
986
|
+
themeMode() {
|
987
|
+
const clrMode = document.body.getAttribute('data-layout-color');
|
988
|
+
if (clrMode == 'dark') {
|
989
|
+
return '2px solid #414141 !important';
|
990
|
+
}
|
991
|
+
else {
|
992
|
+
return '2px solid #D0D0D0 !important';
|
993
|
+
}
|
994
|
+
}
|
995
|
+
themeModeClr() {
|
996
|
+
const clrMode = document.body.getAttribute('data-layout-color');
|
997
|
+
if (clrMode == 'dark') {
|
998
|
+
return '#fff !important';
|
999
|
+
}
|
1000
|
+
else {
|
1001
|
+
return '#000 !important';
|
1002
|
+
}
|
1003
|
+
}
|
1004
|
+
}
|
1005
|
+
ElHeaderAndFooterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.4", ngImport: i0, type: ElHeaderAndFooterComponent, deps: [{ token: i1.Router }, { token: i1.ActivatedRoute }, { token: i0.Renderer2 }, { token: i2.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component });
|
1006
|
+
ElHeaderAndFooterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.4", type: ElHeaderAndFooterComponent, selector: "el-header-and-footer", inputs: { editorId: "editorId", editorText: "editorText", editorFrom: "editorFrom", clear: "clear", editorAction: "editorAction", style: "style", bgColor: "bgColor", toolbarMode: "toolbarMode", value: "value" }, outputs: { editorTextChange: "editorTextChange", editorActionResponse: "editorActionResponse", editorTextClear: "editorTextClear" }, providers: [{
|
1007
|
+
provide: NG_VALUE_ACCESSOR,
|
1008
|
+
useExisting: forwardRef(() => ElHeaderAndFooterComponent),
|
1009
|
+
multi: true
|
1010
|
+
}], viewQueries: [{ propertyName: "dropdown", first: true, predicate: NgbDropdown, descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"container els-text-editor px-0\">\r\n <div class=\"btn-toolbar els-btn-toolbar p-2 py-2 mb-0\" role=\"toolbar\" [id]=\"editorId+'toolbar'\"\r\n aria-label=\"Toolbar with button groups\">\r\n <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Header Options\">\r\n <!-- <div class=\"dropdown\">\r\n <select class=\"els-form-select \" style=\" font-weight: 700 !important; color: #fff; width: 150px; border: 2px solid #7D6D6D !important;\" (change)=\"onFormatChange($event)\">\r\n <option [value]=\"'<h1>'\">Heading 1</option>\r\n <option [value]=\"'<h2>'\">Heading 2</option>\r\n <option [value]=\"'<h3>'\">Heading 3</option>\r\n <option [value]=\"'<h4>'\">Heading 4</option>\r\n <option [value]=\"'<h5>'\">Heading 5</option>\r\n <option [value]=\"'<h6>'\">Heading 6</option>\r\n <option selected [value]=\"'<p>'\">Normal</option>\r\n </select>\r\n </div> -->\r\n <div ngbDropdown class=\"dropdown\">\r\n <button class=\"btn btn-sm els-form-select border els-toolbar-dropdown-button dropdown-toggle text-start\"\r\n [style.border]=\"themeMode()\" [style.color]=\"themeModeClr()\"\r\n id=\"headerDropdown\" ngbDropdownToggle>\r\n <span style=\"width: 85px; font-weight: 700 !important;\">{{selectedFormatBlock | titlecase}}</span>\r\n <i class=\"mdi mdi-chevron-down \"></i>\r\n </button>\r\n <div ngbDropdownMenu aria-labelledby=\"headerDropdown\" class=\"els-text-format\">\r\n <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"onFormatChange('<h1>')\" [style.color]=\"themeModeClr()\">\r\n <h1>Heading 1</h1>\r\n </button>\r\n <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"onFormatChange('<h2>')\" [style.color]=\"themeModeClr()\">\r\n <h2>Heading 2</h2>\r\n </button>\r\n <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"onFormatChange('<h3>')\" [style.color]=\"themeModeClr()\">\r\n <h3>Heading 3</h3>\r\n </button>\r\n <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"onFormatChange('<h4>')\" [style.color]=\"themeModeClr()\">\r\n <h4>Heading 4</h4>\r\n </button>\r\n <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"onFormatChange('<h5>')\" [style.color]=\"themeModeClr()\">\r\n <h5>Heading 5</h5>\r\n </button>\r\n <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"onFormatChange('<h6>')\" [style.color]=\"themeModeClr()\">\r\n <h6>Heading 6</h6>\r\n </button>\r\n <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"onFormatChange('<p>')\" [style.color]=\"themeModeClr()\">\r\n <p>Normal</p>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"btn-group els-button-group\" role=\"group\" aria-label=\"Font Options\">\r\n <div ngbDropdown class=\"dropdown\">\r\n <button class=\"btn btn-sm els-form-select border els-toolbar-dropdown-button dropdown-toggle text-start\"\r\n id=\"headerDropdown\" [style.border]=\"themeMode()\" [style.color]=\"themeModeClr()\" ngbDropdownToggle>\r\n <span style=\"width: 85px; font-weight: 700 !important;\" class=\"text-truncate\">{{selectedFont |\r\n titlecase}}</span>\r\n <i class=\"mdi mdi-chevron-down \"></i>\r\n </button>\r\n <div ngbDropdownMenu aria-labelledby=\"headerDropdown\" class=\"els-text-format\">\r\n <button class=\"dropdown-item pb-0\" type=\"button\" *ngFor=\"let font of fonts\"\r\n (click)=\"changeFont(font)\">\r\n <span>{{ font }}</span>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"border py-0\" [style.border]=\"themeMode()\" style=\"height: fit-content;\">\r\n <div class=\"btn-group els-button-group mr-2 \" role=\"group\" aria-label=\"Text Formatting\">\r\n <button type=\"button\" class=\"btn btn-sm els-toolbar-button\" [class.active]=\"isBoldActive\"\r\n (click)=\"format('bold', editorId)\">\r\n <i class=\"mdi mdi-format-bold\"></i>\r\n </button>\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\" [class.active]=\"isItalicActive\"\r\n (click)=\"format('italic', editorId)\">\r\n <i class=\"mdi mdi-format-italic\"></i>\r\n </button>\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\" [class.active]=\"isUnderlineActive\"\r\n (click)=\"format('underline', editorId)\">\r\n <i class=\"mdi mdi-format-underline\"></i>\r\n </button>\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\" [class.active]=\"isStrikethroughActive\"\r\n (click)=\"format('strikethrough', editorId)\">\r\n <i class=\"mdi mdi-format-strikethrough-variant\"></i>\r\n </button>\r\n <div class=\"btn-group\" role=\"group\" aria-label=\"Text Color\">\r\n <!-- <input type=\"color\" id=\"textColorPicker\"\r\n style=\"position: absolute; top: 100%; left: 0; z-index: 100; opacity: 0;\"\r\n (change)=\"setTextColor($event)\">\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\" style=\"position: relative;\"\r\n (click)=\"openColorPicker('textColorPicker')\">\r\n <i class=\"mdi mdi-format-color-text icon-with-underline\" [style.color]=\"selectedTextColor\"></i>\r\n </button> -->\r\n <div ngbDropdown class=\"ql-align\">\r\n <button type=\"button\"\r\n class=\"btn btn-outline-primary els-toolbar-button arrow-none text-secondary border-none p-0\"\r\n id=\"dropdownBasic1\" aria-expanded=\"false\" ngbDropdownToggle>\r\n <i class=\"mdi mdi-format-color-text icon-with-underline\"\r\n [style.color]=\"selectedTextColor ?? '#000'\"></i>\r\n </button>\r\n <div ngbDropdownMenu aria-labelledby=\"dropdownBasic1\" style=\"width: 200px;\">\r\n <color-sketch color=\"#fff\" [presetColors]=\"[]\"\r\n (onChangeComplete)=\"setTextColor($event, editorId)\"></color-sketch>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"btn-group\" role=\"group\" aria-label=\"Background Color\" style=\"position: relative;\">\r\n <!-- <button type=\"button\" class=\"btn btn-white els-toolbar-button\" [style.color]=\"backgroundColor\"\r\n (click)=\"openColorPicker('bgColorPicker')\">\r\n <i class=\"mdi mdi-alpha-a-box\"></i>\r\n </button>\r\n <input type=\"color\" id=\"bgColorPicker\"\r\n style=\"position: absolute; top: 100%; left: 0; z-index: 100; opacity: 0;\"\r\n (change)=\"setBackgroundColor($event)\"> -->\r\n <div ngbDropdown class=\"ql-align\">\r\n <button type=\"button\"\r\n class=\"btn btn-outline-primary els-toolbar-button arrow-none text-secondary border-none p-0\"\r\n id=\"dropdownBasic1\" aria-expanded=\"false\" ngbDropdownToggle>\r\n <i class=\"mdi mdi-alpha-a-box\" [style.color]=\"backgroundColor ?? '#000'\"></i>\r\n </button>\r\n <div ngbDropdownMenu aria-labelledby=\"dropdownBasic1\" style=\"width: 200px;\">\r\n <color-sketch color=\"#fff\" [presetColors]=\"[]\"\r\n (onChangeComplete)=\"setBackgroundColor($event, editorId)\"></color-sketch>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Text Formatting\">\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\"\r\n (click)=\"format('insertOrderedList', editorId)\"><i\r\n class=\"mdi mdi-format-list-numbered\"></i></button>\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\"\r\n (click)=\"format('insertUnorderedList', editorId)\"><i\r\n class=\"mdi mdi-format-list-bulleted\"></i></button>\r\n <div ngbDropdown class=\"ql-align\">\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button arrow-none text-secondary\"\r\n id=\"dropdownBasic1\" aria-expanded=\"false\" ngbDropdownToggle>\r\n <i class=\"mdi mdi-format-align-left \"></i>\r\n </button>\r\n <div ngbDropdownMenu aria-labelledby=\"dropdownBasic1\" style=\"width: 3px;\">\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\" style=\"color: #7A7982;\"\r\n (click)=\"format('justifyLeft', editorId)\"><i class=\"mdi mdi-format-align-left\"></i></button>\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\" style=\"color: #7A7982;\"\r\n (click)=\"format('justifyCenter', editorId)\"><i\r\n class=\"mdi mdi-format-align-center\"></i></button>\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\" style=\"color: #7A7982;\"\r\n (click)=\"format('justifyRight', editorId)\"><i\r\n class=\"mdi mdi-format-align-right\"></i></button>\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\" style=\"color: #7A7982;\"\r\n (click)=\"format('justifyFull', editorId)\"><i\r\n class=\"mdi mdi-format-align-justify\"></i></button>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Text Formatting\">\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\" [class.active]=\"isSubscriptActive\"\r\n (click)=\"format('subscript', editorId)\">\r\n <i class=\"mdi mdi-format-subscript\"></i>\r\n </button>\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\" [class.active]=\"isSuperscriptActive\"\r\n (click)=\"format('superscript', editorId)\">\r\n <i class=\"mdi mdi-format-superscript\"></i>\r\n </button>\r\n\r\n </div>\r\n <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Table Options\">\r\n\r\n <div ngbDropdown class=\"ql-align\">\r\n <button type=\"button\" class=\"btn btn-outline-primary arrow-none els-toolbar-button border-none p-0\"\r\n id=\"dropdownBasic1\" aria-expanded=\"false\" ngbDropdownToggle>\r\n <i class=\"mdi mdi-format-color-fill\"></i>\r\n </button>\r\n <div ngbDropdownMenu aria-labelledby=\"dropdownBasic1\" style=\"width: 200px;\">\r\n <color-sketch color=\"#fff\"\r\n (onChangeComplete)=\"setCanvasBackgroundColor($event, editorId)\"></color-sketch>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n <div class=\"btn-group els-button-group-2 mr-3\" role=\"group\" aria-label=\"Table Options\">\r\n <button class=\"btn btn-white px-1\" style=\"height: 24px;\" (click)=\"getToday()\">Date</button>\r\n </div>\r\n <div class=\"btn-group els-button-group-2\" role=\"group\" aria-label=\"Table Options\">\r\n <button class=\"btn btn-white px-1\" style=\"height: 24px;\" (click)=\"insertPageNumber()\">Page\r\n No</button>\r\n\r\n </div>\r\n <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Text Formatting\">\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"addLink()\"><i\r\n class=\"mdi mdi-link-variant\"></i></button>\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"insertsImage(editorId)\"><i\r\n class=\"mdi mdi-image\"></i></button>\r\n <input type=\"file\" id=\"imageInput\" style=\"display: none;\" (change)=\"handleImageUpload($event)\">\r\n\r\n </div>\r\n <!-- <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Table Options\">\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"addTable()\"><i\r\n class=\"mdi mdi-table\"></i></button>\r\n <button *ngIf=\"isTableSelected\" type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"addRow()\"><i\r\n class=\"mdi mdi-table-row-plus-after\"></i></button>\r\n <button *ngIf=\"isTableSelected\" type=\"button\" class=\"btn btn-white els-toolbar-button\"\r\n (click)=\"deleteRow()\"><i class=\"mdi mdi-table-row-remove\"></i></button>\r\n <button *ngIf=\"isTableSelected\" type=\"button\" class=\"btn btn-white els-toolbar-button\"\r\n (click)=\"addColumn()\"><i class=\"mdi mdi-table-column-plus-after\"></i></button>\r\n <button *ngIf=\"isTableSelected\" type=\"button\" class=\"btn btn-white els-toolbar-button\"\r\n (click)=\"deleteColumn()\"><i class=\"mdi mdi-table-column-remove\"></i></button>\r\n </div>\r\n <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Table Options\">\r\n <button *ngIf=\"selectedImage\" class=\"btn btn-white els-toolbar-button-2\" (click)=\"editImage()\"\r\n style=\"position: absolute;\">Edit Image</button>\r\n </div> -->\r\n <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Text Formatting\">\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"undo()\">\r\n <i class=\"mdi mdi-undo\"></i>\r\n </button>\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"redo()\">\r\n <i class=\"mdi mdi-redo\"></i>\r\n </button>\r\n\r\n </div>\r\n <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Table Options\">\r\n <!-- <button *ngIf=\"selectedImage\" class=\"btn btn-white els-toolbar-button-2\" (click)=\"editImage()\"\r\n style=\"position: absolute;\">Edit Image</button> -->\r\n <button class=\"btn btn-white els-toolbar-button\" (click)=\"clearTextEditor()\">\r\n <i class=\"mdi mdi-close-circle\"></i>\r\n </button>\r\n </div>\r\n\r\n </div>\r\n </div>\r\n\r\n\r\n <div contenteditable=\"true\" [id]=\"editorId\" class=\"els-border p-3\" #editor\r\n style=\"position: relative !important; height: 130px; max-width: 100%; overflow: hidden; \"\r\n [ngStyle]=\"{'font-family': selectedFont, 'font-size': selectedFontSize + 'px'}\" [style]=\"style\"\r\n contenteditable=\"true\" (input)=\"onModelChange($event)\" placeholder=\"Insert text here ...\"\r\n (mouseup)=\"onTextSelect($event)\" [innerHTML]=\"sanitizedContent\" (paste)=\"onPaste($event)\" (focus)=\"onFocus()\"\r\n (blur)=\"onBlur()\" (click)=\"checkTableSelection($event)\">\r\n </div>\r\n <table *ngIf=\"parsedTable\">\r\n <thead>\r\n <tr>\r\n <th *ngFor=\"let header of parsedTable.headers\">{{ header }}</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let row of parsedTable.rows\">\r\n <td *ngFor=\"let cell of row\">{{ cell }}</td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n</div>", styles: ["*{font-family:Noto Sans Telugu UI,sans-serif}#editor{min-height:125px;max-height:125px;overflow-y:auto}#editor img{max-width:100%;height:auto}.bubble-toolbar{position:absolute;background-color:#fff;border:1px solid #ddd;border-radius:4px;box-shadow:0 2px 5px #00000026;z-index:1000;display:none}.els-text-editor{box-sizing:border-box}.els-btn-toolbar{width:\"1028px\"}.els-toolbar-button{background:none;border:none;cursor:pointer;display:inline-block;float:left;height:24px;padding:3px 5px;width:28px}.els-toolbar-button-2{background:none;border:none;cursor:pointer;display:inline-block;float:left;height:24px;padding:3px 5px;width:100px}.els-toolbar-dropdown-button{background:none;border:none;cursor:pointer;display:inline-block;float:left;height:24px;padding:3px 5px;color:#fff}.els-toolbar-dropdown-button:focus{outline:none}.els-form-select{cursor:pointer;display:inline-block;height:100%;padding:2px 5px 2px 8px;position:relative;width:100%;border:none;background-color:#fff;color:#6c757d}.els-button-group{margin-right:15px}.els-form-select:focus{outline:none}.els-border{border:#353343}.els-border:focus{outline:none}.els-dropdown-item{width:50px!important}.els-toolbar-button.active,.btn-toolbar .btn.active,.btn-toolbar .btn:hover{color:#06c}.dropdown-toggle:after{display:none}.table-container{overflow-x:auto;width:100%}table{width:100%;max-width:100%;margin-bottom:1rem;background-color:transparent;border-collapse:collapse;table-layout:fixed}table td,table th{padding:.75rem;vertical-align:top;border:1px solid #dee2e6;word-wrap:break-word}@media (max-width: 576px){table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;border-spacing:0}table thead,table tbody,table tr,table th,table td{display:block}table thead tr{position:absolute;top:-9999px;left:-9999px}table tr{margin-bottom:.625rem;border:1px solid #ccc}table td,table th{border:none;border-bottom:1px solid #ddd;position:relative;padding-left:50%;white-space:normal;text-align:left}table td:before,table th:before{position:absolute;top:.75rem;left:.75rem;width:45%;padding-right:.75rem;white-space:nowrap;text-align:left;font-weight:700}}table.resizable{overflow:hidden;resize:both}.btn-group .btn{display:flex;align-items:center;justify-content:center}.btn-group .mdi{font-size:18px}.icon-with-underline{text-decoration:underline}pre{background-color:#f0f0f0;border:1px solid #ccc;border-radius:5px;overflow-x:auto}code{display:block;white-space:pre-wrap;font-family:Menlo,Monaco,Consolas,Courier New,monospace;font-size:14px}.custom-scrollbar::-webkit-scrollbar{width:4px}.custom-scrollbar::-webkit-scrollbar-thumb{background-color:#888;border-radius:10px;cursor:pointer}.custom-scrollbar::-webkit-scrollbar-thumb:hover{background-color:#555}.custom-scrollbar::-webkit-scrollbar-track{background:transparent;border-radius:10px}.pasted-table{border-collapse:collapse;width:100%}.pasted-table td{border:1px solid black;padding:8px}.pasted-table tr:nth-child(even){background-color:#f2f2f2}.pasted-table tr:hover{background-color:#ddd}.vertical-line{border-left:2px solid #ccc;height:100%;margin:0 auto}.els-text-format{font-weight:800!important;background-color:#2b2936!important;border:2px solid #7D6D6D!important;color:#fff!important}.els-text-format>button{color:#fff!important}.els-text-format>button:hover{background-color:#7d6d6d!important;color:#fff!important}\n"], components: [{ type: i3.SketchComponent, selector: "color-sketch", inputs: ["disableAlpha", "presetColors", "width"] }], directives: [{ type: i4.NgbDropdown, selector: "[ngbDropdown]", inputs: ["autoClose", "dropdownClass", "open", "placement", "container", "display"], outputs: ["openChange"], exportAs: ["ngbDropdown"] }, { type: i4.NgbDropdownToggle, selector: "[ngbDropdownToggle]" }, { type: i4.NgbDropdownMenu, selector: "[ngbDropdownMenu]" }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i5.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "titlecase": i5.TitleCasePipe } });
|
1011
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.4", ngImport: i0, type: ElHeaderAndFooterComponent, decorators: [{
|
1012
|
+
type: Component,
|
1013
|
+
args: [{ selector: 'el-header-and-footer', providers: [{
|
1014
|
+
provide: NG_VALUE_ACCESSOR,
|
1015
|
+
useExisting: forwardRef(() => ElHeaderAndFooterComponent),
|
1016
|
+
multi: true
|
1017
|
+
}], template: "<div class=\"container els-text-editor px-0\">\r\n <div class=\"btn-toolbar els-btn-toolbar p-2 py-2 mb-0\" role=\"toolbar\" [id]=\"editorId+'toolbar'\"\r\n aria-label=\"Toolbar with button groups\">\r\n <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Header Options\">\r\n <!-- <div class=\"dropdown\">\r\n <select class=\"els-form-select \" style=\" font-weight: 700 !important; color: #fff; width: 150px; border: 2px solid #7D6D6D !important;\" (change)=\"onFormatChange($event)\">\r\n <option [value]=\"'<h1>'\">Heading 1</option>\r\n <option [value]=\"'<h2>'\">Heading 2</option>\r\n <option [value]=\"'<h3>'\">Heading 3</option>\r\n <option [value]=\"'<h4>'\">Heading 4</option>\r\n <option [value]=\"'<h5>'\">Heading 5</option>\r\n <option [value]=\"'<h6>'\">Heading 6</option>\r\n <option selected [value]=\"'<p>'\">Normal</option>\r\n </select>\r\n </div> -->\r\n <div ngbDropdown class=\"dropdown\">\r\n <button class=\"btn btn-sm els-form-select border els-toolbar-dropdown-button dropdown-toggle text-start\"\r\n [style.border]=\"themeMode()\" [style.color]=\"themeModeClr()\"\r\n id=\"headerDropdown\" ngbDropdownToggle>\r\n <span style=\"width: 85px; font-weight: 700 !important;\">{{selectedFormatBlock | titlecase}}</span>\r\n <i class=\"mdi mdi-chevron-down \"></i>\r\n </button>\r\n <div ngbDropdownMenu aria-labelledby=\"headerDropdown\" class=\"els-text-format\">\r\n <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"onFormatChange('<h1>')\" [style.color]=\"themeModeClr()\">\r\n <h1>Heading 1</h1>\r\n </button>\r\n <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"onFormatChange('<h2>')\" [style.color]=\"themeModeClr()\">\r\n <h2>Heading 2</h2>\r\n </button>\r\n <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"onFormatChange('<h3>')\" [style.color]=\"themeModeClr()\">\r\n <h3>Heading 3</h3>\r\n </button>\r\n <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"onFormatChange('<h4>')\" [style.color]=\"themeModeClr()\">\r\n <h4>Heading 4</h4>\r\n </button>\r\n <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"onFormatChange('<h5>')\" [style.color]=\"themeModeClr()\">\r\n <h5>Heading 5</h5>\r\n </button>\r\n <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"onFormatChange('<h6>')\" [style.color]=\"themeModeClr()\">\r\n <h6>Heading 6</h6>\r\n </button>\r\n <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"onFormatChange('<p>')\" [style.color]=\"themeModeClr()\">\r\n <p>Normal</p>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"btn-group els-button-group\" role=\"group\" aria-label=\"Font Options\">\r\n <div ngbDropdown class=\"dropdown\">\r\n <button class=\"btn btn-sm els-form-select border els-toolbar-dropdown-button dropdown-toggle text-start\"\r\n id=\"headerDropdown\" [style.border]=\"themeMode()\" [style.color]=\"themeModeClr()\" ngbDropdownToggle>\r\n <span style=\"width: 85px; font-weight: 700 !important;\" class=\"text-truncate\">{{selectedFont |\r\n titlecase}}</span>\r\n <i class=\"mdi mdi-chevron-down \"></i>\r\n </button>\r\n <div ngbDropdownMenu aria-labelledby=\"headerDropdown\" class=\"els-text-format\">\r\n <button class=\"dropdown-item pb-0\" type=\"button\" *ngFor=\"let font of fonts\"\r\n (click)=\"changeFont(font)\">\r\n <span>{{ font }}</span>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"border py-0\" [style.border]=\"themeMode()\" style=\"height: fit-content;\">\r\n <div class=\"btn-group els-button-group mr-2 \" role=\"group\" aria-label=\"Text Formatting\">\r\n <button type=\"button\" class=\"btn btn-sm els-toolbar-button\" [class.active]=\"isBoldActive\"\r\n (click)=\"format('bold', editorId)\">\r\n <i class=\"mdi mdi-format-bold\"></i>\r\n </button>\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\" [class.active]=\"isItalicActive\"\r\n (click)=\"format('italic', editorId)\">\r\n <i class=\"mdi mdi-format-italic\"></i>\r\n </button>\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\" [class.active]=\"isUnderlineActive\"\r\n (click)=\"format('underline', editorId)\">\r\n <i class=\"mdi mdi-format-underline\"></i>\r\n </button>\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\" [class.active]=\"isStrikethroughActive\"\r\n (click)=\"format('strikethrough', editorId)\">\r\n <i class=\"mdi mdi-format-strikethrough-variant\"></i>\r\n </button>\r\n <div class=\"btn-group\" role=\"group\" aria-label=\"Text Color\">\r\n <!-- <input type=\"color\" id=\"textColorPicker\"\r\n style=\"position: absolute; top: 100%; left: 0; z-index: 100; opacity: 0;\"\r\n (change)=\"setTextColor($event)\">\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\" style=\"position: relative;\"\r\n (click)=\"openColorPicker('textColorPicker')\">\r\n <i class=\"mdi mdi-format-color-text icon-with-underline\" [style.color]=\"selectedTextColor\"></i>\r\n </button> -->\r\n <div ngbDropdown class=\"ql-align\">\r\n <button type=\"button\"\r\n class=\"btn btn-outline-primary els-toolbar-button arrow-none text-secondary border-none p-0\"\r\n id=\"dropdownBasic1\" aria-expanded=\"false\" ngbDropdownToggle>\r\n <i class=\"mdi mdi-format-color-text icon-with-underline\"\r\n [style.color]=\"selectedTextColor ?? '#000'\"></i>\r\n </button>\r\n <div ngbDropdownMenu aria-labelledby=\"dropdownBasic1\" style=\"width: 200px;\">\r\n <color-sketch color=\"#fff\" [presetColors]=\"[]\"\r\n (onChangeComplete)=\"setTextColor($event, editorId)\"></color-sketch>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"btn-group\" role=\"group\" aria-label=\"Background Color\" style=\"position: relative;\">\r\n <!-- <button type=\"button\" class=\"btn btn-white els-toolbar-button\" [style.color]=\"backgroundColor\"\r\n (click)=\"openColorPicker('bgColorPicker')\">\r\n <i class=\"mdi mdi-alpha-a-box\"></i>\r\n </button>\r\n <input type=\"color\" id=\"bgColorPicker\"\r\n style=\"position: absolute; top: 100%; left: 0; z-index: 100; opacity: 0;\"\r\n (change)=\"setBackgroundColor($event)\"> -->\r\n <div ngbDropdown class=\"ql-align\">\r\n <button type=\"button\"\r\n class=\"btn btn-outline-primary els-toolbar-button arrow-none text-secondary border-none p-0\"\r\n id=\"dropdownBasic1\" aria-expanded=\"false\" ngbDropdownToggle>\r\n <i class=\"mdi mdi-alpha-a-box\" [style.color]=\"backgroundColor ?? '#000'\"></i>\r\n </button>\r\n <div ngbDropdownMenu aria-labelledby=\"dropdownBasic1\" style=\"width: 200px;\">\r\n <color-sketch color=\"#fff\" [presetColors]=\"[]\"\r\n (onChangeComplete)=\"setBackgroundColor($event, editorId)\"></color-sketch>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Text Formatting\">\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\"\r\n (click)=\"format('insertOrderedList', editorId)\"><i\r\n class=\"mdi mdi-format-list-numbered\"></i></button>\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\"\r\n (click)=\"format('insertUnorderedList', editorId)\"><i\r\n class=\"mdi mdi-format-list-bulleted\"></i></button>\r\n <div ngbDropdown class=\"ql-align\">\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button arrow-none text-secondary\"\r\n id=\"dropdownBasic1\" aria-expanded=\"false\" ngbDropdownToggle>\r\n <i class=\"mdi mdi-format-align-left \"></i>\r\n </button>\r\n <div ngbDropdownMenu aria-labelledby=\"dropdownBasic1\" style=\"width: 3px;\">\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\" style=\"color: #7A7982;\"\r\n (click)=\"format('justifyLeft', editorId)\"><i class=\"mdi mdi-format-align-left\"></i></button>\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\" style=\"color: #7A7982;\"\r\n (click)=\"format('justifyCenter', editorId)\"><i\r\n class=\"mdi mdi-format-align-center\"></i></button>\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\" style=\"color: #7A7982;\"\r\n (click)=\"format('justifyRight', editorId)\"><i\r\n class=\"mdi mdi-format-align-right\"></i></button>\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\" style=\"color: #7A7982;\"\r\n (click)=\"format('justifyFull', editorId)\"><i\r\n class=\"mdi mdi-format-align-justify\"></i></button>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Text Formatting\">\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\" [class.active]=\"isSubscriptActive\"\r\n (click)=\"format('subscript', editorId)\">\r\n <i class=\"mdi mdi-format-subscript\"></i>\r\n </button>\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\" [class.active]=\"isSuperscriptActive\"\r\n (click)=\"format('superscript', editorId)\">\r\n <i class=\"mdi mdi-format-superscript\"></i>\r\n </button>\r\n\r\n </div>\r\n <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Table Options\">\r\n\r\n <div ngbDropdown class=\"ql-align\">\r\n <button type=\"button\" class=\"btn btn-outline-primary arrow-none els-toolbar-button border-none p-0\"\r\n id=\"dropdownBasic1\" aria-expanded=\"false\" ngbDropdownToggle>\r\n <i class=\"mdi mdi-format-color-fill\"></i>\r\n </button>\r\n <div ngbDropdownMenu aria-labelledby=\"dropdownBasic1\" style=\"width: 200px;\">\r\n <color-sketch color=\"#fff\"\r\n (onChangeComplete)=\"setCanvasBackgroundColor($event, editorId)\"></color-sketch>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n <div class=\"btn-group els-button-group-2 mr-3\" role=\"group\" aria-label=\"Table Options\">\r\n <button class=\"btn btn-white px-1\" style=\"height: 24px;\" (click)=\"getToday()\">Date</button>\r\n </div>\r\n <div class=\"btn-group els-button-group-2\" role=\"group\" aria-label=\"Table Options\">\r\n <button class=\"btn btn-white px-1\" style=\"height: 24px;\" (click)=\"insertPageNumber()\">Page\r\n No</button>\r\n\r\n </div>\r\n <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Text Formatting\">\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"addLink()\"><i\r\n class=\"mdi mdi-link-variant\"></i></button>\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"insertsImage(editorId)\"><i\r\n class=\"mdi mdi-image\"></i></button>\r\n <input type=\"file\" id=\"imageInput\" style=\"display: none;\" (change)=\"handleImageUpload($event)\">\r\n\r\n </div>\r\n <!-- <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Table Options\">\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"addTable()\"><i\r\n class=\"mdi mdi-table\"></i></button>\r\n <button *ngIf=\"isTableSelected\" type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"addRow()\"><i\r\n class=\"mdi mdi-table-row-plus-after\"></i></button>\r\n <button *ngIf=\"isTableSelected\" type=\"button\" class=\"btn btn-white els-toolbar-button\"\r\n (click)=\"deleteRow()\"><i class=\"mdi mdi-table-row-remove\"></i></button>\r\n <button *ngIf=\"isTableSelected\" type=\"button\" class=\"btn btn-white els-toolbar-button\"\r\n (click)=\"addColumn()\"><i class=\"mdi mdi-table-column-plus-after\"></i></button>\r\n <button *ngIf=\"isTableSelected\" type=\"button\" class=\"btn btn-white els-toolbar-button\"\r\n (click)=\"deleteColumn()\"><i class=\"mdi mdi-table-column-remove\"></i></button>\r\n </div>\r\n <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Table Options\">\r\n <button *ngIf=\"selectedImage\" class=\"btn btn-white els-toolbar-button-2\" (click)=\"editImage()\"\r\n style=\"position: absolute;\">Edit Image</button>\r\n </div> -->\r\n <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Text Formatting\">\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"undo()\">\r\n <i class=\"mdi mdi-undo\"></i>\r\n </button>\r\n <button type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"redo()\">\r\n <i class=\"mdi mdi-redo\"></i>\r\n </button>\r\n\r\n </div>\r\n <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Table Options\">\r\n <!-- <button *ngIf=\"selectedImage\" class=\"btn btn-white els-toolbar-button-2\" (click)=\"editImage()\"\r\n style=\"position: absolute;\">Edit Image</button> -->\r\n <button class=\"btn btn-white els-toolbar-button\" (click)=\"clearTextEditor()\">\r\n <i class=\"mdi mdi-close-circle\"></i>\r\n </button>\r\n </div>\r\n\r\n </div>\r\n </div>\r\n\r\n\r\n <div contenteditable=\"true\" [id]=\"editorId\" class=\"els-border p-3\" #editor\r\n style=\"position: relative !important; height: 130px; max-width: 100%; overflow: hidden; \"\r\n [ngStyle]=\"{'font-family': selectedFont, 'font-size': selectedFontSize + 'px'}\" [style]=\"style\"\r\n contenteditable=\"true\" (input)=\"onModelChange($event)\" placeholder=\"Insert text here ...\"\r\n (mouseup)=\"onTextSelect($event)\" [innerHTML]=\"sanitizedContent\" (paste)=\"onPaste($event)\" (focus)=\"onFocus()\"\r\n (blur)=\"onBlur()\" (click)=\"checkTableSelection($event)\">\r\n </div>\r\n <table *ngIf=\"parsedTable\">\r\n <thead>\r\n <tr>\r\n <th *ngFor=\"let header of parsedTable.headers\">{{ header }}</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let row of parsedTable.rows\">\r\n <td *ngFor=\"let cell of row\">{{ cell }}</td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n</div>", styles: ["*{font-family:Noto Sans Telugu UI,sans-serif}#editor{min-height:125px;max-height:125px;overflow-y:auto}#editor img{max-width:100%;height:auto}.bubble-toolbar{position:absolute;background-color:#fff;border:1px solid #ddd;border-radius:4px;box-shadow:0 2px 5px #00000026;z-index:1000;display:none}.els-text-editor{box-sizing:border-box}.els-btn-toolbar{width:\"1028px\"}.els-toolbar-button{background:none;border:none;cursor:pointer;display:inline-block;float:left;height:24px;padding:3px 5px;width:28px}.els-toolbar-button-2{background:none;border:none;cursor:pointer;display:inline-block;float:left;height:24px;padding:3px 5px;width:100px}.els-toolbar-dropdown-button{background:none;border:none;cursor:pointer;display:inline-block;float:left;height:24px;padding:3px 5px;color:#fff}.els-toolbar-dropdown-button:focus{outline:none}.els-form-select{cursor:pointer;display:inline-block;height:100%;padding:2px 5px 2px 8px;position:relative;width:100%;border:none;background-color:#fff;color:#6c757d}.els-button-group{margin-right:15px}.els-form-select:focus{outline:none}.els-border{border:#353343}.els-border:focus{outline:none}.els-dropdown-item{width:50px!important}.els-toolbar-button.active,.btn-toolbar .btn.active,.btn-toolbar .btn:hover{color:#06c}.dropdown-toggle:after{display:none}.table-container{overflow-x:auto;width:100%}table{width:100%;max-width:100%;margin-bottom:1rem;background-color:transparent;border-collapse:collapse;table-layout:fixed}table td,table th{padding:.75rem;vertical-align:top;border:1px solid #dee2e6;word-wrap:break-word}@media (max-width: 576px){table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;border-spacing:0}table thead,table tbody,table tr,table th,table td{display:block}table thead tr{position:absolute;top:-9999px;left:-9999px}table tr{margin-bottom:.625rem;border:1px solid #ccc}table td,table th{border:none;border-bottom:1px solid #ddd;position:relative;padding-left:50%;white-space:normal;text-align:left}table td:before,table th:before{position:absolute;top:.75rem;left:.75rem;width:45%;padding-right:.75rem;white-space:nowrap;text-align:left;font-weight:700}}table.resizable{overflow:hidden;resize:both}.btn-group .btn{display:flex;align-items:center;justify-content:center}.btn-group .mdi{font-size:18px}.icon-with-underline{text-decoration:underline}pre{background-color:#f0f0f0;border:1px solid #ccc;border-radius:5px;overflow-x:auto}code{display:block;white-space:pre-wrap;font-family:Menlo,Monaco,Consolas,Courier New,monospace;font-size:14px}.custom-scrollbar::-webkit-scrollbar{width:4px}.custom-scrollbar::-webkit-scrollbar-thumb{background-color:#888;border-radius:10px;cursor:pointer}.custom-scrollbar::-webkit-scrollbar-thumb:hover{background-color:#555}.custom-scrollbar::-webkit-scrollbar-track{background:transparent;border-radius:10px}.pasted-table{border-collapse:collapse;width:100%}.pasted-table td{border:1px solid black;padding:8px}.pasted-table tr:nth-child(even){background-color:#f2f2f2}.pasted-table tr:hover{background-color:#ddd}.vertical-line{border-left:2px solid #ccc;height:100%;margin:0 auto}.els-text-format{font-weight:800!important;background-color:#2b2936!important;border:2px solid #7D6D6D!important;color:#fff!important}.els-text-format>button{color:#fff!important}.els-text-format>button:hover{background-color:#7d6d6d!important;color:#fff!important}\n"] }]
|
1018
|
+
}], ctorParameters: function () { return [{ type: i1.Router }, { type: i1.ActivatedRoute }, { type: i0.Renderer2 }, { type: i2.DomSanitizer }]; }, propDecorators: { dropdown: [{
|
1019
|
+
type: ViewChild,
|
1020
|
+
args: [NgbDropdown, { static: true }]
|
1021
|
+
}], editorId: [{
|
1022
|
+
type: Input
|
1023
|
+
}], editorText: [{
|
1024
|
+
type: Input
|
1025
|
+
}], editorFrom: [{
|
1026
|
+
type: Input
|
1027
|
+
}], clear: [{
|
1028
|
+
type: Input
|
1029
|
+
}], editorAction: [{
|
1030
|
+
type: Input
|
1031
|
+
}], style: [{
|
1032
|
+
type: Input
|
1033
|
+
}], bgColor: [{
|
1034
|
+
type: Input
|
1035
|
+
}], toolbarMode: [{
|
1036
|
+
type: Input
|
1037
|
+
}], editorTextChange: [{
|
1038
|
+
type: Output
|
1039
|
+
}], editorActionResponse: [{
|
1040
|
+
type: Output
|
1041
|
+
}], value: [{
|
1042
|
+
type: Input
|
1043
|
+
}], editorTextClear: [{
|
1044
|
+
type: Output
|
1045
|
+
}] } });
|
1046
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"el-header-and-footer.component.js","sourceRoot":"","sources":["../../../../projects/el-header-and-footer/src/lib/el-header-and-footer.component.ts","../../../../projects/el-header-and-footer/src/lib/el-header-and-footer.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAiB,SAAS,EAAE,YAAY,EAAE,UAAU,EAAE,KAAK,EAAqB,MAAM,EAA4B,SAAS,EAAE,MAAM,eAAe,CAAC;AAC1J,OAAO,EAAqC,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAGtF,OAAO,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;;;;;;;AAYzD,MAAM,OAAO,0BAA0B;IA2ErC,YACU,MAAc,EACd,KAAqB,EACrB,QAAmB,EACnB,SAAuB;QAHvB,WAAM,GAAN,MAAM,CAAQ;QACd,UAAK,GAAL,KAAK,CAAgB;QACrB,aAAQ,GAAR,QAAQ,CAAW;QACnB,cAAS,GAAT,SAAS,CAAc;QA3ExB,aAAQ,GAAW,EAAE,CAAC;QACtB,eAAU,GAAW,EAAE,CAAC;QACxB,eAAU,GAAW,EAAE,CAAC;QACxB,UAAK,GAAY,KAAK,CAAC;QAIvB,gBAAW,GAAgC,OAAO,CAAC;QAClD,qBAAgB,GAAG,IAAI,YAAY,EAAU,CAAC;QAC9C,yBAAoB,GAAG,IAAI,YAAY,EAAO,CAAC;QAEhD,UAAK,GAAW,EAAE,CAAC;QAElB,oBAAe,GAAG,IAAI,YAAY,EAAO,CAAC;QAKpD,gBAAW,GAAG,KAAK,CAAC;QACpB,eAAU,GAAG,CAAC,CAAC;QACf,gBAAW,GAAG,CAAC,CAAC;QAEhB,UAAK,GAAG,CAAC,OAAO,EAAE,aAAa,EAAE,SAAS,EAAE,iBAAiB,EAAE,SAAS,CAAC,CAAC;QAC1E,cAAS,GAAG,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;QACrD,iBAAY,GAAG,OAAO,CAAC;QACvB,qBAAgB,GAAG,EAAE,CAAC;QACtB,oBAAe,GAAG,KAAK,CAAC;QACxB,eAAU,GAAG,KAAK,CAAC;QACnB,kBAAa,GAA4B,IAAI,CAAC;QAC9C,yBAAoB,GAAG,IAAI,CAAC;QAC5B,iBAAY,GAAgC,IAAI,CAAC;QAEjD,iBAAY,GAAY,KAAK,CAAC;QAC9B,mBAAc,GAAY,KAAK,CAAC;QAChC,sBAAiB,GAAY,KAAK,CAAC;QACnC,0BAAqB,GAAY,KAAK,CAAC;QACvC,sBAAiB,GAAY,KAAK,CAAC;QACnC,wBAAmB,GAAY,KAAK,CAAC;QAErC,wBAAmB,GAAW,QAAQ,CAAA;QAEtC,cAAS,GAAa,EAAE,CAAC;QACzB,cAAS,GAAa,EAAE,CAAC;QACzB,YAAO,GAAa,EAAE,CAAC;QACvB,iBAAY,GAAG,CAAC,CAAC,CAAC;QAElB,kBAAa,GAA4B,IAAI,CAAC;QAC9C,iBAAY,GAAW,EAAE,CAAC;QAC1B,mBAAc,GAAG,CAAC,CAAC;QACnB,mBAAc,GAAG,CAAC,CAAC;QACnB,sBAAiB,GAAG,CAAC,CAAC;QACtB,sBAAiB,GAAG,CAAC,CAAC;QACtB,0BAAqB,GAAG,CAAC,CAAC;QAC1B,2BAAsB,GAAG,CAAC,CAAC;QAC3B,yBAAoB,GAAiE,IAAI,CAAC;QAI1F,aAAQ,GAAQ,GAAG,EAAE,GAAE,CAAC,CAAC;QACzB,cAAS,GAAQ,GAAG,EAAE,GAAE,CAAC,CAAC;QAC1B,UAAK,GAAQ,MAAM,CAAC;QAGpB,sBAAiB,GAAkB,IAAI,CAAC;QAExC,gBAAW,GAAmD,IAAI,CAAC;QAEnE,iBAAY,GAAY,KAAK,CAAC;QAC9B,UAAK,GAAW,EAAE,CAAC;QACnB,gBAAW,GAAW,MAAM,CAAC;IAOzB,CAAC;IACL,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,SAAS,CAAC,EAAE;YACtB,MAAM,KAAK,GAAG,EAAE,KAAK,EAAC,EAAE,GAAG,EAAG,IAAI,CAAC,OAAO,EAAC,EAAE,CAAA;YAC7C,IAAI,CAAC,wBAAwB,CAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAA;SACpD;IACH,CAAC;IACA,eAAe;QACd,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACxB,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA;QAC/B,QAAQ,CAAC,gBAAgB,CAAC,iBAAiB,EAAE,GAAG,EAAE;YAChD,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACzB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACvC,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAChC,IAAI,CAAC,0BAA0B,EAAE,CAAC;QAClC,+CAA+C;QAC/C,6CAA6C;QAC7C,0BAA0B;QAC1B,kEAAkE;QAClE,oBAAoB;QACpB,uDAAuD;QACvD,QAAQ;QACR,sDAAsD;QACtD,MAAM;QACN,KAAK;IAGP,CAAC;IAED,UAAU,CAAC,KAAU;QACnB,IAAI,KAAK,KAAK,SAAS,EAAE;YACvB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;YACxB,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;SACjC;IACH,CAAC;IAED,uCAAuC;IACvC,sDAAsD;IACtD,kBAAkB;IAClB,oDAAoD;IACpD,oDAAoD;IACpD,wCAAwC;IACxC,2DAA2D;IAC3D,sDAAsD;IACtD,8DAA8D;IAC9D,iBAAiB;IACjB,qCAAqC;IACrC,UAAU;IACV,UAAU;IACV,MAAM;IACN,IAAI;IAEI,wBAAwB;QAChC,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACtD,IAAI,MAAM,EAAE;YACV,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC,KAAK,EAAE,EAAE;gBACzC,MAAM,MAAM,GAAG,KAAK,CAAC,MAAqB,CAAC;gBAC3C,IAAI,MAAM,CAAC,OAAO,KAAK,KAAK,EAAE;oBAC5B,IAAI,CAAC,aAAa,GAAG,MAA0B,CAAC;oBAChD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC;oBAE3C,sCAAsC;oBACtC,MAAM,MAAM,GAAG,MAAM,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC;oBAClD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;wBACtC,IAAI,MAAM,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,aAAa,EAAE;4BACpC,IAAI,CAAC,iBAAiB,GAAG,CAAC,CAAC;4BAC3B,MAAM;yBACP;qBACF;oBAED,IAAI,IAAI,CAAC,WAAW,KAAK,QAAQ,EAAE;wBACjC,IAAI,CAAC,YAAY,EAAE,CAAC;qBACrB;iBACF;qBAAM;oBACL,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;oBAC1B,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;iBAC/B;YACH,CAAC,CAAC,CAAC;SACJ;IACD,CAAC;IAEO,0BAA0B;QAClC,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACtD,IAAI,MAAM,EAAE;YACV,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC,KAAK,EAAE,EAAE;gBACzC,MAAM,MAAM,GAAG,KAAK,CAAC,MAAqB,CAAC;gBAE3C,gBAAgB;gBAChB,IAAI,MAAM,CAAC,OAAO,KAAK,KAAK,EAAE;oBAC5B,IAAI,CAAC,aAAa,GAAG,MAA0B,CAAC;oBAChD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC;oBAE3C,sCAAsC;oBACtC,MAAM,MAAM,GAAG,MAAM,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC;oBAClD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;wBACtC,IAAI,MAAM,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,aAAa,EAAE;4BACpC,IAAI,CAAC,iBAAiB,GAAG,CAAC,CAAC;4BAC3B,MAAM;yBACP;qBACF;iBACF;qBAAM;oBACL,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;iBAC3B;gBACD,IAAI,MAAM,CAAC,OAAO,KAAK,IAAI,IAAI,MAAM,CAAC,OAAO,KAAK,IAAI,EAAE;oBACtD,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,OAAO,CAAC,OAAO,CAAqB,CAAC;oBAEjE,MAAM,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,oBAAoB,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;oBACtE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;wBACrC,IAAI,KAAK,CAAC,CAAC,CAAC,KAAK,MAAM,EAAE;4BACvB,IAAI,CAAC,iBAAiB,GAAG,CAAC,CAAC;4BAC3B,MAAM;yBACP;qBACF;iBACF;qBAAM;oBACL,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;iBAC3B;gBAED,IAAI,MAAM,CAAC,OAAO,KAAK,GAAG,IAAI,MAAM,CAAC,OAAO,KAAK,MAAM,IAAI,MAAM,CAAC,OAAO,KAAK,KAAK,EAAE;oBACnF,MAAM,UAAU,GAAG,MAAM,CAAC,oBAAoB,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;oBAC/D,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;wBAC1C,IAAI,UAAU,CAAC,CAAC,CAAC,KAAK,MAAM,EAAE;4BAC5B,IAAI,CAAC,iBAAiB,GAAG,CAAC,CAAC;4BAC3B,MAAM;yBACP;qBACF;iBACF;qBAAM;iBACN;YACH,CAAC,CAAC,CAAC;SACJ;IACD,CAAC;IAEH,eAAe,CAAC,MAAc,EAAE,KAAa;QAC3C,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACtD,IAAI,MAAM,EAAE;YACV,MAAM,CAAC,KAAK,EAAE,CAAA;YACd,MAAM,MAAM,GAAG,MAAM,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC;YAElD,IAAI,KAAK,IAAI,CAAC,EAAG;gBACf,MAAM,CAAC,KAAK,CAAC,CAAC,YAAY,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;aAC3C;iBAAM;gBACL,OAAO,CAAC,IAAI,CAAC,SAAS,KAAK,oCAAoC,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC;aACjF;SACF;aAAM;YACL,OAAO,CAAC,KAAK,CAAC,0BAA0B,CAAC,CAAC;SAC3C;IACH,CAAC;IAIS,UAAU;QAChB,0CAA0C;QAC1C,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAEtD,IAAI,MAAM,EAAE;YACV,MAAM,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC;YACnC,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE,GAAG,EAAE;gBACpC,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;YACvC,CAAC,CAAC,CAAC;SACJ;QACD,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAED,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAED,gBAAgB,CAAE,UAAmB;QACnC,yCAAyC;IAC3C,CAAC;IAED,aAAa,CAAC,KAAU;QACtB,IAAI,KAAK,EAAE;YACT,MAAM,KAAK,GAAG,KAAK,CAAA;YACnB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;YACzC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC;YACtC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC;SAEpD;aAAM;YACL,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;SAC3B;IACH,CAAC;IAED,gBAAgB,CAAC,OAAe;QAC9B,MAAM,GAAG,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAC1C,GAAG,CAAC,SAAS,GAAG,OAAO,CAAC;QACxB,MAAM,MAAM,GAAG,GAAG,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;QAC3C,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;YACnB,IAAI,GAAG,CAAC,KAAK,CAAC,QAAQ,IAAI,OAAO,EAAE;gBACjC,GAAG,CAAC,KAAK,CAAC,QAAQ,GAAG,OAAO,CAAC;gBAC7B,mBAAmB;gBACnB,GAAG,CAAC,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC;aAC3B;iBAAM;gBACL,GAAG,CAAC,KAAK,CAAC,QAAQ,GAAG,MAAM,CAAC;gBAC5B,GAAG,CAAC,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC;aAC3B;QACH,CAAC,CAAC,CAAC;QACH,OAAO,GAAG,CAAC,SAAS,CAAC;IACvB,CAAC;IAED,SAAS,CAAC,IAAS;QACjB,IAAI,IAAI,EAAE;YACR,IAAI,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YACpD,IAAI,MAAM,EAAE;gBACV,MAAM,CAAC,KAAK,EAAE,CAAA;gBACb,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;gBAE/B,sDAAsD;gBACtD,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC;gBAEnC,wDAAwD;gBACxD,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;gBAC1B,iBAAiB;gBACjB,2BAA2B;gBAC3B,+FAA+F;gBAC/F,sDAAsD;gBACtD,2CAA2C;gBAC3C,kBAAkB;gBAClB,qBAAqB;gBACrB,4CAA4C;gBAC5C,MAAM;gBACN,MAAM;aACP;SACF;aAAM;YACL,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;SAC3B;IACH,CAAC;IAEO,gBAAgB,CAAC,IAAY;QACrC,IAAI,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACpD,IAAI,MAAM,EAAE;YACV,wCAAwC;YACxC,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,SAAS,CAAC,uBAAuB,CAAC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC;YAC5F,MAAM,CAAC,SAAS,GAAG,IAAI,CAAC,gBAA0B,CAAC;SACpD;IACH,CAAC;IAEO,qBAAqB,CAAC,MAAmB;QAC/C,MAAM,QAAQ,GAAG,IAAI,gBAAgB,CAAC,GAAG,EAAE;YACzC,kDAAkD;YAClD,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;YAC5B,wCAAwC;YACxC,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QACvC,CAAC,CAAC,CAAC;QAEH,QAAQ,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC,CAAC;IACpF,CAAC;IAEO,cAAc,CAAC,MAAmB;QACxC,MAAM,SAAS,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC;QACxC,MAAM,KAAK,GAAG,QAAQ,CAAC,WAAW,EAAE,CAAC;QAErC,IAAI,MAAM,CAAC,SAAS,EAAE;YACpB,KAAK,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC;YACjC,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,sBAAsB;YAC7C,SAAS,EAAE,eAAe,EAAE,CAAC;YAC7B,SAAS,EAAE,QAAQ,CAAC,KAAK,CAAC,CAAC;SAC5B;IACH,CAAC;IACC,yCAAyC;IACzC,uDAAuD;IACvD,uCAAuC;IACvC,+BAA+B;IAC/B,yEAAyE;IACzE,sFAAsF;IACtF,gBAAgB;IAChB,qDAAqD;IACrD,SAAS;IACT,IAAI;IAEJ,cAAc,CAAC,IAAS;QACtB,MAAM,KAAK,GAAG,IAAI,CAAC;QACnB,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAAC;QACnC,IAAI,KAAK,EAAE;YACT,IAAI,CAAC,MAAM,CAAC,aAAa,EAAE,IAAI,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;SAClD;IACH,CAAC;IAGC,MAAM,CAAC,OAAe,EAAE,QAAgB,EAAE,KAAW;QACnD,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;QACjD,IAAI,MAAM,EAAE;YACV,MAAM,CAAC,KAAK,EAAE,CAAC;YACf,IAAI,OAAO,KAAK,WAAW,EAAE;gBAC3B,IAAI,CAAC,iBAAiB,GAAG,CAAC,IAAI,CAAC,iBAAiB,CAAC;gBACjD,QAAQ,CAAC,WAAW,CAAC,WAAW,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;aAC9C;iBAAM,IAAI,OAAO,KAAK,aAAa,EAAE;gBACpC,IAAI,CAAC,mBAAmB,GAAG,CAAC,IAAI,CAAC,mBAAmB,CAAC;gBACrD,QAAQ,CAAC,WAAW,CAAC,aAAa,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;gBAAA,CAAC;aACjD;iBAAM;gBACL,QAAQ,CAAC,WAAW,CAAC,OAAO,EAAE,KAAK,EAAE,KAAK,IAAI,EAAE,CAAC,CAAC;gBAClD,IAAI,KAAK,EAAE;oBACT,MAAM,GAAG,GAAG,KAAK,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC,CAAA;oBACpD,MAAM,OAAO,GAAG,QAAQ,CAAC,cAAc,CAAC,QAAQ,GAAG,SAAS,CAAC,CAAC;oBAC9D,IAAI,OAAO,EAAE;wBACX,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC;qBACxD;iBACF;aACF;SACF;QACA,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC;IACnC,CAAC;IAED,iBAAiB;QACf,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC;QACvD,IAAI,CAAC,cAAc,GAAG,QAAQ,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAC;QAC3D,IAAI,CAAC,iBAAiB,GAAG,QAAQ,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;QACjE,IAAI,CAAC,qBAAqB,GAAG,QAAQ,CAAC,iBAAiB,CAAC,eAAe,CAAC,CAAC;QACzE,IAAI,CAAC,iBAAiB,GAAG,QAAQ,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;QACjE,IAAI,CAAC,mBAAmB,GAAG,QAAQ,CAAC,iBAAiB,CAAC,aAAa,CAAC,CAAC;IACvE,CAAC;IAED,gBAAgB,CAAC,QAAgB;QAC/B,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;QACjD,IAAI,MAAM,EAAE;YACV,MAAM,WAAW,GAAG,QAAQ,CAAC,iBAAiB,CAAC,aAAa,CAAC,CAAC;YAC7D,MAAM,OAAO,GAAG,QAAQ,CAAC,cAAc,CAAC,QAAQ,GAAG,SAAS,CAAC,CAAC;YAC/D,IAAI,OAAO,EAAE;gBACX,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;aAChE;YACD,yDAAyD;SAC1D;IACH,CAAC;IAED,iBAAiB,CAAC,IAAY;QAC5B,QAAQ,IAAI,EAAE;YACZ,KAAK,IAAI;gBACP,OAAO,WAAW,CAAC;gBACnB,MAAM;YACR,KAAK,IAAI;gBACP,OAAO,WAAW,CAAC;gBACnB,MAAM;YACR,KAAK,IAAI;gBACP,OAAO,WAAW,CAAC;gBACnB,MAAM;YACR,KAAK,IAAI;gBACP,OAAO,WAAW,CAAC;gBACnB,MAAM;YACR,KAAK,IAAI;gBACP,OAAO,WAAW,CAAC;gBACnB,MAAM;YACR,KAAK,IAAI;gBACP,OAAO,WAAW,CAAC;gBACnB,MAAM;YACR,KAAK,GAAG;gBACN,OAAO,QAAQ,CAAC;gBAChB,MAAM;YACR;gBACE,OAAO,QAAQ,CAAC;gBAChB,MAAM;SACT;IACH,CAAC;IAED,UAAU,CAAC,KAAU;QACnB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAA;QACzB,QAAQ,CAAC,WAAW,CAAC,UAAU,EAAE,KAAK,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;IAC7D,CAAC;IAED,eAAe;QACb,MAAM,IAAI,GAAG;;;;;;;;;;;;;;KAcZ,CAAC;QACF,QAAQ,CAAC,WAAW,CAAC,YAAY,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;IAClD,CAAC;IAED,+BAA+B;IAC/B,kDAAkD;IAClD,oDAAoD;IACpD,kBAAkB;IAClB,8DAA8D;IAC9D,sDAAsD;IACtD,2CAA2C;IAC3C,mDAAmD;IACnD,yEAAyE;IACzE,UAAU;IACV,QAAQ;IACR,MAAM;IACN,IAAI;IACJ,cAAc,CAAC,KAAU;QACvB,MAAM,YAAY,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC;QAE3C,IAAI,YAAY,IAAI,YAAY,CAAC,UAAU,GAAG,CAAC,EAAE;YAC7C,MAAM,KAAK,GAAG,YAAY,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;YACzC,MAAM,IAAI,GAAG,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;YAC5C,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;YACnD,KAAK,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;SAChC;IACH,CAAC;IAED,OAAO;QACL,IAAI,GAAG,GAAG,MAAM,CAAC,uBAAuB,EAAE,SAAS,CAAC,CAAC;QACrD,IAAI,GAAG,EAAE;YACP,QAAQ,CAAC,WAAW,CAAC,YAAY,EAAE,KAAK,EAAE,GAAG,CAAC,CAAC;SAChD;IACH,CAAC;IAED,YAAY,CAAC,QAAgB;QAC3B,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;QACjD,IAAI,MAAM,EAAE;YACV,MAAM,CAAC,KAAK,EAAE,CAAC;YACf,IAAI,UAAU,GAAG,QAAQ,CAAC,cAAc,CAAC,YAAY,CAAqB,CAAC;YAC3E,IAAI,UAAU,EAAE;gBACd,UAAU,CAAC,KAAK,EAAE,CAAC;aACpB;SACF;IACH,CAAC;IAEA,iBAAiB,CAAC,KAAU;QAC7B,MAAM,IAAI,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACnC,IAAI,IAAI,EAAE;YACR,MAAM,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;YAChC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAM,EAAE,EAAE;gBACzB,MAAM,GAAG,GAAG,IAAI,KAAK,EAAE,CAAC;gBACxB,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC;gBAC1B,GAAG,CAAC,MAAM,GAAG,GAAG,EAAE;oBAChB,yDAAyD;oBACzD,MAAM,OAAO,GAAG,aAAa,GAAG,CAAC,GAAG,YAAY,GAAG,CAAC,KAAK,aAAa,GAAG,CAAC,MAAM,IAAI,CAAC;oBACrF,mCAAmC;oBACnC,QAAQ,CAAC,WAAW,CAAC,YAAY,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC;gBACrD,CAAC,CAAC;YACJ,CAAC,CAAC;YACF,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;SAC5B;IACH,CAAC;IAGC,QAAQ,CAAC,QAAgB;QACvB,MAAM,UAAU,GAAG,GAAG,CAAC,CAAC,wBAAwB;QAChD,MAAM,IAAI,GAAG,CAAC,CAAC,CAAC,oBAAoB;QACpC,MAAM,YAAY,GAAG,UAAU,GAAG,IAAI,CAAC,CAAC,wCAAwC;QAEhF,IAAI,KAAK,GAAG,yDAAyD,UAAU,gCAAgC,CAAC;QAChH,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,iBAAiB;YAC7C,KAAK,IAAI,MAAM,CAAC;YAChB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,EAAE,EAAE;gBAC7B,KAAK,IAAI,oHAAoH,YAAY,kBAAkB,CAAC;aAC7J;YACD,KAAK,IAAI,OAAO,CAAC;SAClB;QACC,KAAK,IAAI,gBAAgB,CAAC;QAC1B,oDAAoD;QACpD,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;QACnD,IAAI,MAAM,EAAE;YACV,MAAM,CAAC,KAAK,EAAE,CAAC;YACf,QAAQ,CAAC,WAAW,CAAC,YAAY,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;SAClD;QACD,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QACvB,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAID,mBAAmB,CAAC,KAAkB;QACpC,IAAI,MAAM,GAAG,KAAK,EAAE,MAAqB,CAAC;QAC1C,IAAI,MAAM,IAAI,CAAC,MAAM,CAAC,OAAO,KAAK,IAAI,IAAI,MAAM,CAAC,OAAO,KAAK,IAAI,CAAC,EAAE;YAClE,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;YAC5B,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,OAAO,CAAC,OAAO,CAAqB,CAAC;SAClE;aAAM;YACL,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;YAC7B,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;SAC3B;QAED,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAED,gBAAgB;QACd,kDAAkD;QAClD,gBAAgB;QAChB,wFAAwF;QACxF,qCAAqC;QACrC,qIAAqI;QACrI,aAAa;QACb,8DAA8D;QAC9D,yBAAyB;QACzB,yCAAyC;QACzC,QAAQ;QACR,MAAM;QACN,IAAI;IACN,CAAC;IAED,OAAO;QACL,kDAAkD;QAClD,6CAA6C;QAC7C,2BAA2B;QAC3B,uCAAuC;QACvC,IAAI;IACN,CAAC;IAED,kCAAkC;IAClC,2BAA2B;IAC3B,IAAI;IAEJ,MAAM;QACJ,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAED,MAAM;QACJ,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,GAAG,GAAG,IAAI,CAAC,aAAa,CAAC,SAAS,EAAE,CAAC;YACzC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBAChE,IAAI,IAAI,GAAG,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;gBAC7B,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;gBAC1B,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,iBAAiB,CAAC;aACvC;SACF;IACH,CAAC;IAED,gBAAgB;IAChB,8BAA8B;IAC9B,wCAAwC;IACxC,MAAM;IACN,IAAI;IAEN,kBAAkB;IAClB,8BAA8B;IAC9B,0DAA0D;IAC1D,iCAAiC;IACjC,+CAA+C;IAC/C,yBAAyB;IACzB,wEAAwE;IACxE,qBAAqB;IACrB,qCAAqC;IACrC,YAAY;IACZ,UAAU;IACV,QAAQ;IACR,8CAA8C;IAC9C,MAAM;IACN,IAAI;IAEF,SAAS;QACT,MAAM,SAAS,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC;QACtC,IAAI,SAAS,EAAE;YACf,IAAI,CAAC,SAAS,CAAC,UAAU;gBAAE,OAAO;YAElC,MAAM,KAAK,GAAG,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;YACtC,MAAM,YAAY,GAAG,KAAK,CAAC,cAAc,CAAC;YAC1C,MAAM,GAAG,GAAG,YAAY,CAAC,aAAa,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC;YAEtD,IAAI,GAAG,EAAE;gBACP,MAAM,KAAK,GAAG,GAAG,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;gBACnC,IAAI,KAAK,EAAE;oBACT,KAAK,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;iBAC/B;aACF;SACF;IACH,CAAC;IAGC,gBAAgB;IAChB,8BAA8B;IAC9B,iEAAiE;IACjE,8DAA8D;IAC9D,mCAAmC;IACnC,+CAA+C;IAC/C,QAAQ;IACR,MAAM;IACN,IAAI;IAEJ,SAAS;QACT,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,MAAM,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,mBAAmB;YACpF,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC;YAClD,MAAM,QAAQ,GAAG,UAAU,GAAG,WAAW,CAAC;YAE1C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBACvD,IAAI,IAAI,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;gBACrD,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;gBAC1B,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,iBAAiB,CAAC;gBACtC,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,GAAG,QAAQ,IAAI,CAAC;gBACtC,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,YAAY,CAAC;gBACnC,IAAI,CAAC,KAAK,CAAC,SAAS,GAAG,WAAW,CAAC;gBACnC,IAAI,CAAC,KAAK,CAAC,UAAU,GAAG,QAAQ,CAAC;aAClC;YAED,kCAAkC;YAClC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBACvD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;oBAChE,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,QAAQ,GAAG,GAAG,QAAQ,IAAI,CAAC;iBACtE;aACF;SACF;IACH,CAAC;IAGC,YAAY;QACZ,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,MAAM,CAAC,YAAY,EAAE;gBACvB,IAAI,SAAS,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC;gBACtC,IAAI,SAAS,EAAE;oBACb,IAAI,IAAI,GAAG,SAAS,CAAC,UAAU,EAAE,aAAa,EAAE,OAAO,CAAC,QAAQ,CAAyB,CAAC;oBAC1F,IAAI,IAAI,EAAE;wBACR,IAAI,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;wBAC/B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;4BACvD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;yBAClD;qBACF;iBACF;aACF;SACF;IACH,CAAC;IAEC,mBAAmB;IACnB,8BAA8B;IAC9B,iEAAiE;IACjE,mDAAmD;IACnD,QAAQ;IACR,MAAM;IACN,IAAI;IAEJ,gBAAgB,CAAC,KAAU;QACzB,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC;SAC5D;IACH,CAAC;IAED,eAAe,CAAC,KAAU;QACxB,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBACvD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;oBAChE,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC;iBAC7E;aACF;SACF;IACH,CAAC;IAED,gBAAgB,CAAC,KAAU;QACzB,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBACvD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;oBAChE,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC;iBAC9E;aACF;SACF;IACH,CAAC;IAEO,aAAa,CAAC,OAAoB;QACxC,MAAM,KAAK,GAAG,QAAQ,CAAC,WAAW,EAAE,CAAC;QACrC,MAAM,GAAG,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC;QAChC,IAAI,GAAG,EAAE;YACT,KAAK,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC;YACpC,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YACtB,GAAG,CAAC,eAAe,EAAE,CAAC;YACtB,GAAG,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;SACnB;IACH,CAAC;IAED,eAAe,CAAC,OAAe;QAC7B,MAAM,YAAY,GAAG,QAAQ,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;QACtD,IAAI,YAAY,EAAE;YAChB,YAAY,CAAC,KAAK,EAAE,CAAC;SACtB;IACH,CAAC;IAED,YAAY,CAAC,KAAU,EAAE,QAAa;QACpC,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;QACjD,IAAI,MAAM,EAAE;YACV,MAAM,CAAC,KAAK,EAAE,CAAC;YACf,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC;YAC9B,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;YAC/B,QAAQ,CAAC,WAAW,CAAC,WAAW,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;YAC/C,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjB,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;aACvB;SACF;IACH,CAAC;IAED,kBAAkB,CAAC,KAAU,EAAE,QAAgB;QAC7C,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;QACjD,IAAI,MAAM,EAAE;YACV,MAAM,CAAC,KAAK,EAAE,CAAC;YACf,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC;YAC9B,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;YAC7B,QAAQ,CAAC,WAAW,CAAC,aAAa,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;YACjD,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjB,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;aACvB;SACF;IACH,CAAC;IAED,6BAA6B;IAC7B,mCAAmC;IACnC,IAAI;IAEG,QAAQ,CAAC,KAAU,EAAE,OAAY;QACtC,MAAM,KAAK,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAA;QACvC,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAA;QAC9B,QAAQ,CAAC,WAAW,CAAC,WAAW,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;QAChD,6DAA6D;IAC/D,CAAC;IAED,SAAS;QACP,IAAI,IAAI,CAAA;QACR,QAAQ,IAAI,CAAC,UAAU,EAAE;YACvB,KAAK,iBAAiB;gBACpB,IAAI,GAAG,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,YAAY,EAAE,KAAK,EAAE,IAAI,CAAC,iBAAiB,EAAE,CAAC;gBAC5E,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;gBAC/B,cAAc,CAAC,OAAO,CAAC,mBAAmB,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;gBAC/E,cAAc,CAAC,OAAO,CAAC,YAAY,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;gBACtD,MAAM;YACR,KAAK,UAAU;gBACb,IAAI,GAAG,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,gBAAgB,EAAE,KAAK,EAAE,IAAI,CAAC,iBAAiB,EAAE,CAAC;gBAChF,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;gBAC/B,mFAAmF;gBACnF,cAAc,CAAC,OAAO,CAAC,gBAAgB,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;gBAC1D,MAAM;YACR;gBACE,cAAc,CAAC,UAAU,CAAC,mBAAmB,CAAC,CAAC;gBAC/C,mDAAmD;gBACnD,cAAc,CAAC,UAAU,CAAC,gBAAgB,CAAC,CAAC;gBAC5C,cAAc,CAAC,UAAU,CAAC,YAAY,CAAC,CAAC;gBACxC,MAAM;SACT;QACD,+CAA+C;QAC/C,oFAAoF;QACpF,mCAAmC;QACnC,mFAAmF;QACnF,0DAA0D;QAC1D,KAAK;IAEP,CAAC;IAED,mBAAmB,CAAC,IAAS;QAC3B,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,qBAAqB,CAAC,EAAE,EAAE,WAAW,EAAE,EAAC,IAAI,EAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAC,EAAE,CAAC,CAAA;IAC/F,CAAC;IAED,2CAA2C;IAC3C,yCAAyC;IACzC,+CAA+C;IAC/C,mDAAmD;IACnD,+CAA+C;IAC/C,gCAAgC;IAChC,sDAAsD;IACtD,+DAA+D;IAC/D,iFAAiF;IACjF,mCAAmC;IACnC,iBAAiB;IACjB,oCAAoC;IACpC,UAAU;IACV,QAAQ;IACR,MAAM;IACN,IAAI;IAEL,YAAY,CAAC,KAAkB;QAC9B,IAAI,IAAI,CAAC,WAAW,KAAK,QAAQ,EAAE;YACjC,MAAM,SAAS,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC;YACxC,IAAI,SAAS,IAAI,SAAS,CAAC,UAAU,GAAG,CAAC,EAAE;gBACzC,MAAM,KAAK,GAAG,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;gBACtC,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE;oBACpB,MAAM,IAAI,GAAG,KAAK,CAAC,qBAAqB,EAAE,CAAC;oBAC3C,MAAM,OAAO,GAAI,QAAQ,CAAC,eAAe,CAAC,SAAS,CAAC;oBACpD,MAAM,OAAO,GAAI,QAAQ,CAAC,eAAe,CAAC,UAAU,CAAC;oBACrD,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,GAAG,GAAG,OAAO,GAAG,EAAE,CAAC;oBAC1C,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,IAAI,GAAG,OAAO,GAAG,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC;oBAChE,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;iBACzB;qBAAM;oBACL,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;iBAC1B;aACF;iBAAM;gBACL,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;aAC1B;SACF;IACH,CAAC;IAGD,OAAO,CAAC,KAAqB;QACzB,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,MAAM,aAAa,GAAG,KAAK,CAAC,aAAa,CAAC;QAC1C,IAAI,aAAa,EAAE;YACjB,MAAM,UAAU,GAAG,aAAa,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;YACvD,IAAI,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,EAAE;gBAChC,MAAM,IAAI,GAAG,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC,CAAC;gBACjD,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;aAC9B;iBAAM;gBACL,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAC;aACpC;SACF;IACH,CAAC;IAED,WAAW,CAAC,IAAY;QACtB,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAC9B,OAAO,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;IAC3D,CAAC;IAED,kBAAkB,CAAC,IAAY;QAC7B,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC;QAC/D,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;YAC/B,MAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,wDAAwD,IAAI,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YACxH,OAAO,QAAQ,KAAK,OAAO,CAAC;QAC9B,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACZ,OAAO,UAAU,SAAS,UAAU,CAAC;IACvC,CAAC;IAED,iBAAiB,CAAC,IAAY;QAC5B,MAAM,KAAK,GAAG,MAAM,CAAC,YAAY,EAAE,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC;QACnD,IAAI,KAAK,EAAE;YACT,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YAC9C,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC;YACzB,MAAM,IAAI,GAAG,QAAQ,CAAC,sBAAsB,EAAE,CAAC;YAC/C,IAAI,IAAI,CAAC;YACT,OAAO,CAAC,IAAI,GAAG,OAAO,CAAC,UAAU,CAAC,EAAE;gBAClC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;aACxB;YACD,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YACvB,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;SACvB;IACH,CAAC;IAGM,cAAc;QACnB,IAAI,IAAI,GAAQ,QAAQ,CAAC,cAAc,CAAC,YAAY,CAAC,CAAC;QACtD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,IAAI,IAAI,CAAC,iBAAiB,EAAE;YAC1B,IAAI,CAAC,iBAAiB,EAAE,CAAC;SAC1B;aAAM,IAAI,IAAI,CAAC,oBAAoB,EAAE;YACpC,IAAI,CAAC,oBAAoB,EAAE,CAAC;SAC7B;aAAM,IAAI,IAAI,CAAC,uBAAuB,EAAE;YACvC,IAAI,CAAC,uBAAuB,EAAE,CAAC;SAChC;aAAM,IAAI,IAAI,CAAC,mBAAmB,EAAE;YACnC,IAAI,CAAC,mBAAmB,EAAE,CAAC;SAC5B;QACD,IAAI,CAAC,KAAK,GAAG;YACX,YAAY,EAAE,MAAM;YACpB,YAAY,EAAE,MAAM;SACrB,CAAA;IACH,CAAC;IAEM,eAAe;QACpB,IAAI,QAAQ,CAAC,cAAc,EAAE;YAC3B,QAAQ,CAAC,cAAc,EAAE,CAAC;YAC1B,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;YAC1B,IAAI,CAAC,KAAK,GAAG;gBACX,YAAY,EAAE,OAAO;gBACrB,YAAY,EAAE,OAAO;aACtB,CAAA;SACF;IACH,CAAC;IAED,qBAAqB,CAAC,OAAe;QACnC,MAAM,YAAY,GAAG,QAAQ,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;QACtD,IAAI,YAAY,EAAE;YAChB,YAAY,CAAC,KAAK,EAAE,CAAC;SACtB;IACH,CAAC;IAED,wBAAwB,CAAC,KAAU,EAAE,QAAgB;QACnD,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC;QACnC,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;QACjD,IAAI,MAAM,EAAE;YACV,IAAI,KAAK,GAAG,EAAE,CAAC;YACX,OAAO,CAAC,GAAG,CAAC,oBAAoB,EAAE,KAAK,CAAC,CAAA;YAE5C,MAAM,CAAC,KAAK,CAAC,eAAe,GAAG,MAAM,CAAA;YACrC,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,GAAG,IAAI,KAAK,CAAA;YAChC,MAAM,CAAC,KAAK,CAAC,eAAe,GAAG,KAAK,CAAC;YACrC,IAAI,CAAC,UAAU,EAAE,CAAA;YACjB,uFAAuF;YACvF,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjB,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;aACvB;SACF;IACH,CAAC;IAED,QAAQ;QACN,MAAM,WAAW,GAAG,IAAI,IAAI,EAAE,CAAC;QAC/B,MAAM,GAAG,GAAG,WAAW,CAAC,OAAO,EAAE,CAAE;QACnC,MAAM,KAAK,GAAG,WAAW,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;QACzC,MAAM,IAAI,GAAG,WAAW,CAAC,WAAW,EAAE,CAAC;QACvC,MAAM,aAAa,GAAG,GAAG,IAAI,IAAI,KAAK,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,IAAI,GAAG,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC;QACxG,IAAI,CAAC,KAAK,GAAG,aAAa,CAAC;QAC3B,qCAAqC;QACrC,MAAM,KAAK,GAAG,UAAU,CAAC;QACzB,MAAM,WAAW,GAAG,IAAI,KAAK,GAAG,CAAC;QACjC,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACtD,IAAI,MAAM,EAAE;YACV,IAAI,CAAC,UAAU,IAAI,SAAS,WAAW,SAAS,CAAC;YACjD,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,UAAU,CAAC;SACzC;aAAM;YACL,IAAI,CAAC,UAAU,IAAI,SAAS,WAAW,SAAS,CAAC;YACjD,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,UAAU,CAAC;SACzC;IACH,CAAC;IAED,gBAAgB;QACd,MAAM,UAAU,GAAG,UAAU,CAAC;QAC9B,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACtD,IAAI,MAAM,EAAE;YACV,IAAI,CAAC,UAAU,IAAI,SAAS,UAAU,SAAS,CAAC;YAChD,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,UAAU,CAAC;SACzC;aAAM;YACL,IAAI,CAAC,UAAU,IAAI,SAAS,UAAU,SAAS,CAAC;YAChD,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,UAAU,CAAC;SACzC;IACH,CAAC;IAED,eAAe;QACb,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACtD,IAAI,MAAM,EAAE;YACV,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,CAAA;YAC3B,IAAI,IAAS,CAAC;YACd,6BAA6B;YAC7B,IAAI,GAAG;gBACL,KAAK,EAAE;oBACL,GAAG,EAAE,SAAS;iBACf;aACF,CAAA;YACD,MAAM,CAAC,SAAS,GAAG,EAAE,CAAA;YACrB,IAAI,CAAC,wBAAwB,CAAC,IAAI,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAA;SACnD;IACH,CAAC;IAGD,YAAY;QACV,IAAI,CAAC,SAAS,EAAE,CAAC;QAChB,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAEvD,IAAI,MAAM,EAAE;YACV,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;SACxD;IACH,CAAC;IAED,OAAO;QACL,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;IAED,SAAS;QACP,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAEtD,IAAI,MAAM,EAAE;YACV,MAAM,aAAa,GAAG,MAAM,CAAC,SAAS,CAAC;YACvC,IAAI,IAAI,CAAC,YAAY,KAAK,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE;gBACjD,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;gBACjC,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;aACrB;iBAAM;gBACL,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC,CAAC;gBAC5D,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;gBACjC,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;aACrB;YACD,IAAI,CAAC,YAAY,EAAE,CAAC;SACrB;IACH,CAAC;IACD,IAAI;QACF,IAAI,IAAI,CAAC,YAAY,GAAG,CAAC,EAAE;YACzB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;YACrD,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YAEtD,IAAI,MAAM,EAAE;gBACV,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;aACzD;SACF;IACH,CAAC;IAED,IAAI;QACF,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE;YAC7B,MAAM,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC;YACzC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,WAAY,CAAC,CAAC;YAChC,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YAEtD,IAAI,MAAM,EAAE;gBACV,IAAI,CAAC,gBAAgB,GAAG,WAAY,CAAC;aACtC;SACF;IACH,CAAC;IAED,UAAU,CAAC,IAAU;QACnB,IAAI,EAAE,GAAG,EAAE,CAAA;QACX,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACtD,IAAI,MAAM,EAAE;YACV,MAAM,CAAC,KAAK,EAAE,CAAA;YACd,IAAI,MAAM,CAAC,KAAK,CAAC,eAAe,KAAK,iBAAiB,EAAE;gBACtD,EAAE,GAAG,oBAAoB,CAAA;aAC1B;iBAAM;gBACL,EAAE,GAAG,MAAM,CAAC,KAAK,CAAC,eAAe,CAAC;aACnC;YACD,OAAO,iCAAiC,EAAE,0BAA0B,IAAI,QAAQ,CAAA;SAChF;aACG;YACH,OAAO,QAAQ,IAAI,QAAQ,CAAA;SAC3B;IAEJ,CAAC;IAEA,SAAS;QACR,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,mBAAmB,CAAC,CAAA;QAC/D,IAAI,OAAO,IAAI,MAAM,EAAE;YACrB,OAAO,8BAA8B,CAAA;SACtC;aAAM;YACL,OAAO,8BAA8B,CAAA;SACtC;IACH,CAAC;IAED,YAAY;QACV,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,mBAAmB,CAAC,CAAA;QAC/D,IAAI,OAAO,IAAI,MAAM,EAAE;YACrB,OAAO,iBAAiB,CAAA;SACzB;aAAM;YACL,OAAO,iBAAiB,CAAA;SACzB;IACH,CAAC;;uHAhlCU,0BAA0B;2GAA1B,0BAA0B,wYAN1B,CAAC;YACV,OAAO,EAAE,iBAAiB;YAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,0BAA0B,CAAC;YACzD,KAAK,EAAE,IAAI;SACZ,CAAC,oEAIQ,WAAW,mFClBvB,63iBA0PM;2FD1OO,0BAA0B;kBAVtC,SAAS;+BACE,sBAAsB,aAGrB,CAAC;4BACV,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,2BAA2B,CAAC;4BACzD,KAAK,EAAE,IAAI;yBACZ,CAAC;6KAIuC,QAAQ;sBAAjD,SAAS;uBAAC,WAAW,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAE9B,QAAQ;sBAAhB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACI,gBAAgB;sBAAzB,MAAM;gBACG,oBAAoB;sBAA7B,MAAM;gBAEE,KAAK;sBAAb,KAAK;gBAEI,eAAe;sBAAxB,MAAM","sourcesContent":["import { AfterViewInit, Component, EventEmitter, forwardRef, Input, OnChanges, OnInit, Output, Renderer2, SimpleChanges, ViewChild } from '@angular/core';\nimport { ControlValueAccessor, FormControl, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { SafeHtml, DomSanitizer } from '@angular/platform-browser';\nimport { Router, ActivatedRoute } from '@angular/router';\nimport { NgbDropdown } from '@ng-bootstrap/ng-bootstrap';\n\n@Component({\n  selector: 'el-header-and-footer',\n  templateUrl: './el-header-and-footer.component.html',\n  styleUrls: ['./el-header-and-footer.component.scss'],\n  providers: [{\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => ElHeaderAndFooterComponent),\n    multi: true\n  }]\n})\nexport class ElHeaderAndFooterComponent implements  ControlValueAccessor, OnChanges, AfterViewInit {\n\n @ViewChild(NgbDropdown, { static: true }) dropdown!: NgbDropdown;\n\n  @Input() editorId: string = '';\n  @Input() editorText: string = '';\n  @Input() editorFrom: string = '';\n  @Input() clear: boolean = false;\n  @Input() editorAction: any;\n  @Input() style: any;\n  @Input() bgColor: any;\n  @Input() toolbarMode: 'fixed' | 'bubble' | 'none' = 'fixed';\n  @Output() editorTextChange = new EventEmitter<string>();\n  @Output() editorActionResponse = new EventEmitter<any>();\n  \n  @Input() value: string = '';\n    \n  @Output() editorTextClear = new EventEmitter<any>();\n\n  sanitizedContent!: SafeHtml;\n\n\n  showToolbar = false;\n  toolbarTop = 0;\n  toolbarLeft = 0;\n\n  fonts = ['Arial', 'Courier New', 'Georgia', 'Times New Roman', 'Verdana'];\n  fontSizes = [10, 12, 14, 16, 18, 20, 24, 28, 32, 36];\n  selectedFont = 'Arial';\n  selectedFontSize = 14;\n  isTableSelected = false;\n  tableAdded = false;\n  selectedTable: HTMLTableElement | null = null;\n  isPlaceholderVisible = true;\n  selectedCell: HTMLTableCellElement | null = null;\n  \n  isBoldActive: boolean = false;\n  isItalicActive: boolean = false;\n  isUnderlineActive: boolean = false;\n  isStrikethroughActive: boolean = false;\n  isSubscriptActive: boolean = false;\n  isSuperscriptActive: boolean = false;\n\n  selectedFormatBlock: string = 'normal'\n\n  undoStack: string[] = [];\n  redoStack: string[] = [];\n  history: string[] = [];\n  historyIndex = -1;\n\n  selectedImage: HTMLImageElement | null = null;\n  imageEditUrl: string = '';\n  imagePositionX = 0;\n  imagePositionY = 0;\n  imageResizeStartX = 0;\n  imageResizeStartY = 0;\n  imageResizeStartWidth = 0;\n  imageResizeStartHeight = 0;\n  imageResizeDirection: 'topLeft' | 'topRight' | 'bottomLeft' | 'bottomRight' | null = null;\n\n  // editorText1 = ``;\n  selectedTextColor: any;\n  onChange: any = () => {};\n  onTouched: any = () => {};\n  color: any = '#ddd';\n  colorFormControl!: FormControl;\n  backgroundColor: any;\n  selectedItemIndex: number | null = null;\n\n  parsedTable: { headers: string[], rows: string[][] } | null = null;\n\n  isFullScreen: boolean = false;\n  today: string = '';\n  CanvasColor: string = '#fff';\n\n  constructor(\n    private router: Router,\n    private route: ActivatedRoute,\n    private renderer: Renderer2,\n    private sanitizer: DomSanitizer\n  ) { }\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['bgColor']) {\n      const event = { color:{ hex : this.bgColor} }\n      this.setCanvasBackgroundColor(event, this.editorId)\n    }\n  }\n   ngAfterViewInit() {\n    this.initEditor();\n    this.checkPlaceholder();\n    this.setupHistory(); \n  }\n\n  ngOnInit(): void {\n    this.init_Func(this.editorText)\n    document.addEventListener('selectionchange', () => {\n      this.checkActiveStates();\n      this.checkFormatBlock(this.editorId);\n    });\n    this.addClickListenerToImages();\n    this.addClickListenerToElements();\n    // this.route.queryParams.subscribe(params => {\n    //   const data = JSON.parse(params['data']);\n    //   if (data.editedIMG) {\n    //     const imgUrl = sessionStorage.getItem('editImageFromTemp');\n    //     if (imgUrl) {\n    //       this.replaceImageSrc(imgUrl, data.index.index)\n    //     }\n    //     sessionStorage.removeItem('editImageFromTemp');\n    //   }\n    // })\n\n    \n  }\n\n  writeValue(value: any): void {\n    if (value !== undefined) {\n      this.editorText = value;\n      this.initEditor();\n      this.init_Func(this.editorText);\n    }\n  }\n\n  // private addClickListenerToImages() {\n  //   const editor = document.getElementById('editor');\n  //   if (editor) {\n  //     editor.addEventListener('click', (event) => {\n  //       const target = event.target as HTMLElement;\n  //       if (target.tagName === 'IMG') {\n  //         this.selectedImage = target as HTMLImageElement;\n  //         this.imageEditUrl = this.selectedImage.src;\n  //         // Position the edit button near the selected image\n  //       } else {\n  //         this.selectedImage = null;\n  //       }\n  //     });\n  //   }\n  // }\n  \n  private addClickListenerToImages() {\n  const editor = document.getElementById(this.editorId);\n  if (editor) {\n    editor.addEventListener('click', (event) => {\n      const target = event.target as HTMLElement;\n      if (target.tagName === 'IMG') {\n        this.selectedImage = target as HTMLImageElement;\n        this.imageEditUrl = this.selectedImage.src;\n\n        // Get the index of the selected image\n        const images = editor.getElementsByTagName('img');\n        for (let i = 0; i < images.length; i++) {\n          if (images[i] === this.selectedImage) {\n            this.selectedItemIndex = i;\n            break;\n          }\n        }\n\n        if (this.toolbarMode === 'bubble') {\n          this.onTextSelect();\n        }\n      } else {\n        this.selectedImage = null;\n        this.selectedItemIndex = null;\n      }\n    });\n  }\n  }\n  \n  private addClickListenerToElements() {\n  const editor = document.getElementById(this.editorId);\n  if (editor) {\n    editor.addEventListener('click', (event) => {\n      const target = event.target as HTMLElement;\n\n      // Handle images\n      if (target.tagName === 'IMG') {\n        this.selectedImage = target as HTMLImageElement;\n        this.imageEditUrl = this.selectedImage.src;\n\n        // Get the index of the selected image\n        const images = editor.getElementsByTagName('img');\n        for (let i = 0; i < images.length; i++) {\n          if (images[i] === this.selectedImage) {\n            this.selectedItemIndex = i;\n            break;\n          }\n        }\n      } else {\n        this.selectedImage = null;\n      }\n      if (target.tagName === 'TD' || target.tagName === 'TH') {\n        this.selectedTable = target.closest('table') as HTMLTableElement;\n\n        const cells = this.selectedTable.getElementsByTagName(target.tagName);\n        for (let i = 0; i < cells.length; i++) {\n          if (cells[i] === target) {\n            this.selectedItemIndex = i;\n            break;\n          }\n        }\n      } else {\n        this.selectedTable = null;\n      }\n\n      if (target.tagName === 'P' || target.tagName === 'SPAN' || target.tagName === 'DIV') {\n        const paragraphs = editor.getElementsByTagName(target.tagName);\n        for (let i = 0; i < paragraphs.length; i++) {\n          if (paragraphs[i] === target) {\n            this.selectedItemIndex = i;\n            break;\n          }\n        }\n      } else {\n      }\n    });\n  }\n  }\n\nreplaceImageSrc(newSrc: string, index: number) {\n  const editor = document.getElementById(this.editorId);\n  if (editor) {\n    editor.focus()\n    const images = editor.getElementsByTagName('IMG');\n\n    if (index >= 0 ) {\n      images[index].setAttribute('src', newSrc);\n    } else {\n      console.warn(`Index ${index} is out of bounds. Total images: ${images.length}`);\n    }\n  } else {\n    console.error('Editor element not found');\n  }\n}\n\n\n\n  private initEditor() {\n    // Initialize editor content and listeners\n    const editor = document.getElementById(this.editorId);\n\n    if (editor) {\n      editor.innerHTML = this.editorText;\n      editor.addEventListener('input', () => {\n        this.onModelChange(editor.innerHTML);\n      });\n    }\n    this.checkPlaceholder();\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState?(isDisabled: boolean): void {\n    // Handle the disabled state if necessary\n  }\n\n  onModelChange(value: any): void {\n    if (value) {\n      const VALUE = value\n      this.editorText = this.mainCanvas(VALUE);\n      this.onChange(this.mainCanvas(VALUE));\n      this.editorTextChange.emit(this.mainCanvas(VALUE));\n      \n    } else {\n      this.selectedImage = null;\n    }\n  }\n\n  applyImageStyles(content: string): string {\n    const div = document.createElement('div');\n    div.innerHTML = content;\n    const images = div.querySelectorAll('img');\n    images.forEach(img => {\n      if (img.style.maxWidth >= '700px') {\n        img.style.maxWidth = '700px';\n        // img.width = 300;\n        img.style.height = 'auto';\n      } else {\n        img.style.maxWidth = '100%';\n        img.style.height = 'auto';\n      }\n    });\n    return div.innerHTML;\n  }\n\n  init_Func(html: any) {\n    if (html) {\n      let editor = document.getElementById(this.editorId);\n      if (editor) { \n        editor.focus()\n         this.setEditorContent(html);\n\n      // Set up a MutationObserver to handle content changes\n      this.setupMutationObserver(editor);\n\n      // Move the caret to the end after initial content setup\n      this.moveCaretToEnd(editor);\n        // editor.focus()\n        // editor.innerHTML = html;\n        // this.sanitizedContent = this.sanitizer.bypassSecurityTrustHtml(this.applyImageStyles(html));\n        // editor.innerHTML = this.sanitizedContent as string;\n        // editor.addEventListener('input', () => {\n        //   if (editor) {\n        //     editor.focus()\n        //     this.onModelChange(editor.innerHTML);\n        //   }\n        // });\n      }\n    } else {\n      this.selectedImage = null;\n    }\n  }\n\n  private setEditorContent(html: string) {\n  let editor = document.getElementById(this.editorId);\n  if (editor) {\n    // Sanitize and apply styles to the HTML\n    this.sanitizedContent = this.sanitizer.bypassSecurityTrustHtml(this.applyImageStyles(html));\n    editor.innerHTML = this.sanitizedContent as string;\n  }\n}\n\nprivate setupMutationObserver(editor: HTMLElement) {\n  const observer = new MutationObserver(() => {\n    // Move the caret to the end after content changes\n    this.moveCaretToEnd(editor);\n    // Update model with the current content\n    this.onModelChange(editor.innerHTML);\n  });\n\n  observer.observe(editor, { childList: true, subtree: true, characterData: true });\n}\n\nprivate moveCaretToEnd(editor: HTMLElement) {\n  const selection = window.getSelection();\n  const range = document.createRange();\n  \n  if (editor.lastChild) {\n    range.selectNodeContents(editor);\n    range.collapse(false); // Collapse to the end\n    selection?.removeAllRanges();\n    selection?.addRange(range);\n  }\n}\n  // format(command: string, value?: any) {\n  //   document.execCommand(command, false, value ?? '');\n  //   //  if (command === 'underline') {\n  //   //     // Toggle underline\n  //   //     const isUnderlined = document.queryCommandState('underline');\n  //   //     document.execCommand('underline', false, isUnderlined ? 'false' : 'true');\n  //   // } else {\n  //   //     document.execCommand(command, false, '');\n  //   // }\n  // }\n\n  onFormatChange(data: any) {\n    const value = data;\n    this.selectedFormatBlock = value;\n  if (value) {\n    this.format('formatBlock', this.editorId, value);\n  }\n}\n\n\n  format(command: string, editorId: string, value?: any) {\n    const editor = document.getElementById(editorId);\n    if (editor) {\n      editor.focus();\n      if (command === 'subscript') {\n        this.isSubscriptActive = !this.isSubscriptActive;\n        document.execCommand('subscript', false, '');\n      } else if (command === 'superscript') {\n        this.isSuperscriptActive = !this.isSuperscriptActive;\n        document.execCommand('superscript', false, '');;\n      } else {\n        document.execCommand(command, false, value ?? '');\n        if (value) {\n          const tag = value.toLowerCase().replace(/[<>]/g, '')\n          const toolbar = document.getElementById(editorId + 'toolbar');\n          if (toolbar) {\n            this.selectedFormatBlock = this.formatBlockDecode(tag);\n          }\n        }\n      }\n    }\n     this.checkActiveStates();\n     this.checkFormatBlock(editorId);\n  }\n\n  checkActiveStates() {\n    this.isBoldActive = document.queryCommandState('bold');\n    this.isItalicActive = document.queryCommandState('italic');\n    this.isUnderlineActive = document.queryCommandState('underline');\n    this.isStrikethroughActive = document.queryCommandState('strikethrough');\n    this.isSubscriptActive = document.queryCommandState('subscript');\n    this.isSuperscriptActive = document.queryCommandState('superscript');\n  }\n\n  checkFormatBlock(editorId: string) {\n    const editor = document.getElementById(editorId);\n    if (editor) {\n      const formatBlock = document.queryCommandValue('formatBlock');\n       const toolbar = document.getElementById(editorId + 'toolbar');\n      if (toolbar) {\n        this.selectedFormatBlock = this.formatBlockDecode(formatBlock);\n      }\n      // You can further handle the formatBlock value as needed\n    }\n  }\n\n  formatBlockDecode(data: string): any {\n    switch (data) {\n      case 'h1':\n        return 'heading 1';\n        break;\n      case 'h2':\n        return 'heading 2';\n        break;\n      case 'h3':\n        return 'heading 3';\n        break;\n      case 'h4':\n        return 'heading 4';\n        break;\n      case 'h5':\n        return 'heading 5';\n        break;\n      case 'h6':\n        return 'heading 6';\n        break;\n      case 'p':\n        return 'normal';\n        break;\n      default:\n        return 'normal';\n        break;\n    }\n  }\n\n  changeFont(event: any) {\n    this.selectedFont = event\n    document.execCommand('fontName', false, this.selectedFont);\n  }\n\n  insertCodeBlock() {\n    const code = `\n      <pre style=\"font-size: 12px;\n                  color: white;\n                  background-color: black;\n                  overflow-x: auto;\n                  margin-bottom: 5px;\n                  margin-top: 5px;\n                  padding: 5px 10px;\">\n        <code style=\"display: block;\n                     white-space: pre-wrap;\n                     height: auto;\n                     font-family: Menlo, Monaco, Consolas, 'Courier New', monospace;\n                     font-size: 14px;\" class=\"language-html\">Insert code here...</code>\n      </pre>\n    `;\n    document.execCommand('insertHTML', false, code);\n  }\n\n  // changeFontSize(event: any) {\n  //   document.execCommand('fontSize', false, '7');\n  //   let editor = document.getElementById('editor');\n  //   if (editor) {\n  //     let fontElements = editor.getElementsByTagName('font');\n  //     for (let i = 0; i < fontElements.length; i++) {\n  //       if (fontElements[i].size == \"7\") {\n  //         fontElements[i].removeAttribute(\"size\");\n  //         fontElements[i].style.fontSize = this.selectedFontSize + 'px';\n  //       }\n  //     }\n  //   }\n  // }\n  changeFontSize(event: any) {\n    const selectedText = window.getSelection();\n    \n    if (selectedText && selectedText.rangeCount > 0) {\n        const range = selectedText.getRangeAt(0);\n        const span = document.createElement('span');\n        span.style.fontSize = this.selectedFontSize + 'px';\n        range.surroundContents(span);\n    }\n  }\n\n  addLink() {\n    let url = prompt(\"Enter the link here: \", \"http://\");\n    if (url) {\n      document.execCommand(\"createLink\", false, url);\n    }\n  }\n\n  insertsImage(editorId: string) {\n    const editor = document.getElementById(editorId);\n    if (editor) {\n      editor.focus();\n      let imageInput = document.getElementById('imageInput') as HTMLInputElement;\n      if (imageInput) {\n        imageInput.click();\n      }\n    }\n  }\n\n   handleImageUpload(event: any) {\n  const file = event.target.files[0];\n  if (file) {\n    const reader = new FileReader();\n    reader.onload = (e: any) => {\n      const img = new Image();\n      img.src = e.target.result;\n      img.onload = () => {\n        // Create the HTML string with the exact width and height\n        const imgHTML = `<img src=\"${img.src}\" width=\"${img.width}\" height=\"${img.height}\">`;\n        // Insert the image into the editor\n        document.execCommand('insertHTML', false, imgHTML);\n      };\n    };\n    reader.readAsDataURL(file);\n  }\n}\n\n\n  addTable(editorId: string) {\n    const tableWidth = 825; // Table width in pixels\n    const cols = 3; // Number of columns\n    const cellMinWidth = tableWidth / cols; // Calculate minimum width for each cell\n\n    let table = `<br /><table style=\"border-collapse: collapse; width: ${tableWidth}px; border: 1px solid black;\">`;\n    for (let i = 0; i < 3; i++) { // Number of rows\n      table += '<tr>';\n      for (let j = 0; j < cols; j++) {\n        table += `<td style=\"border: 1px solid #000; word-wrap: break-word; word-break: break-all; white-space: normal; min-width: ${cellMinWidth}px;\">&nbsp;</td>`;\n      }\n      table += '</tr>';\n    }\n      table += '</table><br/ >';\n      // document.execCommand('insertHTML', false, table);\n      const editor = document.getElementById(editorId);\n    if (editor) {\n      editor.focus();\n      document.execCommand('insertHTML', false, table);\n    }\n    this.tableAdded = true;\n    this.checkTableSelection();\n  }\n\n\n\n  checkTableSelection(event?: MouseEvent) {\n    let target = event?.target as HTMLElement;\n    if (target && (target.tagName === 'TD' || target.tagName === 'TH')) {\n      this.isTableSelected = true;\n      this.selectedTable = target.closest('table') as HTMLTableElement;\n    } else {\n      this.isTableSelected = false;\n      this.selectedTable = null;\n    }\n    \n    this.checkPlaceholder();\n  }\n\n  checkPlaceholder() {\n    // let editor = document.getElementById('editor');\n    // if (editor) {\n    //   this.isPlaceholderVisible = editor.innerHTML === '' || editor.innerHTML === '<br>';\n    //   if (this.isPlaceholderVisible) {\n    //     // editor.innerHTML = '<span class=\"placeholder\" style=\"background: transparent; color: #000000\">Insert text here ...</span>';\n    //   } else {\n    //     let placeholder = editor.querySelector('.placeholder');\n    //     if (placeholder) {\n    //       editor.removeChild(placeholder);\n    //     }\n    //   }\n    // }\n  }\n\n  onFocus() {\n    // let editor = document.getElementById('editor');\n    // if (editor && this.isPlaceholderVisible) {\n    //   editor.innerHTML = '';\n    //   this.isPlaceholderVisible = false;\n    // }\n  }\n\n  // colorChange(newColor: string) {\n  //   this.color = newColor;\n  // }\n\n  onBlur() {\n    this.checkPlaceholder();\n  }\n\n  addRow() {\n    if (this.selectedTable) {\n      let row = this.selectedTable.insertRow();\n      for (let i = 0; i < this.selectedTable.rows[0].cells.length; i++) {\n        let cell = row.insertCell(i);\n        cell.innerHTML = '&nbsp;';\n        cell.style.border = '1px solid black';\n      }\n    }\n  }\n\n  // deleteRow() {\n  //   if (this.selectedTable) {\n  //     this.selectedTable.deleteRow(-1);\n  //   }\n  // }\n\n//   deleteRow() {\n//   if (this.selectedTable) {\n//     let rowIndex = this.selectedTable.rows.length - 1; \n//     if (window.getSelection) {\n//       let selection = window.getSelection();\n//       if (selection) {\n//         let row = selection.anchorNode?.parentElement?.closest('tr');\n//         if (row) {\n//           rowIndex = row.rowIndex;\n//         }\n//       }\n//     }\n//     this.selectedTable.deleteRow(rowIndex);\n//   }\n// }\n\n  deleteRow() {\n  const selection = window.getSelection();\n    if (selection) {\n    if (!selection.rangeCount) return;\n\n    const range = selection.getRangeAt(0);\n    const selectedNode = range.startContainer;\n    const row = selectedNode.parentElement?.closest('tr');\n\n    if (row) {\n      const table = row.closest('table');\n      if (table) {\n        table.deleteRow(row.rowIndex);\n      }\n    }\n  }\n}\n\n\n  // addColumn() {\n  //   if (this.selectedTable) {\n  //     for (let i = 0; i < this.selectedTable.rows.length; i++) {\n  //       let cell = this.selectedTable.rows[i].insertCell(-1);\n  //       cell.innerHTML = '&nbsp;';\n  //       cell.style.border = '1px solid black';\n  //     }\n  //   }\n  // }\n\n  addColumn() {\n  if (this.selectedTable) {\n    const columnCount = this.selectedTable.rows[0].cells.length + 1; // New column count\n    const tableWidth = this.selectedTable.offsetWidth;\n    const minWidth = tableWidth / columnCount;\n\n    for (let i = 0; i < this.selectedTable.rows.length; i++) {\n      let cell = this.selectedTable.rows[i].insertCell(-1);\n      cell.innerHTML = '&nbsp;';\n      cell.style.border = '1px solid black';\n      cell.style.minWidth = `${minWidth}px`;\n      cell.style.wordWrap = 'break-word';\n      cell.style.wordBreak = 'break-all';\n      cell.style.whiteSpace = 'normal';\n    }\n\n    // Update existing cells' minWidth\n    for (let i = 0; i < this.selectedTable.rows.length; i++) {\n      for (let j = 0; j < this.selectedTable.rows[i].cells.length; j++) {\n        this.selectedTable.rows[i].cells[j].style.minWidth = `${minWidth}px`;\n      }\n    }\n  }\n}\n\n\n  deleteColumn() {\n  if (this.selectedTable) {\n    if (window.getSelection) {\n      let selection = window.getSelection();\n      if (selection) {\n        let cell = selection.anchorNode?.parentElement?.closest('td, th') as HTMLTableCellElement;\n        if (cell) {\n          let cellIndex = cell.cellIndex;\n          for (let i = 0; i < this.selectedTable.rows.length; i++) {\n            this.selectedTable.rows[i].deleteCell(cellIndex);\n          }\n        }\n      }\n    }\n  }\n}\n\n  // deleteColumn() {\n  //   if (this.selectedTable) {\n  //     for (let i = 0; i < this.selectedTable.rows.length; i++) {\n  //       this.selectedTable.rows[i].deleteCell(-1);\n  //     }\n  //   }\n  // }\n\n  adjustTableWidth(event: any) {\n    if (this.selectedTable) {\n      this.selectedTable.style.width = event.target.value + 'px';\n    }\n  }\n\n  adjustCellWidth(event: any) {\n    if (this.selectedTable) {\n      for (let i = 0; i < this.selectedTable.rows.length; i++) {\n        for (let j = 0; j < this.selectedTable.rows[i].cells.length; j++) {\n          this.selectedTable.rows[i].cells[j].style.width = event.target.value + 'px';\n        }\n      }\n    }\n  }\n\n  adjustCellHeight(event: any) {\n    if (this.selectedTable) {\n      for (let i = 0; i < this.selectedTable.rows.length; i++) {\n        for (let j = 0; j < this.selectedTable.rows[i].cells.length; j++) {\n          this.selectedTable.rows[i].cells[j].style.height = event.target.value + 'px';\n        }\n      }\n    }\n  }\n\n  private setCaretToEnd(element: HTMLElement) {\n    const range = document.createRange();\n    const sel = window.getSelection();\n      if (sel) {\n      range.selectNodeContents(element);\n    range.collapse(false);\n    sel.removeAllRanges();\n    sel.addRange(range);\n    }\n  }\n\n  openColorPicker(inputId: string) {\n    const inputElement = document.getElementById(inputId);\n    if (inputElement) {\n      inputElement.click();\n    }\n  }\n\n  setTextColor(event: any, editorId: any) {\n    const editor = document.getElementById(editorId);\n    if (editor) {\n      editor.focus();\n      const color = event.color.hex;\n      this.selectedTextColor = color;\n      document.execCommand('foreColor', true, color);\n      if (this.dropdown) {\n        this.dropdown.close();\n      }\n    }\n  }\n\n  setBackgroundColor(event: any, editorId: string) {\n    const editor = document.getElementById(editorId);\n    if (editor) {\n      editor.focus();\n      const color = event.color.hex;\n      this.backgroundColor = color;\n      document.execCommand('hiliteColor', true, color);\n      if (this.dropdown) {\n        this.dropdown.close();\n      }\n    }\n  }\n\n  // colorChanged(event: any) {\n  //   this.color = event.color.hex; \n  // }\n\n  public logEvent(event: any, trigger: any) {\n    const color = event;\n    this.setTextColor(color, this.editorId)\n    this.selectedTextColor = event\n    document.execCommand('foreColor', false, event);\n    // this.logs.unshift([this.logs.length + 1, trigger, event]);\n  }\n\n  editImage() {\n    let data \n    switch (this.editorFrom) {\n      case 'section-content':\n        data = { editIMG: true, from: 'htmlEditor', index: this.selectedItemIndex };\n        this.navigateToIMGEditor(data);\n        sessionStorage.setItem('editImageFromTemp', JSON.stringify(this.imageEditUrl));\n        sessionStorage.setItem('textEditor', this.editorText);\n        break;\n      case 'template':\n        data = { editIMG: true, from: 'templateEditor', index: this.selectedItemIndex };\n        this.navigateToIMGEditor(data);\n        // sessionStorage.setItem('editImageFromTemp2', JSON.stringify(this.imageEditUrl));\n        sessionStorage.setItem('templateEditor', this.editorText);\n        break;\n      default:\n        sessionStorage.removeItem('editImageFromTemp');\n        // sessionStorage.removeItem('editImageFromTemp2');\n        sessionStorage.removeItem('templateEditor');\n        sessionStorage.removeItem('textEditor');\n        break;\n    }\n    // if (this.editorFrom === 'section-content') {\n    //   const data = {editIMG: true, from: 'htmlEditor', index: this.selectedItemIndex}\n    //   this.navigateToIMGEditor(data)\n    //   sessionStorage.setItem('editImageFromTemp', JSON.stringify(this.imageEditUrl))\n    //   sessionStorage.setItem('textEditor', this.editorText)\n    // } \n    \n  }\n\n  navigateToIMGEditor(data: any) {\n    this.router.navigate(['/admin/image-editor'], { queryParams: {data : JSON.stringify(data)} })\n  }\n\n  //  onTextSelect(event: MouseEvent): void {\n  //   if (this.toolbarMode === 'bubble') {\n  //     const selection = window.getSelection();\n  //     if (selection && selection.rangeCount > 0) {\n  //       const range = selection.getRangeAt(0);\n  //       if (!range.collapsed) {\n  //         const rect = range.getBoundingClientRect();\n  //         this.toolbarTop = rect.bottom + window.scrollY + 10;\n  //         this.toolbarLeft = rect.left + window.scrollX + (rect.width / 2) - 50;\n  //         this.showToolbar = true;\n  //       } else {\n  //         this.showToolbar = false;\n  //       }\n  //     }\n  //   }\n  // }\n\n onTextSelect(event?: MouseEvent): void {\n  if (this.toolbarMode === 'bubble') {\n    const selection = window.getSelection();\n    if (selection && selection.rangeCount > 0) {\n      const range = selection.getRangeAt(0);\n      if (!range.collapsed) {\n        const rect = range.getBoundingClientRect();\n        const scrollY =  document.documentElement.scrollTop;\n        const scrollX =  document.documentElement.scrollLeft;\n        this.toolbarTop = rect.top + scrollY - 75;\n        this.toolbarLeft = rect.left + scrollX + (rect.width / 2) - 325;\n        this.showToolbar = true;\n      } else {\n        this.showToolbar = false;\n      }\n    } else {\n      this.showToolbar = false;\n    }\n  }\n}\n\n\nonPaste(event: ClipboardEvent) {\n    event.preventDefault();\n    const clipboardData = event.clipboardData;\n    if (clipboardData) {\n      const pastedText = clipboardData.getData('text/plain');\n      if (this.isTableData(pastedText)) {\n        const html = this.convertTextToTable(pastedText);\n        this.insertHtmlAtCaret(html);\n      } else {\n        this.insertHtmlAtCaret(pastedText);\n      }\n    }\n  }\n\n  isTableData(text: string): boolean {\n    const rows = text.split('\\n');\n    return rows.length > 1 && rows[0].split('\\t').length > 1;\n  }\n\n  convertTextToTable(text: string): string {\n    const rows = text.split('\\n').filter(row => row.trim() !== '');\n    const tableRows = rows.map(row => {\n      const cells = row.split('\\t').map(cell => `<td class=\"px-1 py-1  style=\"border: 1px solid #000\">${cell}</td>`).join('');\n      return `<tr >${cells}</tr>`;\n    }).join('');\n    return `<table>${tableRows}</table>`;\n  }\n\n  insertHtmlAtCaret(html: string) {\n    const range = window.getSelection()?.getRangeAt(0);\n    if (range) {\n      range.deleteContents();\n      const tempDiv = document.createElement('div');\n      tempDiv.innerHTML = html;\n      const frag = document.createDocumentFragment();\n      let node;\n      while ((node = tempDiv.firstChild)) {\n        frag.appendChild(node);\n      }\n      range.insertNode(frag);\n      range.collapse(false);\n    }\n  }\n\n \n  public openFullscreen() {\n    var elem: any = document.getElementById(\"textEditor\");\n    this.isFullScreen = true;\n    if (elem.requestFullscreen) {\n      elem.requestFullscreen();\n    } else if (elem.mozRequestFullScreen) {\n      elem.mozRequestFullScreen();\n    } else if (elem.webkitRequestFullscreen) {\n      elem.webkitRequestFullscreen();\n    } else if (elem.msRequestFullscreen) {\n      elem.msRequestFullscreen();\n    }\n    this.style = {\n      'min-height': '90vh',\n      'max-height': '90vh',\n    }\n  }\n\n  public closeFullscreen() {\n    if (document.exitFullscreen) {\n      document.exitFullscreen();\n      this.isFullScreen = false;\n      this.style = {\n        'min-height': '400px',\n        'max-height': '400px',\n      }\n    }\n  }\n\n  openCanvasColorPicker(inputId: string) {\n    const inputElement = document.getElementById(inputId);\n    if (inputElement) {\n      inputElement.click();\n    }\n  }\n\n  setCanvasBackgroundColor(event: any, editorId: string): void {\n    this.CanvasColor = event.color.hex;\n    const editor = document.getElementById(editorId);\n    if (editor) {\n      let color = '';\n          console.log('event bg color  = ', event)\n\n      editor.style.backgroundColor = '#fff'\n      color = event.color.hex || event\n      editor.style.backgroundColor = color;\n      this.mainCanvas()\n      // this.init_Func(`<div style=\"background-color: ${color};\">${this.editorText}</div>`);\n      if (this.dropdown) {\n        this.dropdown.close();\n      }\n    }\n  }\n\n  getToday() {\n    const currentDate = new Date();\n    const day = currentDate.getDate() ;\n    const month = currentDate.getMonth() + 1; \n    const year = currentDate.getFullYear();\n    const formattedDate = `${year}-${month.toString().padStart(2, '0')}-${day.toString().padStart(2, '0')}`;\n    this.today = formattedDate;\n    // const label = `{(${this.today})}`;\n    const label = `{(date)}`;\n    const htmlContent = ` ${label} `;\n    const editor = document.getElementById(this.editorId);\n    if (editor) {\n      this.editorText += `<div> ${htmlContent} </div>`;\n      this.sanitizedContent = this.editorText;\n    } else {\n      this.editorText += `<div> ${htmlContent} </div>`;\n      this.sanitizedContent = this.editorText;\n    }\n  }\n\n  insertPageNumber() {\n    const pageNumber = '{(page)}';\n    const editor = document.getElementById(this.editorId);\n    if (editor) {\n      this.editorText += `<div> ${pageNumber} </div>`;\n      this.sanitizedContent = this.editorText;\n    } else {\n      this.editorText += `<div> ${pageNumber} </div>`;\n      this.sanitizedContent = this.editorText;\n    }\n  }\n\n  clearTextEditor() {\n    const editor = document.getElementById(this.editorId);\n    if (editor) {\n      this.editorTextClear.emit()\n      let data: any;\n      // data.color.hex = '#ffffff'\n      data = {\n        color: {\n          hex: '#353343'\n        }\n      }\n      editor.innerHTML = ''\n      this.setCanvasBackgroundColor(data, this.editorId)\n    }\n  }\n\n  \n  setupHistory() {\n    this.saveState();\n     const editor = document.getElementById(this.editorId);\n  \n    if (editor) {\n      editor.addEventListener('input', () => this.onInput());\n    }\n  }\n\n  onInput() {\n    this.saveState();\n  }\n\n  saveState() {\n    const editor = document.getElementById(this.editorId);\n  \n    if (editor) {\n      const editorContent = editor.innerHTML;\n      if (this.historyIndex === this.history.length - 1) {\n        this.history.push(editorContent);\n        this.redoStack = [];\n      } else {\n        this.history = this.history.slice(0, this.historyIndex + 1);\n        this.history.push(editorContent);\n        this.redoStack = [];\n      }\n      this.historyIndex++;\n    }\n  }\n  undo() {\n    if (this.historyIndex > 0) {\n      this.redoStack.push(this.history[this.historyIndex]);\n      this.historyIndex--;\n      const editor = document.getElementById(this.editorId);\n  \n      if (editor) {\n        this.sanitizedContent = this.history[this.historyIndex];\n      }\n    }\n  }\n\n  redo() {\n    if (this.redoStack.length > 0) {\n      const redoContent = this.redoStack.pop();\n      this.history.push(redoContent!);\n      this.historyIndex++;\n      const editor = document.getElementById(this.editorId);\n  \n      if (editor) {\n        this.sanitizedContent = redoContent!;\n      }\n    }\n  }\n\n  mainCanvas(data?: any) {\n    let BG = ''\n    const editor = document.getElementById(this.editorId);\n    if (editor) {\n      editor.focus()\n      if (editor.style.backgroundColor === 'rgb(53, 51, 67)') {\n        BG = 'rgb(255, 255, 255)'\n      } else {\n        BG = editor.style.backgroundColor;\n      } \n      return `<div style=\"background-color: ${BG}; padding: 10px 15px;\">${data}</div>`\n     }\n    else {\n      return `<div>${data}</div>`\n     }\n    \n  }\n\n   themeMode() {\n    const clrMode = document.body.getAttribute('data-layout-color')\n    if (clrMode == 'dark') {\n      return '2px solid #414141 !important'\n    } else {\n      return '2px solid #D0D0D0 !important'\n    }\n  }\n\n  themeModeClr() {\n    const clrMode = document.body.getAttribute('data-layout-color')\n    if (clrMode == 'dark') {\n      return '#fff !important'\n    } else {\n      return '#000 !important'\n    }\n  }\n\n\n}\n","<div class=\"container els-text-editor px-0\">\r\n    <div class=\"btn-toolbar els-btn-toolbar p-2 py-2 mb-0\" role=\"toolbar\" [id]=\"editorId+'toolbar'\"\r\n        aria-label=\"Toolbar with button groups\">\r\n        <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Header Options\">\r\n            <!-- <div class=\"dropdown\">\r\n                <select class=\"els-form-select \" style=\" font-weight: 700 !important; color: #fff; width: 150px; border: 2px solid #7D6D6D !important;\" (change)=\"onFormatChange($event)\">\r\n                    <option [value]=\"'<h1>'\">Heading 1</option>\r\n                    <option [value]=\"'<h2>'\">Heading 2</option>\r\n                    <option [value]=\"'<h3>'\">Heading 3</option>\r\n                    <option [value]=\"'<h4>'\">Heading 4</option>\r\n                    <option [value]=\"'<h5>'\">Heading 5</option>\r\n                    <option [value]=\"'<h6>'\">Heading 6</option>\r\n                    <option selected [value]=\"'<p>'\">Normal</option>\r\n                </select>\r\n            </div> -->\r\n            <div ngbDropdown class=\"dropdown\">\r\n                <button class=\"btn btn-sm els-form-select border els-toolbar-dropdown-button dropdown-toggle text-start\"\r\n                 [style.border]=\"themeMode()\" [style.color]=\"themeModeClr()\"\r\n                    id=\"headerDropdown\" ngbDropdownToggle>\r\n                    <span style=\"width: 85px; font-weight: 700 !important;\">{{selectedFormatBlock | titlecase}}</span>\r\n                    <i class=\"mdi mdi-chevron-down \"></i>\r\n                </button>\r\n                <div ngbDropdownMenu aria-labelledby=\"headerDropdown\" class=\"els-text-format\">\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"onFormatChange('<h1>')\" [style.color]=\"themeModeClr()\">\r\n                        <h1>Heading 1</h1>\r\n                    </button>\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"onFormatChange('<h2>')\" [style.color]=\"themeModeClr()\">\r\n                        <h2>Heading 2</h2>\r\n                    </button>\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"onFormatChange('<h3>')\" [style.color]=\"themeModeClr()\">\r\n                        <h3>Heading 3</h3>\r\n                    </button>\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"onFormatChange('<h4>')\" [style.color]=\"themeModeClr()\">\r\n                        <h4>Heading 4</h4>\r\n                    </button>\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"onFormatChange('<h5>')\" [style.color]=\"themeModeClr()\">\r\n                        <h5>Heading 5</h5>\r\n                    </button>\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"onFormatChange('<h6>')\" [style.color]=\"themeModeClr()\">\r\n                        <h6>Heading 6</h6>\r\n                    </button>\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"onFormatChange('<p>')\" [style.color]=\"themeModeClr()\">\r\n                        <p>Normal</p>\r\n                    </button>\r\n                </div>\r\n            </div>\r\n        </div>\r\n        <div class=\"btn-group els-button-group\" role=\"group\" aria-label=\"Font Options\">\r\n            <div ngbDropdown class=\"dropdown\">\r\n                <button class=\"btn btn-sm els-form-select border els-toolbar-dropdown-button dropdown-toggle text-start\"\r\n                    id=\"headerDropdown\"  [style.border]=\"themeMode()\" [style.color]=\"themeModeClr()\" ngbDropdownToggle>\r\n                    <span style=\"width: 85px; font-weight: 700 !important;\" class=\"text-truncate\">{{selectedFont |\r\n                        titlecase}}</span>\r\n                    <i class=\"mdi mdi-chevron-down \"></i>\r\n                </button>\r\n                <div ngbDropdownMenu aria-labelledby=\"headerDropdown\" class=\"els-text-format\">\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" *ngFor=\"let font of fonts\"\r\n                        (click)=\"changeFont(font)\">\r\n                        <span>{{ font }}</span>\r\n                    </button>\r\n                </div>\r\n            </div>\r\n        </div>\r\n\r\n        <div class=\"border py-0\" [style.border]=\"themeMode()\" style=\"height: fit-content;\">\r\n            <div class=\"btn-group els-button-group mr-2 \" role=\"group\" aria-label=\"Text Formatting\">\r\n                <button type=\"button\" class=\"btn btn-sm els-toolbar-button\" [class.active]=\"isBoldActive\"\r\n                    (click)=\"format('bold', editorId)\">\r\n                    <i class=\"mdi mdi-format-bold\"></i>\r\n                </button>\r\n                <button type=\"button\" class=\"btn btn-white els-toolbar-button\" [class.active]=\"isItalicActive\"\r\n                    (click)=\"format('italic', editorId)\">\r\n                    <i class=\"mdi mdi-format-italic\"></i>\r\n                </button>\r\n                <button type=\"button\" class=\"btn btn-white els-toolbar-button\" [class.active]=\"isUnderlineActive\"\r\n                    (click)=\"format('underline', editorId)\">\r\n                    <i class=\"mdi mdi-format-underline\"></i>\r\n                </button>\r\n                <button type=\"button\" class=\"btn btn-white els-toolbar-button\" [class.active]=\"isStrikethroughActive\"\r\n                    (click)=\"format('strikethrough', editorId)\">\r\n                    <i class=\"mdi mdi-format-strikethrough-variant\"></i>\r\n                </button>\r\n                <div class=\"btn-group\" role=\"group\" aria-label=\"Text Color\">\r\n                    <!-- <input type=\"color\" id=\"textColorPicker\"\r\n                                style=\"position: absolute; top: 100%; left: 0; z-index: 100; opacity: 0;\"\r\n                                (change)=\"setTextColor($event)\">\r\n                            <button type=\"button\" class=\"btn btn-white els-toolbar-button\" style=\"position: relative;\"\r\n                                (click)=\"openColorPicker('textColorPicker')\">\r\n                                <i class=\"mdi mdi-format-color-text icon-with-underline\" [style.color]=\"selectedTextColor\"></i>\r\n                            </button> -->\r\n                    <div ngbDropdown class=\"ql-align\">\r\n                        <button type=\"button\"\r\n                            class=\"btn btn-outline-primary els-toolbar-button arrow-none text-secondary border-none p-0\"\r\n                            id=\"dropdownBasic1\" aria-expanded=\"false\" ngbDropdownToggle>\r\n                            <i class=\"mdi mdi-format-color-text icon-with-underline\"\r\n                                [style.color]=\"selectedTextColor ?? '#000'\"></i>\r\n                        </button>\r\n                        <div ngbDropdownMenu aria-labelledby=\"dropdownBasic1\" style=\"width: 200px;\">\r\n                            <color-sketch color=\"#fff\" [presetColors]=\"[]\"\r\n                                (onChangeComplete)=\"setTextColor($event, editorId)\"></color-sketch>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n                <div class=\"btn-group\" role=\"group\" aria-label=\"Background Color\" style=\"position: relative;\">\r\n                    <!-- <button type=\"button\" class=\"btn btn-white els-toolbar-button\" [style.color]=\"backgroundColor\"\r\n                                (click)=\"openColorPicker('bgColorPicker')\">\r\n                                <i class=\"mdi mdi-alpha-a-box\"></i>\r\n                            </button>\r\n                            <input type=\"color\" id=\"bgColorPicker\"\r\n                                style=\"position: absolute; top: 100%; left: 0; z-index: 100; opacity: 0;\"\r\n                                (change)=\"setBackgroundColor($event)\"> -->\r\n                    <div ngbDropdown class=\"ql-align\">\r\n                        <button type=\"button\"\r\n                            class=\"btn btn-outline-primary els-toolbar-button arrow-none text-secondary border-none p-0\"\r\n                            id=\"dropdownBasic1\" aria-expanded=\"false\" ngbDropdownToggle>\r\n                            <i class=\"mdi mdi-alpha-a-box\" [style.color]=\"backgroundColor ?? '#000'\"></i>\r\n                        </button>\r\n                        <div ngbDropdownMenu aria-labelledby=\"dropdownBasic1\" style=\"width: 200px;\">\r\n                            <color-sketch color=\"#fff\" [presetColors]=\"[]\"\r\n                                (onChangeComplete)=\"setBackgroundColor($event, editorId)\"></color-sketch>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n\r\n            </div>\r\n            <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Text Formatting\">\r\n                <button type=\"button\" class=\"btn btn-white els-toolbar-button\"\r\n                    (click)=\"format('insertOrderedList', editorId)\"><i\r\n                        class=\"mdi mdi-format-list-numbered\"></i></button>\r\n                <button type=\"button\" class=\"btn btn-white els-toolbar-button\"\r\n                    (click)=\"format('insertUnorderedList', editorId)\"><i\r\n                        class=\"mdi mdi-format-list-bulleted\"></i></button>\r\n                <div ngbDropdown class=\"ql-align\">\r\n                    <button type=\"button\" class=\"btn btn-white els-toolbar-button arrow-none text-secondary\"\r\n                        id=\"dropdownBasic1\" aria-expanded=\"false\" ngbDropdownToggle>\r\n                        <i class=\"mdi mdi-format-align-left \"></i>\r\n                    </button>\r\n                    <div ngbDropdownMenu aria-labelledby=\"dropdownBasic1\" style=\"width: 3px;\">\r\n                        <button type=\"button\" class=\"btn btn-white els-toolbar-button\" style=\"color: #7A7982;\"\r\n                            (click)=\"format('justifyLeft', editorId)\"><i class=\"mdi mdi-format-align-left\"></i></button>\r\n                        <button type=\"button\" class=\"btn btn-white els-toolbar-button\" style=\"color: #7A7982;\"\r\n                            (click)=\"format('justifyCenter', editorId)\"><i\r\n                                class=\"mdi mdi-format-align-center\"></i></button>\r\n                        <button type=\"button\" class=\"btn btn-white els-toolbar-button\" style=\"color: #7A7982;\"\r\n                            (click)=\"format('justifyRight', editorId)\"><i\r\n                                class=\"mdi mdi-format-align-right\"></i></button>\r\n                        <button type=\"button\" class=\"btn btn-white els-toolbar-button\" style=\"color: #7A7982;\"\r\n                            (click)=\"format('justifyFull', editorId)\"><i\r\n                                class=\"mdi mdi-format-align-justify\"></i></button>\r\n                    </div>\r\n                </div>\r\n\r\n            </div>\r\n            <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Text Formatting\">\r\n                <button type=\"button\" class=\"btn btn-white els-toolbar-button\" [class.active]=\"isSubscriptActive\"\r\n                    (click)=\"format('subscript', editorId)\">\r\n                    <i class=\"mdi mdi-format-subscript\"></i>\r\n                </button>\r\n                <button type=\"button\" class=\"btn btn-white els-toolbar-button\" [class.active]=\"isSuperscriptActive\"\r\n                    (click)=\"format('superscript', editorId)\">\r\n                    <i class=\"mdi mdi-format-superscript\"></i>\r\n                </button>\r\n\r\n            </div>\r\n            <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Table Options\">\r\n\r\n                <div ngbDropdown class=\"ql-align\">\r\n                    <button type=\"button\" class=\"btn btn-outline-primary arrow-none els-toolbar-button  border-none p-0\"\r\n                        id=\"dropdownBasic1\" aria-expanded=\"false\" ngbDropdownToggle>\r\n                        <i class=\"mdi mdi-format-color-fill\"></i>\r\n                    </button>\r\n                    <div ngbDropdownMenu aria-labelledby=\"dropdownBasic1\" style=\"width: 200px;\">\r\n                        <color-sketch color=\"#fff\"\r\n                            (onChangeComplete)=\"setCanvasBackgroundColor($event, editorId)\"></color-sketch>\r\n                    </div>\r\n                </div>\r\n\r\n            </div>\r\n            <div class=\"btn-group els-button-group-2 mr-3\" role=\"group\" aria-label=\"Table Options\">\r\n                <button class=\"btn btn-white  px-1\" style=\"height: 24px;\" (click)=\"getToday()\">Date</button>\r\n            </div>\r\n            <div class=\"btn-group els-button-group-2\" role=\"group\" aria-label=\"Table Options\">\r\n                <button class=\"btn btn-white  px-1\" style=\"height: 24px;\" (click)=\"insertPageNumber()\">Page\r\n                    No</button>\r\n\r\n            </div>\r\n            <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Text Formatting\">\r\n                <button type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"addLink()\"><i\r\n                        class=\"mdi mdi-link-variant\"></i></button>\r\n                <button type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"insertsImage(editorId)\"><i\r\n                        class=\"mdi mdi-image\"></i></button>\r\n                <input type=\"file\" id=\"imageInput\" style=\"display: none;\" (change)=\"handleImageUpload($event)\">\r\n\r\n            </div>\r\n            <!-- <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Table Options\">\r\n                        <button type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"addTable()\"><i\r\n                                class=\"mdi mdi-table\"></i></button>\r\n                        <button *ngIf=\"isTableSelected\" type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"addRow()\"><i\r\n                                class=\"mdi mdi-table-row-plus-after\"></i></button>\r\n                        <button *ngIf=\"isTableSelected\" type=\"button\" class=\"btn btn-white els-toolbar-button\"\r\n                            (click)=\"deleteRow()\"><i class=\"mdi mdi-table-row-remove\"></i></button>\r\n                        <button *ngIf=\"isTableSelected\" type=\"button\" class=\"btn btn-white els-toolbar-button\"\r\n                            (click)=\"addColumn()\"><i class=\"mdi mdi-table-column-plus-after\"></i></button>\r\n                        <button *ngIf=\"isTableSelected\" type=\"button\" class=\"btn btn-white els-toolbar-button\"\r\n                            (click)=\"deleteColumn()\"><i class=\"mdi mdi-table-column-remove\"></i></button>\r\n                    </div>\r\n                    <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Table Options\">\r\n                        <button *ngIf=\"selectedImage\" class=\"btn btn-white els-toolbar-button-2\" (click)=\"editImage()\"\r\n                            style=\"position: absolute;\">Edit Image</button>\r\n                    </div> -->\r\n            <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Text Formatting\">\r\n                <button type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"undo()\">\r\n                    <i class=\"mdi mdi-undo\"></i>\r\n                </button>\r\n                <button type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"redo()\">\r\n                    <i class=\"mdi mdi-redo\"></i>\r\n                </button>\r\n\r\n            </div>\r\n            <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Table Options\">\r\n                <!-- <button *ngIf=\"selectedImage\" class=\"btn btn-white els-toolbar-button-2\" (click)=\"editImage()\"\r\n                                    style=\"position: absolute;\">Edit Image</button> -->\r\n                <button class=\"btn btn-white els-toolbar-button\" (click)=\"clearTextEditor()\">\r\n                    <i class=\"mdi mdi-close-circle\"></i>\r\n                </button>\r\n            </div>\r\n\r\n        </div>\r\n    </div>\r\n\r\n\r\n    <div contenteditable=\"true\" [id]=\"editorId\" class=\"els-border p-3\" #editor\r\n        style=\"position: relative !important; height: 130px; max-width: 100%; overflow: hidden; \"\r\n        [ngStyle]=\"{'font-family': selectedFont, 'font-size': selectedFontSize + 'px'}\" [style]=\"style\"\r\n        contenteditable=\"true\" (input)=\"onModelChange($event)\" placeholder=\"Insert text here ...\"\r\n        (mouseup)=\"onTextSelect($event)\" [innerHTML]=\"sanitizedContent\" (paste)=\"onPaste($event)\" (focus)=\"onFocus()\"\r\n        (blur)=\"onBlur()\" (click)=\"checkTableSelection($event)\">\r\n    </div>\r\n    <table *ngIf=\"parsedTable\">\r\n        <thead>\r\n            <tr>\r\n                <th *ngFor=\"let header of parsedTable.headers\">{{ header }}</th>\r\n            </tr>\r\n        </thead>\r\n        <tbody>\r\n            <tr *ngFor=\"let row of parsedTable.rows\">\r\n                <td *ngFor=\"let cell of row\">{{ cell }}</td>\r\n            </tr>\r\n        </tbody>\r\n    </table>\r\n</div>"]}
|