el-header-and-footer 0.0.1

Sign up to get free protection for your applications and to get access to all the features.
@@ -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;">&nbsp;</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 = '&nbsp;';
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 = '&nbsp;';
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 = '&nbsp;';
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":"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","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>"]}