el-text-editor 0.0.78 → 0.0.80

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -996,13 +996,25 @@ export class ElTextEditorComponent {
996
996
  addRow() {
997
997
  if (this.selectedTable) {
998
998
  let row = this.selectedTable.insertRow();
999
- row.style.borderBottom = this.themeModeClrVerticalLineForTable(); // Add bottom border to the row
999
+ // Loop through the columns of the first row to determine the number of cells
1000
1000
  for (let i = 0; i < this.selectedTable.rows[0].cells.length; i++) {
1001
1001
  let cell = row.insertCell(i);
1002
1002
  cell.innerHTML = '&nbsp;';
1003
+ // Apply bottom border explicitly
1004
+ cell.style.borderBottom = `2px solid ${this.themeModeClrVerticalLineColorForTable()}`; // You can replace 'black' with your theme color
1003
1005
  }
1004
1006
  }
1005
1007
  }
1008
+ // addRow() {
1009
+ // if (this.selectedTable) {
1010
+ // let row = this.selectedTable.insertRow();
1011
+ // row.style.borderBottom = this.themeModeClrVerticalLineForTable(); // Add bottom border to the row
1012
+ // for (let i = 0; i < this.selectedTable.rows[0].cells.length; i++) {
1013
+ // let cell = row.insertCell(i);
1014
+ // cell.innerHTML = '&nbsp;';
1015
+ // }
1016
+ // }
1017
+ // }
1006
1018
  // deleteRow() {
1007
1019
  // if (this.selectedTable) {
1008
1020
  // this.selectedTable.deleteRow(-1);
@@ -1082,6 +1094,7 @@ export class ElTextEditorComponent {
1082
1094
  cell.style.wordBreak = 'break-all';
1083
1095
  cell.style.whiteSpace = 'normal';
1084
1096
  cell.style.minWidth = `${minWidth}px`;
1097
+ cell.style.borderBottom = `2px solid ${this.themeModeClrVerticalLineColorForTable()}`;
1085
1098
  }
1086
1099
  // Update existing rows' bottom border
1087
1100
  for (let i = 0; i < this.selectedTable.rows.length; i++) {
@@ -1114,6 +1127,15 @@ export class ElTextEditorComponent {
1114
1127
  return '2px solid #5F5F5F !important';
1115
1128
  }
1116
1129
  }
1130
+ themeModeClrVerticalLineColorForTable() {
1131
+ const clrMode = document.body.getAttribute('data-layout-color');
1132
+ if (clrMode == 'dark') {
1133
+ return '#414141';
1134
+ }
1135
+ else {
1136
+ return '#5F5F5F';
1137
+ }
1138
+ }
1117
1139
  adjustTableWidth(event) {
1118
1140
  if (this.selectedTable) {
1119
1141
  this.selectedTable.style.width = event.target.value + 'px';
@@ -1158,24 +1180,58 @@ export class ElTextEditorComponent {
1158
1180
  inputElement.click();
1159
1181
  }
1160
1182
  }
1183
+ // setTextColor(event: any) {
1184
+ // if (this.savedSelection) {
1185
+ // const color = event.target.value;
1186
+ // this.selectedTextColor = color;
1187
+ // // Restore the saved selection
1188
+ // const selection = window.getSelection();
1189
+ // if (selection) {
1190
+ // selection.removeAllRanges();
1191
+ // selection.addRange(this.savedSelection);
1192
+ // // Apply the color using a span
1193
+ // const range = this.savedSelection;
1194
+ // const span = document.createElement('span');
1195
+ // span.style.color = color;
1196
+ // span.textContent = range.toString();
1197
+ // // Replace the selected text with the styled span
1198
+ // range.deleteContents();
1199
+ // range.insertNode(span);
1200
+ // // Clear the saved selection
1201
+ // this.savedSelection = null;
1202
+ // }
1203
+ // }
1204
+ // }
1161
1205
  setTextColor(event) {
1162
1206
  if (this.savedSelection) {
1163
1207
  const color = event.target.value;
1164
1208
  this.selectedTextColor = color;
1165
1209
  // Restore the saved selection
1166
1210
  const selection = window.getSelection();
1167
- if (selection) {
1168
- selection.removeAllRanges();
1169
- selection.addRange(this.savedSelection);
1170
- // Apply the color using a span
1211
+ if (selection && selection.rangeCount > 0) {
1171
1212
  const range = this.savedSelection;
1172
- const span = document.createElement('span');
1173
- span.style.color = color;
1174
- span.textContent = range.toString();
1175
- // Replace the selected text with the styled span
1213
+ selection.removeAllRanges();
1214
+ selection.addRange(range);
1215
+ // Get selected elements
1216
+ const selectedContent = range.cloneContents();
1217
+ const elements = Array.from(selectedContent.querySelectorAll("*")); // ✅ Explicitly cast to HTMLElement[]
1218
+ // Apply color to each element without modifying structure
1219
+ elements.forEach((el) => {
1220
+ el.style.color = color;
1221
+ });
1222
+ // Apply color to the top-level text nodes (without wrapping them)
1223
+ Array.from(selectedContent.childNodes).forEach((node) => {
1224
+ if (node.nodeType === Node.TEXT_NODE && node.textContent?.trim() !== "") {
1225
+ const parent = range.commonAncestorContainer.parentElement;
1226
+ if (parent) {
1227
+ parent.style.color = color;
1228
+ }
1229
+ }
1230
+ });
1231
+ // Replace selected content
1176
1232
  range.deleteContents();
1177
- range.insertNode(span);
1178
- // Clear the saved selection
1233
+ range.insertNode(selectedContent);
1234
+ // Clear saved selection
1179
1235
  this.savedSelection = null;
1180
1236
  }
1181
1237
  }
@@ -1648,4 +1704,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImpor
1648
1704
  type: ViewChild,
1649
1705
  args: ['fullscreen']
1650
1706
  }] } });
1651
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"el-text-editor.component.js","sourceRoot":"","sources":["../../../../projects/el-text-editor/src/lib/el-text-editor.component.ts","../../../../projects/el-text-editor/src/lib/el-text-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, Input, OnInit, Output, EventEmitter, forwardRef, ViewChild, ElementRef, Renderer2, OnChanges, SimpleChanges } from '@angular/core';\nimport { ControlValueAccessor, FormControl, NG_VALUE_ACCESSOR } from '@angular/forms';\n// import { MatDialog } from '@angular/material/dialog';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { Router, ActivatedRoute } from '@angular/router';\nimport { NgxFullscreenDirective } from '@ultimate/ngx-fullscreen';\nimport * as XLSX from 'xlsx';\n// import { ImageEditorModalComponent } from '../modals/image-editor-modal/image-editor-modal.component';\nimport { compress, decompress } from 'lz-string';\n\n\n@Component({\n  selector: 'text-editor',\n  templateUrl: './el-text-editor.component.html',\n  styleUrls: ['./el-text-editor.component.scss'],\n    providers: [{\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => ElTextEditorComponent),\n    multi: true\n  }]\n})\nexport class ElTextEditorComponent implements ControlValueAccessor, AfterViewInit, OnChanges {\n\n  @Input() editorText: string = '';\n  @Input() editorFrom: any;\n  @Input() editorAction: any;\n  @Input() UserRole: any;\n  @Input() style: any;\n  @Input() disableToolbar: any;\n  @Input() placeHolder: any;\n  @Input() reportId: any;\n  @Input() backgroundImage: any;\n  @Input() toolbarMode: 'fixed' | 'bubble' | 'none' = 'fixed';\n  @Output() editorTextChange = new EventEmitter<string>();\n  @Output() editorActionResponse = new EventEmitter<any>();\n  @Output() editorTextClear = new EventEmitter<any>();\n  @Output() imageEdit = new EventEmitter<any>();\n  @Output() imageEdit2 = new EventEmitter<any>();\n  @Output() placeHolderRemove = new EventEmitter<any>();\n  @Output() isOpen = new EventEmitter<any>();\n  @Output() newImageAdded = new EventEmitter<any>();\n  \n  @Input() value: string = '';\n\n  \n  @ViewChild('textEditor') TextEditor!:  ElementRef<Element>;\n  @ViewChild('fullscreen') fullscreen!: NgxFullscreenDirective\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  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  undoStack: string[] = [];\n  redoStack: string[] = [];\n  history: string[] = [];\n  historyIndex = -1;\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  currentCaretPosition: any;\n  userRole: any[] = [];\n  showEditButton: boolean = false;\n\n  constructor(\n    private router: Router,\n    private route: ActivatedRoute,\n    private renderer: Renderer2,\n    private sanitizer: DomSanitizer,\n  ) {\n    this.getUserRoles()\n\n    \n  }\n\n  themeMode() {\n    const clrMode = document.body.getAttribute('data-layout-color')\n    if (clrMode == 'dark') {\n      return '2px solid #403F4A !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  themeModeClrVerticalLine() {\n    const clrMode = document.body.getAttribute('data-layout-color')\n    if (clrMode == 'dark') {\n      return '2px solid #FFFFFF !important'\n    } else {\n      return '2px solid #D0D0D0 !important'\n    }\n  }\n\n  themeModeBgClr() {\n    const clrMode = document.body.getAttribute('data-layout-color')\n    if (clrMode == 'dark') {\n      return '#282828 !important'\n    } else {\n      return '#F3F3F3 !important'\n    }\n  }\n\n  themeModeBorderTop() {\n    const clrMode = document.body.getAttribute('data-layout-color')\n    if (clrMode == 'dark') {\n      return '2px solid #000 !important'\n    } else {\n      return '2px solid #fff !important'\n    }\n  }\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['placeHolder']) {\n      this.insertAtCaret(this.placeHolder)\n\n    }\n\n    if (changes['reportId']) {\n      sessionStorage.setItem('reportId', this.reportId)\n    } \n\n    if (changes['UserRole']) { \n      this.getUserRoles()\n    }\n  }\n  ngAfterViewInit() {\n    this.initEditor();\n    this.checkPlaceholder();\n    this.setupHistory();\n    document.addEventListener('fullscreenchange', this.onFullscreenChange);\n  }\n\n  ngOnInit(): void {\n    this.init_Func(this.editorText)\n    document.addEventListener('selectionchange', () => {\n      this.checkActiveStates();\n      this.checkFormatBlock();\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   ngOnDestroy() {\n    // Cleanup the event listener when the component is destroyed\n    document.removeEventListener('fullscreenchange', this.onFullscreenChange);\n  }\n\n  IsOpen: boolean = false;\n\n    toggleFullscreen1() {\n      this.IsOpen = !this.IsOpen;\n      this.isOpen.emit(this.IsOpen)\n      if (this.IsOpen) { \n        this.fullscreen.enter(this.TextEditor.nativeElement);\n      } else {\n        this.fullscreen.exit()\n      }\n    }\n  \n  private onFullscreenChange = () => {\n    if (!document.fullscreenElement) {\n      // When fullscreen mode is exited\n      this.IsOpen = false;\n      this.isOpen.emit(this.IsOpen);\n    }\n  };\n  \n  // enterFullscreenVideo() {\n  //   console.log('event:', event);\n  //   const fullscreen = event;\n  //   this.isOpen = event;\n  //   if (fullscreen) {\n  //     this.fullscreen.enter(this.TextEditor.nativeElement);\n  //   } else {\n  //     this.fullscreen.exit()\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\n//         let container = this.selectedImage.parentElement;\n//         if (!container || container.className !== 'image-container') {\n//           container = document.createElement('div');\n//           container.className = 'image-container';\n//           container.style.position = 'relative';\n//           container.style.display = 'inline-block';\n//           this.selectedImage.parentNode?.insertBefore(container, this.selectedImage);\n//           container.appendChild(this.selectedImage);\n//         }\n//         const existingButton = container.querySelector('.image-edit-button');\n//         if (existingButton) {\n//           existingButton.remove();\n//         }\n\n//         const button = document.createElement('button');\n//         // button.textContent = 'Edit';\n//         button.innerText = 'Edit Image';\n\n//         button.className = 'image-edit-button btn btn-sm';\n//         button.style.position = 'absolute';\n//         button.style.top = '50%';\n//         button.style.left = '50%';\n//         button.style.transform = 'translate(-50%, -50%)';\n//         button.style.zIndex = '1000';\n//         button.style.backgroundColor = '#fff';\n//         button.style.border = '2px solid #fff';\n//         // button.style.padding = '10px';\n//         button.style.color = '#313a46';\n//         button.style.cursor = 'pointer';\n\n//         button.addEventListener('click', (e) => {\n//           e.stopPropagation();\n//           this.editImage();\n//         });\n\n//         container.appendChild(button);\n//       } else {\n//         this.selectedImage = null;\n//         this.selectedItemIndex = null;\n//       }\n//     });\n//   }\n  // }\n  getUserRoles() {\n    this.userRole = this.UserRole\n  }\n  // roleCheck() {\n  //   for (let i = 0; i < this.userRole.length; ++i) {\n  //     const roleName = []\n  //       roleName.push(this.userRole[i]?.name);\n  //     return this.userRole[i]?.name;\n  //   }\n  // }\n\n  roleCheck() {\n    let userRoleName: string[] = [];\n    for (let i = 0; i <= this.userRole.length; ++i) {\n      userRoleName.push(this.userRole[i]?.name);\n    }\n    return userRoleName;\n  }\n\n\n// private addClickListenerToImages() {\n//   const editor = document.getElementById('editor');\n//   const roles = this.roleCheck(); // Get user roles dynamically\n//   const isAdmin = roles.includes('Admin');\n//   const isCreator = roles.includes('Creator');\n//   const isApprover = roles.includes('Approver');\n  \n//   if (isCreator || isAdmin) {\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//         let container = this.selectedImage.parentElement;\n//         if (!container || container.className !== 'image-container') {\n//           container = document.createElement('div');\n//           container.className = 'image-container';\n//           container.style.position = 'relative';\n//           container.style.display = 'inline-block';  \n//           this.selectedImage.parentNode?.insertBefore(container, this.selectedImage);\n//           container.appendChild(this.selectedImage);\n//         }\n\n//         const existingButton = container.querySelector('.image-edit-button');\n//         if (existingButton) {\n//           existingButton.remove();\n//         }\n\n//         const button = document.createElement('button');\n//         button.textContent  = 'Edit Image';\n//         button.className = 'image-edit-button btn btn-sm';\n//         button.style.position = 'absolute';\n//         button.style.top = '50%';\n//         button.style.left = '50%';\n//         button.style.transform = 'translate(-50%, -50%)';\n//         button.style.zIndex = '1000';\n//         button.style.backgroundColor = '#fff'; \n//         button.style.border = '2px solid #fff'; \n//         button.style.color = '#313a46';\n//         button.style.cursor = 'pointer';\n//         button.style.userSelect = 'none';\n\n//         button.addEventListener('click', (e) => {\n//           e.stopPropagation();\n//           this.editImage();\n//         });\n\n//         container.appendChild(button);\n\n//       } else {\n//         this.selectedImage = null;\n//         this.selectedItemIndex = null;\n//         const buttons = document.querySelectorAll('.image-edit-button');\n//         buttons.forEach(button => button.remove());\n//       }\n//     });\n//   }\n//   }\n  // }\n  private addClickListenerToImages() {\n  const editor = document.getElementById('editor');\n  const roles = this.roleCheck(); // Get user roles dynamically\n  const isAdmin = roles.includes('Admin');\n  const isCreator = roles.includes('Creator');\n\n  if (isCreator || isAdmin) {\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          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          let container = this.selectedImage.parentElement;\n          if (!container || container.className !== 'image-container') {\n            container = document.createElement('div');\n            container.className = 'image-container';\n            container.style.position = 'relative';\n            container.style.display = 'inline-block';\n            this.selectedImage.parentNode?.insertBefore(container, this.selectedImage);\n            container.appendChild(this.selectedImage);\n          }\n\n          const existingButton = container.querySelector('.image-edit-button');\n          if (existingButton) {\n            existingButton.remove();\n          }\n\n          const button = document.createElement('button');\n          button.textContent = 'Edit Image';\n          button.className = 'image-edit-button btn btn-sm';\n          button.style.position = 'absolute';\n          button.style.top = '50%';\n          button.style.left = '50%';\n          button.style.transform = 'translate(-50%, -50%)';\n          button.style.zIndex = '1000';\n          button.style.backgroundColor = '#fff';\n          button.style.border = '2px solid #fff';\n          button.style.color = '#313a46';\n          button.style.cursor = 'pointer';\n          button.style.userSelect = 'none';\n\n          button.addEventListener('click', (e) => {\n            e.stopPropagation();\n            this.editImage();\n          });\n\n          container.appendChild(button);\n        } else {\n          this.removeEditButtons();\n        }\n      });\n\n      // Monitor editor content changes to handle image deletion\n      const observer = new MutationObserver(() => {\n        const buttons = editor.querySelectorAll('.image-edit-button');\n        buttons.forEach((button) => {\n          const container = button.parentElement;\n          if (container && !container.querySelector('img')) {\n            button.remove(); // Remove the button if the associated image is gone\n            container.remove(); // Clean up the container\n          }\n        });\n      });\n\n      // Observe changes in the editor\n      observer.observe(editor, { childList: true, subtree: true });\n    }\n  }\n}\n\nprivate removeEditButtons() {\n  const buttons = document.querySelectorAll('.image-edit-button');\n  buttons.forEach((button) => button.remove());\n  this.selectedImage = null;\n  this.selectedItemIndex = null;\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\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('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        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        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      }\n    });\n  }\n  }\n\nreplaceImageSrc(newSrc: string, index: number) {\n  const editor = document.getElementById('editor');\n  \n  if (editor) {\n    editor.focus()\n    const images = editor.getElementsByTagName('IMG');\n    if (index >= 0 ) {\n      images[index].setAttribute('src', newSrc);\n    } \n  }\n}\n\n\n\n  private initEditor() {\n    // Initialize editor content and listeners\n    const editor = document.getElementById('editor');\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 = VALUE;\n      this.onChange(VALUE);\n      this.editorTextChange.emit(VALUE);\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('editor');\n  //     if (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//   init_Func(html: any) {\n//   if (html) {\n//     let editor = document.getElementById('editor');\n//     if (editor) {\n//       // Initialize the editor with sanitized content\n      \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\n//       // Track caret position on mouse click\n//       editor.addEventListener('click', () => {\n//         if (editor) {  // Ensure editor is not null\n//           // this.trackCaretPosition(editor);\n//         }\n//       });\n//     }\n//   } else {\n//     this.selectedImage = null;\n//   }\n// }\n\n// private setEditorContent(html: string) {\n//   let editor = document.getElementById('editor');\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\n// private setupMutationObserver(editor: HTMLElement) {\n//   const observer = new MutationObserver(() => {\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\n// This function tracks the caret position based on the mouse click\nprivate trackCaretPosition(editor: HTMLElement) {\n  const selection = window.getSelection();\n  if (selection && selection.rangeCount > 0) {\n    const range = selection.getRangeAt(0);\n    const startNode = range.startContainer;\n    const startOffset = range.startOffset;\n\n\n    // You can use this information to insert content or perform actions based on the caret position\n    // Example: Save the current caret position for future use\n    this.currentCaretPosition = { node: startNode, offset: startOffset };\n  }\n  }\n  \n  // Method to get caret position and insert new data\nprivate insertAtCaret(newData: string): void {\n  const selection = window.getSelection();\n  \n  if (selection && selection.rangeCount > 0) {\n    // Get the current range (caret position)\n    const range = selection.getRangeAt(0);\n\n    // Create a document fragment to insert (allows handling HTML strings)\n    const fragment = document.createDocumentFragment();\n    const tempDiv = document.createElement('div');\n    tempDiv.innerHTML = newData;\n\n    // Append the new data to the fragment (supports HTML insertion)\n    while (tempDiv.firstChild) {\n      fragment.appendChild(tempDiv.firstChild);\n    }\n\n    // Insert the fragment at the caret position\n    range.deleteContents(); // Remove any selected content if applicable\n    range.insertNode(fragment);\n\n    // Move the caret after the inserted content\n    const lastChild = fragment.lastChild;\n\n    if (lastChild) {\n      range.setStartAfter(lastChild);\n      range.setEndAfter(lastChild);\n      selection.removeAllRanges();\n      selection.addRange(range);\n    }\n    let editor = document.getElementById('editor');\n    if (editor) {\n      this.moveCaretToEnd(editor)\n    }\n    \n    this.placeHolderRemove.emit()\n  }\n}\n\n\n//   // Move caret to the end of the editor content\n//   private 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//   }\n  \n  \n\n\n  init_Func(html: any) {\n  if (html) {\n    let editor = document.getElementById('editor');\n    if (editor) {\n      // Initialize the editor with sanitized content\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      //  Track caret position on mouse click\n      editor.addEventListener('click', () => {\n        if (editor) {  // Ensure editor is not null\n          this.trackCaretPosition(editor);\n        }\n      });\n    }\n  } else {\n    this.selectedImage = null;\n  }\n}\n\n\nprivate setEditorContent(html: string) {\n  let editor = document.getElementById('editor');\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\n//   init_Func(html: any) {\n//   if (html) {\n//     let editor = document.getElementById('editor');\n//     if (editor) {\n//       editor.focus();\n//       editor.innerHTML = html;\n\n//       // Sanitize the content and apply styles\n//       this.sanitizedContent = this.sanitizer.bypassSecurityTrustHtml(this.applyImageStyles(html));\n//       editor.innerHTML = this.sanitizedContent as string;\n\n//       // Place the caret at the end of the content\n//       const range = document.createRange();\n//       const selection = window.getSelection();\n      \n//       if (editor.lastChild) {\n//         // Set the range at the end of the editor's content\n//         range.selectNodeContents(editor);\n//         range.collapse(false); // collapse to the end\n//         selection?.removeAllRanges();\n//         selection?.addRange(range);\n//       }\n\n//       editor.addEventListener('input', () => {\n//         if (editor) {\n//           this.onModelChange(editor.innerHTML);\n\n//           // Ensure the caret remains at the end after new content is added\n//           const range = document.createRange();\n//           const selection = window.getSelection();\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//       });\n//     }\n//   } else {\n//     this.selectedImage = null;\n//   }\n// }\n\n  format(command: string, value?: any) {\n    const editor = document.getElementById('editor');\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          this.selectedFormatBlock = this.formatBlockDecode(tag);\n        }\n      }\n    }\n     this.checkActiveStates();\n     this.checkFormatBlock();\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() {\n    const editor = document.getElementById('editor');\n    if (editor) {\n      const formatBlock = document.queryCommandValue('formatBlock');\n      this.selectedFormatBlock = this.formatBlockDecode(formatBlock);\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() {\n    const editor = document.getElementById('editor');\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=\"${794}\" >`;\n  //         // Insert the image into the editor\n  //         document.execCommand('insertHTML', false, imgHTML);\n  //       };\n  //     };\n  //     reader.readAsDataURL(file);\n  //   }\n  // }\n\n  handleImageUpload(event: any) {\n  const file = event.target.files[0];\n  const editorElement = document.getElementById('editor'); // Reference to the editor\n\n  if (file && editorElement) {\n    const editorWidth = editorElement.offsetWidth; // Get the editor's width\n    const reader = new FileReader();\n\n    reader.onload = (e: any) => {\n      const img = new Image();\n      img.src = e.target.result;\n\n      img.onload = () => {\n        const imgWidth = img.width;\n\n        // If the image width exceeds the editor's width, fit it to the editor\n        const imgHTML =\n          imgWidth > editorWidth\n            ? `<img src=\"${img.src}\" style=\" max-width: ${700}px; height: auto;\">`\n            : `<img src=\"${img.src}\" style=\"width: ${imgWidth}px; height: auto;\">`;\n        this.newImageAdded.emit()\n        // Insert the image into the editor\n        document.execCommand('insertHTML', false, imgHTML);\n      };\n    };\n\n    reader.readAsDataURL(file);\n  }\n}\n\n\n\n  // addTable() {\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=\"width: ${tableWidth}px;\">`;\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=\" 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('editor');\n  //   if (editor) {\n  //     editor.focus();\n  //     document.execCommand('insertHTML', false, table);\n  //   }\n  //   this.tableAdded = true;\n  //   this.checkTableSelection();\n  // }\n\n  addTable() {\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=\"width: ${tableWidth}px;\">`;\n  for (let i = 0; i < 3; i++) { // Number of rows\n    table += `<tr style=\"border-bottom: ${this.themeModeClrVerticalLineForTable()}\">`; // Add border-bottom to the row\n    for (let j = 0; j < cols; j++) {\n      table += `<td style=\"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\n  const editor = document.getElementById('editor');\n  if (editor) {\n    editor.focus();\n    document.execCommand('insertHTML', false, table);\n  }\n\n  this.tableAdded = true;\n  this.checkTableSelection();\n}\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  addRow() {\n  if (this.selectedTable) {\n    let row = this.selectedTable.insertRow();\n    row.style.borderBottom = this.themeModeClrVerticalLineForTable(); // Add bottom border to the row\n    for (let i = 0; i < this.selectedTable.rows[0].cells.length; i++) {\n      let cell = row.insertCell(i);\n      cell.innerHTML = '&nbsp;';\n    }\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  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.wordWrap = 'break-word';\n      cell.style.wordBreak = 'break-all';\n      cell.style.whiteSpace = 'normal';\n      cell.style.minWidth = `${minWidth}px`;\n    }\n\n    // Update existing rows' bottom border\n    for (let i = 0; i < this.selectedTable.rows.length; i++) {\n      this.selectedTable.rows[i].style.borderBottom = this.themeModeClrVerticalLineForTable();\n    }\n  }\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  themeModeClrVerticalLineForTable() {\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 #5F5F5F !important'\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) {\n  //   const editor = document.getElementById('editor');\n  //   if (editor) {\n  //     editor.focus();\n  //     const color = event.target.value;\n  //     this.selectedTextColor = color;\n  //     document.execCommand('foreColor', false, color);\n  //   }\n  // }\n\n  // setBackgroundColor(event: any) {\n  //   const editor = document.getElementById('editor');\n  //   if (editor) {\n  //     editor.focus();\n  //     const color = event.target.value;\n  //     this.backgroundColor = color;\n  //     document.execCommand('hiliteColor', false, color);\n  //   }\n  // }\n\n  private savedSelection: Range | null = null;\n\nopenColorPicker(inputId: string) {\n  const inputElement = document.getElementById(inputId) as HTMLInputElement;\n  if (inputElement) {\n    // Save the current selection\n    const selection = window.getSelection();\n    if (selection && selection.rangeCount > 0) {\n      this.savedSelection = selection.getRangeAt(0);\n    }\n    inputElement.click();\n  }\n}\n\nsetTextColor(event: any) {\n  if (this.savedSelection) {\n    const color = event.target.value;\n    this.selectedTextColor = color;\n\n    // Restore the saved selection\n    const selection = window.getSelection();\n    if (selection) {\n      selection.removeAllRanges();\n      selection.addRange(this.savedSelection);\n\n      // Apply the color using a span\n      const range = this.savedSelection;\n      const span = document.createElement('span');\n      span.style.color = color;\n      span.textContent = range.toString();\n\n      // Replace the selected text with the styled span\n      range.deleteContents();\n      range.insertNode(span);\n\n      // Clear the saved selection\n      this.savedSelection = null;\n    }\n  }\n}\n\n  setBackgroundColor(event: any) {\n  if (this.savedSelection) {\n    const color = event.target.value;\n    this.backgroundColor = color;\n\n    // Restore the saved selection\n    const selection = window.getSelection();\n    if (selection) {\n      selection.removeAllRanges();\n      selection.addRange(this.savedSelection);\n\n      // Apply the background color using a span\n      const range = this.savedSelection;\n      const span = document.createElement('span');\n      span.style.backgroundColor = color;\n      span.textContent = range.toString();\n\n      // Replace the selected text with the styled span\n      range.deleteContents();\n      range.insertNode(span);\n\n      // Clear the saved selection\n      this.savedSelection = null;\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)\n    this.selectedTextColor = event\n    document.execCommand('foreColor', false, event);\n    // this.logs.unshift([this.logs.length + 1, trigger, event]);\n  }\n  \n\n  editImage() {\n    let data \n    switch (this.editorFrom.name) {\n      case 'section-content':\n        data = { editIMG: true, from: 'htmlEditor', index: this.selectedItemIndex, id: this.editorFrom.id };\n        const compressedData: string = compress(JSON.stringify(this.imageEditUrl));\n        sessionStorage.setItem('editImageFromTemp', compressedData);\n        const compressedData2 = compress(JSON.stringify(this.sanitizedContent));\n        sessionStorage.setItem('textEditor', compressedData2);\n        // alert('go to editor!')\n        this.navigateToIMGEditor(data);\n        this.imageEdit.emit()\n        break;\n      case 'create-document':\n        this.imageEdit.emit()\n        data = { editIMG: true, from: 'createDocument', index: this.selectedItemIndex, id: this.editorFrom.id, section: this.editorFrom.section, reportSectionId: this.editorFrom.reportSectionId };\n        // this.openDialog(data)\n        const compressedData3 = compress(JSON.stringify(this.imageEditUrl));\n        const compressedData4 = compress(this.editorText);\n\n        sessionStorage.setItem('editImageFromTemp2', compressedData3);\n        sessionStorage.setItem('textEditor2', compressedData4);\n        this.navigateToIMGEditor(data);\n        break;\n      default:\n        null\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  openDialog( item: any): void {\n    // let data: any;\n    //   data = item\n    // const dialogRef = this.dialog.open(ImageEditorModalComponent,{\n    //   minWidth: '100%', minHeight: '100vh', panelClass: 'theme-2B2936' ,disableClose: true, data: data\n    // });\n    // dialogRef.afterClosed().subscribe(result => {\n    //   console.log('result ===> img = ', result)\n    //   const imgUrl = sessionStorage.getItem('editImageFromTemp2');\n    //     if (imgUrl) {\n    //       this.replaceImageSrc(imgUrl,  result.index.index);\n    //       sessionStorage.removeItem('editImageFromTemp2');\n    //     }\n    // });\n  }\n\n  replaceImageSRC(newSrc: string, index: number) {\n    const parser = new DOMParser();\n    const doc = parser.parseFromString(this.editorText, 'text/html');\n    const imgTags = doc.getElementsByTagName('img');\n\n  if (imgTags && imgTags.length > 0) {\n    if (index >= 0 && index < imgTags.length) {\n      // Update the src attribute of the img at the specified index\n      \n      imgTags[index].setAttribute('src', newSrc);\n      this.editorText = doc.body.innerHTML;\n    \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\n// onPaste(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  // onPaste(event: ClipboardEvent) {\n  //   event.preventDefault();\n  //   const clipboardData = event.clipboardData;\n  //   if (clipboardData) {\n  //     // Handle image data\n  //     const items = clipboardData.items;\n  //     for (let i = 0; i < items.length; i++) {\n  //       if (items[i].type.startsWith('image/')) {\n  //         const file = items[i].getAsFile();\n  //         if (file) {\n  //           const reader = new FileReader();\n  //           reader.onload = (e: any) => {\n  //             const imgHtml = `<img src=\"${e.target.result}\" alt=\"Pasted Image\" style=\"max-width: 100%;\"/>`;\n  //             this.insertHtmlAtCaret(imgHtml);\n  //           };\n  //           reader.readAsDataURL(file);\n  //           return; // Exit if an image is handled\n  //         }\n  //       }\n  //     }\n\n  //     // Handle text or table data\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  onPaste(event: ClipboardEvent) {\n    event.preventDefault();\n    const clipboardData = event.clipboardData;\n    if (clipboardData) {\n      for (let i = 0; i < clipboardData.items.length; i++) {\n        const item = clipboardData.items[i];\n\n        if (item.type.startsWith(\"image/\")) {\n          // Handle image paste\n          const file = item.getAsFile();\n          if (file) {\n            const reader = new FileReader();\n            reader.onload = (e: any) => {\n              const imgHtml = `<img src=\"${e.target.result}\" alt=\"Pasted Image\" style=\"max-width: 100%;\" />`;\n              this.insertHtmlAtCaret(imgHtml);\n            };\n            reader.readAsDataURL(file);\n            return;\n          }\n        } else if (item.type === \"text/html\") {\n          // Handle HTML paste\n          // const htmlData = clipboardData.getData(\"text/html\");\n          if (this.isTableData(clipboardData.getData('text/html'))) {\n            const html = this.convertTextToTable(clipboardData.getData('text/html'));\n            this.insertHtmlAtCaret(html);\n          } else {\n            this.insertHtmlAtCaret(clipboardData.getData('text/html'));\n          }\n          // this.insertHtmlAtCaret(htmlData);\n          return;\n        } else if (item.type === \"text/plain\") {\n          // Handle plain text paste\n          if (this.isTableData(clipboardData.getData('text/plain'))) {\n            const html = this.convertTextToTable(clipboardData.getData('text/plain'));\n            this.insertHtmlAtCaret(html);\n          } else {\n            this.insertHtmlAtCaret(clipboardData.getData('text/plain'));\n          }\n          // const plainText = clipboardData.getData(\"text/plain\");\n          // this.insertHtmlAtCaret(plainText);\n          return;\n        }\n      }\n    }\n  }\n\n  isExcelData(html: string): boolean {\n    return html.includes('xmlns:o=\"urn:schemas-microsoft-com:office:office\"') || \n          html.includes('xmlns:x=\"urn:schemas-microsoft-com:office:excel\"');\n  }\n\n  convertExcelHtmlToTable(html: string): string {\n    const parser = new DOMParser();\n    const doc = parser.parseFromString(html, 'text/html');\n    const table = doc.querySelector('table');\n    return table ? table.outerHTML : ''; // Extract only the table part\n  }\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\" >${cell}</td>`).join('');\n  //     return `<tr class=\"table-border-top\" style=\"border-top: ${this.themeModeTableBorderTop()}; width: 100% !important\">${cells}</tr>`;\n  //   }).join('');\n  //   return `<table>${tableRows}</table>`;\n  // }\n\n  convertTextToTable(text: string): string {\n    const rows = text.split('\\n').filter(row => row.trim() !== '');\n    const columnCount = rows[0]?.split('\\t').length || 1; // Get the number of columns from the first row\n    const columnWidth = 100 / columnCount; // Calculate column width\n\n    const tableRows = rows.map((row, index) => {\n      const cells = row.split('\\t').map(cell => `\n        <td class=\"px-1 py-1 text-truncate\" \n            style=\"max-width: ${columnWidth}%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;\">\n          ${cell}\n        </td>`).join('');\n\n      // Add a border-top for all rows except the first and border-bottom for the last row\n      const borderTop = index === 0 ? '' : `border-top: ${this.themeModeTableBorderTop()};`;\n      const borderBottom = index === rows.length - 1 ? `border-bottom: ${this.themeModeTableBorderTop()};` : '';\n\n      return `\n        <tr \n          style=\"${borderTop} ${borderBottom} width: 100% !important;\">\n          ${cells}\n        </tr>`;\n    }).join('');\n\n    return `\n      <table style=\"table-layout: fixed; width: 100%;\"> \n        ${tableRows}\n      </table>`;\n  }\n\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  themeModeTableBorderTop() {\n    const clrMode = document.body.getAttribute('data-layout-color')\n    if (clrMode == 'dark') {\n      return '1px solid #D0D0D0; !important'\n    } else {\n      return '1px solid #414141 !important'\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  clearTextEditor() {\n    this.editorTextClear.emit()\n  }\n\n  setupHistory() {\n    this.saveState();\n     const editor = document.getElementById('editor');\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('editor');\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('editor');\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('editor');\n  \n      if (editor) {\n        this.sanitizedContent = redoContent!;\n      }\n    }\n  }\n\n//   formatTextWithDates(text: string): string {\n//   // Regular expression to detect YYYY-MM-DD formatted dates\n//   const dateRegex = /\\b\\d{4}-\\d{2}-\\d{2}\\b/g;\n\n//   // Replace found dates with a formatted version\n//   return text.replace(dateRegex, (dateStr) => {\n//     // Convert the detected date string into a Date object\n//     const dateObj = new Date(dateStr);\n    \n//     // Format the date to 'Month Day, Year' (e.g., October 10, 2024)\n//     return dateObj.toLocaleDateString('en-US', {\n//       year: 'numeric',\n//       month: 'long',\n//       day: 'numeric',\n//     });\n//   });\n  // }\n  \n  formatTextWithDates(text: string): string {\n  // Regular expression to detect YYYY-MM-DD formatted dates\n  const dateRegex = /\\b\\d{4}-\\d{2}-\\d{2}\\b/g;\n\n  // Replace found dates with a formatted version\n  return text.replace(dateRegex, (dateStr) => {\n    // Convert the detected date string into a Date object\n    const dateObj = new Date(dateStr);\n\n    // Extract day, month, and year\n    const day = dateObj.getDate().toString().padStart(2, '0'); // Ensure day is two digits\n    const month = dateObj.toLocaleString('en-US', { month: 'short' }); // Get abbreviated month name\n    const year = dateObj.getFullYear(); // Get full year\n\n    // Format the date as 'dd/mmm/yyyy'\n    return `${day}/${month}/${year}`;\n  });\n}\n\n\n}","<div class=\"container els-text-editor px-0\" id=\"textEditor\" #fullscreen=\"ngxFullscreen\"\r\n                                        #textEditor\r\n                                            ngxFullscreen>\r\n    <div *ngIf=\"toolbarMode === 'fixed'\" class=\"btn-toolbar els-btn-toolbar p-2 py-2 mb-0\" role=\"toolbar\" [style.background]=\"themeModeBgClr()\"\r\n        [ngStyle]=\"{\r\n    'pointer-events': disableToolbar ? 'none' : 'auto',\r\n    'border-top-left-radius': IsOpen ? '0' : '20px',\r\n    'border-top-right-radius': IsOpen ? '0' : '20px'\r\n}\"\r\naria-label=\"Toolbar with button groups\"\r\nstyle=\"border-top-left-radius: 20px !important; border-top-right-radius: 20px !important;\"\r\n>\r\n        <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Header Options\">\r\n            <div ngbDropdown class=\"dropdown\">\r\n                <button\r\n                    class=\"btn btn-white els-form-select border els-toolbar-dropdown-button dropdown-toggle text-start\" [style.border-radius]=\"'5px'\"\r\n                    id=\"headerDropdown\" [style.border]=\"themeMode()\" [style.color]=\"themeModeClr()\" ngbDropdownToggle>\r\n                    <span>{{selectedFormatBlock | titlecase}}</span> <i class=\"mdi mdi-chevron-down \"></i>\r\n                </button>\r\n                <div ngbDropdownMenu aria-labelledby=\"headerDropdown\" class=\"els-text-format\"\r\n                    [style.border]=\"themeMode()\">\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" [style.color]=\"themeModeClr()\"\r\n                        (click)=\"format('formatBlock', '<h1>')\">\r\n                        <h1>Heading 1</h1>\r\n                    </button>\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" [style.color]=\"themeModeClr()\"\r\n                        (click)=\"format('formatBlock', '<h2>')\">\r\n                        <h2>Heading 2</h2>\r\n                    </button>\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" [style.color]=\"themeModeClr()\"\r\n                        (click)=\"format('formatBlock', '<h3>')\">\r\n                        <h3>Heading 3</h3>\r\n                    </button>\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" [style.color]=\"themeModeClr()\"\r\n                        (click)=\"format('formatBlock', '<h4>')\">\r\n                        <h4>Heading 4</h4>\r\n                    </button>\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" [style.color]=\"themeModeClr()\"\r\n                        (click)=\"format('formatBlock', '<h5>')\">\r\n                        <h5>Heading 5</h5>\r\n                    </button>\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" [style.color]=\"themeModeClr()\"\r\n                        (click)=\"format('formatBlock', '<h6>')\">\r\n                        <h6>Heading 6</h6>\r\n                    </button>\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" [style.color]=\"themeModeClr()\"\r\n                        (click)=\"format('formatBlock', '<p>')\">\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            <!-- <select class=\"els-form-select \" style=\" font-weight: 700 !important; color: #fff;border: 2px solid #7D6D6D !important;\" \r\n                [(ngModel)]=\"selectedFont\" (change)=\"changeFont($event)\">\r\n                <option class=\"els-form-option\" *ngFor=\"let font of fonts\" [value]=\"font\">{{ font }}</option>\r\n            </select> -->\r\n            <div ngbDropdown class=\"dropdown\">\r\n                <button\r\n                    class=\"btn btn-white els-form-select border els-toolbar-dropdown-button dropdown-toggle text-start\"\r\n                    id=\"headerDropdown\" style=\"width: 100px\" [style.border]=\"themeMode()\" [style.color]=\"themeModeClr()\"\r\n                    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                    [style.border]=\"themeMode()\">\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" *ngFor=\"let font of fonts\"\r\n                        (click)=\"changeFont(font)\" [style.color]=\"themeModeClr()\">\r\n                        <span>{{ font }}</span>\r\n                    </button>\r\n                </div>\r\n            </div>\r\n        </div>\r\n        <div class=\"py-0\"  style=\"height: fit-content;\" [style.color]=\"themeModeClr()\">\r\n            <div class=\"btn-group els-button-group me-2 mr-2 \" role=\"group\" aria-label=\"Text Formatting\">\r\n                <button type=\"button\" class=\"btn btn-white els-toolbar-button\" [class.active]=\"isBoldActive\"\r\n                    (click)=\"format('bold')\">\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')\">\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')\">\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')\">\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>\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>\r\n                <div class=\"vertical-line ms-2 border\" [style.border-left]=\"themeModeClrVerticalLine()\"></div>\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)=\"format('insertOrderedList')\"><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')\"><i 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 text-dark\"\r\n                            (click)=\"format('justifyLeft')\"><i class=\"mdi mdi-format-align-left\"></i></button>\r\n                        <button type=\"button\" class=\"btn btn-white els-toolbar-button text-dark\"\r\n                            (click)=\"format('justifyCenter')\"><i class=\"mdi mdi-format-align-center\"></i></button>\r\n                        <button type=\"button\" class=\"btn btn-white els-toolbar-button text-dark\"\r\n                            (click)=\"format('justifyRight')\"><i class=\"mdi mdi-format-align-right\"></i></button>\r\n                        <button type=\"button\" class=\"btn btn-white els-toolbar-button text-dark\"\r\n                            (click)=\"format('justifyFull')\"><i class=\"mdi mdi-format-align-justify\"></i></button>\r\n                    </div>\r\n                </div>\r\n                <div class=\"vertical-line ms-2 border\" [style.border-left]=\"themeModeClrVerticalLine()\"></div>\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')\">\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')\">\r\n                    <i class=\"mdi mdi-format-superscript\"></i>\r\n                </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)=\"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()\"><i\r\n                        class=\"mdi mdi-image\"></i></button>\r\n                <input type=\"file\" id=\"imageInput\" style=\"display: none;\" (change)=\"handleImageUpload($event)\" accept=\"image/*\">\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\"\r\n                    (click)=\"addRow()\"><i 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=\"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            </div> -->\r\n            <div class=\"btn-group els-button-group\" 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                    style=\" width: fit-content !important;\">\r\n                    <i class=\"mdi mdi-close-circle\"></i>\r\n                </button>\r\n            </div>\r\n            <div class=\"btn-group els-button-group\" role=\"group\" aria-label=\"Table Options\">\r\n                <button class=\"btn btn-white els-toolbar-button\" (click)=\"toggleFullscreen1()\">\r\n                    <ng-container *ngIf=\"IsOpen; else fullscreenIcon\">\r\n                        <i class=\"mdi mdi-fullscreen-exit\"></i> <!-- Collapse Icon -->\r\n                    </ng-container>\r\n                    <ng-template #fullscreenIcon>\r\n                        <i class=\"mdi mdi-fullscreen\"></i> <!-- Expand Icon -->\r\n                    </ng-template>\r\n                </button>\r\n            </div>\r\n        </div>\r\n    </div>\r\n    <div *ngIf=\"toolbarMode === 'bubble'\" class=\"bubble-toolbar border p-2\"\r\n        [ngStyle]=\"{'top.px': toolbarTop, 'left.px': toolbarLeft, 'display': showToolbar ? 'block' : 'none'}\">\r\n        <div class=\"btn-group els-button-group\" role=\"group\" aria-label=\"Font Options\">\r\n            <select class=\"els-form-select\" [(ngModel)]=\"selectedFont\" (change)=\"changeFont($event)\">\r\n                <option *ngFor=\"let font of fonts\" [value]=\"font\">{{ font }}</option>\r\n            </select>\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]=\"isBoldActive\"\r\n                (click)=\"format('bold')\">\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')\">\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')\">\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')\">\r\n                <i class=\"mdi mdi-format-strikethrough-variant\"></i>\r\n            </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)=\"format('blockquote')\"><i\r\n                        class=\"mdi mdi-format-quote-close\"></i></button>\r\n                <button type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"insertCodeBlock()\"><i \r\n                        class=\"mdi mdi-code-tags\"></i></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)=\"format('insertOrderedList')\"><i\r\n                    class=\"mdi mdi-format-list-numbered\"></i></button>\r\n            <button type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"format('insertUnorderedList')\"><i\r\n                    class=\"mdi mdi-format-list-bulleted\"></i></button>\r\n            <!-- <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Color Formatting\"> -->\r\n            <div class=\"btn-group\" role=\"group\" aria-label=\"Text Color\">\r\n                <!-- <div ngbDropdown class=\"ql-align\">\r\n                                <button type=\"button\" class=\"btn btn-outline-primary arrow-none text-secondary\" id=\"dropdownBasic1\"\r\n                                    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: 300px;\">\r\n                                    <color-sketch color=\"#fff\" (onChangeComplete)=\"setTextColor($event)\"></color-sketch>\r\n                                </div>\r\n                            </div> -->\r\n                <!-- <div class=\"btn btn-white els-toolbar-button custom-color-trigger\" ngx-colors-trigger [(ngModel)]=\"color\"\r\n                                (ngModelChange)=\"logEvent($event, 'ngModelChange')\"\r\n                                (change)=\"logEvent($event, 'change')\"\r\n                                (input)=\"logEvent($event, 'input')\"\r\n                                >\r\n                                <i class=\"mdi mdi-format-color-text icon-with-underline\" [style.color]=\"color\"\r\n                                    [style]=\"{color: color}\"></i>\r\n                                <ngx-colors style=\"display: none;\" ></ngx-colors>\r\n                            </div> -->\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>\r\n\r\n            <!-- <div class=\"btn-group\" role=\"group\" aria-label=\"Background Color\">\r\n                            <input type=\"color\" id=\"bgColorPicker\" style=\"display: none;\" (change)=\"setBackgroundColor($event)\">\r\n                            <button type=\"button\" class=\"btn btn-white els-toolbar-button\"\r\n                                (click)=\"openColorPicker('bgColorPicker')\">\r\n                                <i class=\"mdi mdi-alpha-a-box\"></i>\r\n                            </button>\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 style=\"width: 0px !important;\" id=\"bgColorPicker\" [cpPresetColors]=\"['#fff', '#000', '#2889e9', '#e920e9', '#fff500', 'rgb(236,64,64)']\"\r\n                                [(colorPicker)]=\"color\" (change)=\"setBackgroundColor($event)\" /> -->\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>\r\n\r\n\r\n            <!-- </div> -->\r\n        </div>\r\n        <!-- <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Header Options\">\r\n                    <div class=\"dropdown\">\r\n                            <button class=\"btn btn-white els-toolbar-button dropdown-toggle\" type=\"button\" id=\"headerDropdown\"\r\n                                    data-toggle=\"dropdown\" aria-haspopup=\"true\" aria-expanded=\"false\">\r\n                                    <i class=\"mdi mdi-format-header-1\"></i>\r\n                            </button>\r\n                            <div class=\"dropdown-menu\" aria-labelledby=\"headerDropdown\">\r\n                                    <button class=\"dropdown-item\" type=\"button\" (click)=\"format('formatBlock', '<h1>')\"><i\r\n                                                    class=\"mdi mdi-format-header-1\"></i> Heading 1</button>\r\n                                    <button class=\"dropdown-item\" type=\"button\" (click)=\"format('formatBlock', '<h2>')\"><i\r\n                                                    class=\"mdi mdi-format-header-2\"></i> Heading 2</button>\r\n                                    <button class=\"dropdown-item\" type=\"button\" (click)=\"format('formatBlock', '<h3>')\"><i\r\n                                                    class=\"mdi mdi-format-header-3\"></i> Heading 3</button>\r\n                                    <button class=\"dropdown-item\" type=\"button\" (click)=\"format('formatBlock', '<h4>')\"><i\r\n                                                    class=\"mdi mdi-format-header-4\"></i> Heading 4</button>\r\n                                    <button class=\"dropdown-item\" type=\"button\" (click)=\"format('formatBlock', '<h5>')\"><i\r\n                                                    class=\"mdi mdi-format-header-5\"></i> Heading 5</button>\r\n                                    <button class=\"dropdown-item\" type=\"button\" (click)=\"format('formatBlock', '<h6>')\"><i\r\n                                                    class=\"mdi mdi-format-header-6\"></i> Heading 6</button>\r\n                            </div>\r\n                    </div>\r\n            </div> -->\r\n        <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Header Options\">\r\n            <div ngbDropdown class=\"dropdown\">\r\n                <button class=\"btn btn-white els-toolbar-dropdown-button dropdown-toggle\" id=\"headerDropdown\"\r\n                    ngbDropdownToggle>\r\n                    <span style=\"width: 85px;\">{{selectedFormatBlock | titlecase}}</span> <i\r\n                        class=\"mdi mdi-chevron-down text-dark\"></i>\r\n                </button>\r\n                <div ngbDropdownMenu aria-labelledby=\"headerDropdown\">\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"format('formatBlock', '<h1>')\">\r\n                        <h1>Heading 1</h1>\r\n                    </button>\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"format('formatBlock', '<h2>')\">\r\n                        <h2>Heading 2</h2>\r\n                    </button>\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"format('formatBlock', '<h3>')\">\r\n                        <h3>Heading 3</h3>\r\n                    </button>\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"format('formatBlock', '<h4>')\">\r\n                        <h4>Heading 4</h4>\r\n                    </button>\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"format('formatBlock', '<h5>')\">\r\n                        <h5>Heading 5</h5>\r\n                    </button>\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"format('formatBlock', '<h6>')\">\r\n                        <h6>Heading 6</h6>\r\n                    </button>\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"format('formatBlock', '<p>')\">\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 mr-2\" role=\"group\" aria-label=\"Text Formatting\">\r\n            <!-- <button type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"format('superscript')\"><i\r\n                        class=\"mdi mdi-format-superscript\"></i></button>\r\n                <button type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"format('subscript')\"><i\r\n                        class=\"mdi mdi-format-subscript\"></i></button> -->\r\n            <button type=\"button\" class=\"btn btn-white els-toolbar-button\" [class.active]=\"isSubscriptActive\"\r\n                (click)=\"format('subscript')\">\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')\">\r\n                <i class=\"mdi mdi-format-superscript\"></i>\r\n            </button>\r\n        </div>\r\n        <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Text Formatting\">\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\" (click)=\"format('justifyLeft')\"><i\r\n                            class=\"mdi mdi-format-align-left\"></i></button>\r\n                    <button type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"format('justifyCenter')\"><i\r\n                            class=\"mdi mdi-format-align-center\"></i></button>\r\n                    <button type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"format('justifyRight')\"><i\r\n                            class=\"mdi mdi-format-align-right\"></i></button>\r\n                    <button type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"format('justifyFull')\"><i\r\n                            class=\"mdi mdi-format-align-justify\"></i></button>\r\n                </div>\r\n            </div>\r\n        </div>\r\n\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)=\"format('removeFormat')\"><i\r\n                    class=\"mdi mdi-format-clear\"></i></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)=\"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()\"><i\r\n                    class=\"mdi mdi-image\"></i></button>\r\n            <input type=\"file\" id=\"imageInput\" style=\"display: none;\" (change)=\"handleImageUpload($event)\" accept=\"image/*\">\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\r\n\r\n        <!-- <div class=\"btn btn-white els-toolbar-button custom-color-trigger\">\r\n        <i class=\"mdi mdi-format-color-text icon-with-underline\" [style.color]=\"color\"></i>\r\n        <ngx-colors [(ngModel)]=\"color\" (change)=\"colorChanged($event)\"></ngx-colors>\r\n    </div> -->\r\n        <!-- <div class=\"btn-group els-button-group\" ngbDropdown aria-label=\"Table Options\">\r\n                <button class=\"btn btn-white els-toolbar-button\" ngbDropdownToggle  (click)=\"addTable()\">\r\n                    <i class=\"mdi mdi-table\"></i>\r\n                </button>\r\n            \r\n                <div ngbDropdownMenu *ngIf=\"isTableSelected || tableAdded\">\r\n                    <button class=\"dropdown-item\" (click)=\"addRow()\">\r\n                        <i class=\"mdi mdi-table-row-plus-after\"></i> Add Row\r\n                    </button>\r\n                    <button class=\"dropdown-item\" (click)=\"deleteRow()\">\r\n                        <i class=\"mdi mdi-table-row-remove\"></i> Delete Row\r\n                    </button>\r\n                    <button class=\"dropdown-item\" (click)=\"addColumn()\">\r\n                        <i class=\"mdi mdi-table-column-plus-after\"></i> Add Column\r\n                    </button>\r\n                    <button class=\"dropdown-item\" (click)=\"deleteColumn()\">\r\n                        <i class=\"mdi mdi-table-column-remove\"></i> Delete Column\r\n                    </button>\r\n                    <div class=\"dropdown-divider\"></div>\r\n                    <div class=\"dropdown-item\">\r\n                        <label for=\"tableWidth\">Table Width</label>\r\n                        <input type=\"number\" id=\"tableWidth\" class=\"form-control\" (change)=\"adjustTableWidth($event)\"\r\n                            placeholder=\"Width\">\r\n                    </div>\r\n                    <div class=\"dropdown-item\">\r\n                        <label for=\"cellWidth\">Cell Width</label>\r\n                        <input type=\"number\" id=\"cellWidth\" class=\"form-control\" (change)=\"adjustCellWidth($event)\"\r\n                            placeholder=\"Width\">\r\n                    </div>\r\n                    <div class=\"dropdown-item\">\r\n                        <label for=\"cellHeight\">Cell Height</label>\r\n                        <input type=\"number\" id=\"cellHeight\" class=\"form-control\" (change)=\"adjustCellHeight($event)\"\r\n                            placeholder=\"Height\">\r\n                    </div>\r\n                </div>\r\n            </div> -->\r\n    </div>\r\n    <!-- <div contenteditable=\"true\" id=\"editor\" class=\"p-3 custom-scrollbar non-focus\" #editor\r\n        style=\"position: relative !important;border-bottom-left-radius: 20px !important; border-bottom-right-radius: 20px !important; border-bottom-left-radius: 20px !important;\" [style.background]=\"themeModeBgClr()\" [style.border-top]=\"themeModeBorderTop()\"\r\n        [ngStyle]=\"{'font-family': selectedFont, 'font-size': selectedFontSize + 'px'}\" [style]=\"style\"\r\n        [style.min-height]=\"IsOpen ? '85vh !important' :  '405px !important'\"\r\n        (input)=\"onModelChange($event)\" placeholder=\"Insert text here ...\" readonly (mouseup)=\"onTextSelect($event)\"\r\n        [innerHTML]=\"sanitizedContent\" (paste)=\"onPaste($event)\" (focus)=\"onFocus()\" (blur)=\"onBlur()\"\r\n        (click)=\"checkTableSelection($event)\">\r\n    </div> -->\r\n    <!-- <div contenteditable=\"true\" id=\"editor\" class=\"p-3 custom-scrollbar non-focus overflow-auto\" #editor\r\n         style=\"position: relative !important;\r\n               \" [style.background]=\"themeModeBgClr()\"\r\n        [style.border-top]=\"themeModeBorderTop()\"\r\n        \r\n        [ngStyle]=\"{'font-family': selectedFont, 'font-size': selectedFontSize + 'px',\r\n           'border-bottom-left-radius': isOpen ? '0' :'20px',\r\n           'border-bottom-right-radius': isOpen ? '0' :'20px'\r\n        }\"\r\n        [style.min-height]=\"IsOpen ? '93vh' : '405px'\" (input)=\"onModelChange($event)\" placeholder=\"Insert text here ...\"\r\n        readonly (mouseup)=\"onTextSelect($event)\" [innerHTML]=\"sanitizedContent\" (paste)=\"onPaste($event)\"\r\n        (focus)=\"onFocus()\" (blur)=\"onBlur()\" (click)=\"checkTableSelection($event)\">\r\n    </div> -->\r\n    <div contenteditable=\"true\" id=\"editor\" class=\"p-3 custom-scrollbar non-focus overflow-auto\" #editor\r\n        style=\"position: relative !important; overflow: auto;\" [style.background]=\"themeModeBgClr()\"\r\n        [style.border-top]=\"themeModeBorderTop()\" [ngStyle]=\"{\r\n                'font-family': selectedFont, \r\n                'font-size': selectedFontSize + 'px',\r\n                'border-bottom-left-radius': IsOpen ? '0' :'20px',\r\n                'border-bottom-right-radius': IsOpen ? '0' :'20px',\r\n                'min-height': IsOpen ? '93vh' : '405px',\r\n                'max-height': IsOpen ? '93vh' : '405px'\r\n            }\" placeholder=\"Insert text here ...\" readonly (mouseup)=\"onTextSelect($event)\"\r\n        (input)=\"onModelChange($event)\" [innerHTML]=\"sanitizedContent\" (paste)=\"onPaste($event)\" (focus)=\"onFocus()\"\r\n        (blur)=\"onBlur()\" (click)=\"checkTableSelection($event)\">\r\n    </div>\r\n\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\r\n</div>"]}
1707
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"el-text-editor.component.js","sourceRoot":"","sources":["../../../../projects/el-text-editor/src/lib/el-text-editor.component.ts","../../../../projects/el-text-editor/src/lib/el-text-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, Input, OnInit, Output, EventEmitter, forwardRef, ViewChild, ElementRef, Renderer2, OnChanges, SimpleChanges } from '@angular/core';\nimport { ControlValueAccessor, FormControl, NG_VALUE_ACCESSOR } from '@angular/forms';\n// import { MatDialog } from '@angular/material/dialog';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { Router, ActivatedRoute } from '@angular/router';\nimport { NgxFullscreenDirective } from '@ultimate/ngx-fullscreen';\nimport * as XLSX from 'xlsx';\n// import { ImageEditorModalComponent } from '../modals/image-editor-modal/image-editor-modal.component';\nimport { compress, decompress } from 'lz-string';\n\n\n@Component({\n  selector: 'text-editor',\n  templateUrl: './el-text-editor.component.html',\n  styleUrls: ['./el-text-editor.component.scss'],\n    providers: [{\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => ElTextEditorComponent),\n    multi: true\n  }]\n})\nexport class ElTextEditorComponent implements ControlValueAccessor, AfterViewInit, OnChanges {\n\n  @Input() editorText: string = '';\n  @Input() editorFrom: any;\n  @Input() editorAction: any;\n  @Input() UserRole: any;\n  @Input() style: any;\n  @Input() disableToolbar: any;\n  @Input() placeHolder: any;\n  @Input() reportId: any;\n  @Input() backgroundImage: any;\n  @Input() toolbarMode: 'fixed' | 'bubble' | 'none' = 'fixed';\n  @Output() editorTextChange = new EventEmitter<string>();\n  @Output() editorActionResponse = new EventEmitter<any>();\n  @Output() editorTextClear = new EventEmitter<any>();\n  @Output() imageEdit = new EventEmitter<any>();\n  @Output() imageEdit2 = new EventEmitter<any>();\n  @Output() placeHolderRemove = new EventEmitter<any>();\n  @Output() isOpen = new EventEmitter<any>();\n  @Output() newImageAdded = new EventEmitter<any>();\n  \n  @Input() value: string = '';\n\n  \n  @ViewChild('textEditor') TextEditor!:  ElementRef<Element>;\n  @ViewChild('fullscreen') fullscreen!: NgxFullscreenDirective\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  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  undoStack: string[] = [];\n  redoStack: string[] = [];\n  history: string[] = [];\n  historyIndex = -1;\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  currentCaretPosition: any;\n  userRole: any[] = [];\n  showEditButton: boolean = false;\n\n  constructor(\n    private router: Router,\n    private route: ActivatedRoute,\n    private renderer: Renderer2,\n    private sanitizer: DomSanitizer,\n  ) {\n    this.getUserRoles()\n\n    \n  }\n\n  themeMode() {\n    const clrMode = document.body.getAttribute('data-layout-color')\n    if (clrMode == 'dark') {\n      return '2px solid #403F4A !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  themeModeClrVerticalLine() {\n    const clrMode = document.body.getAttribute('data-layout-color')\n    if (clrMode == 'dark') {\n      return '2px solid #FFFFFF !important'\n    } else {\n      return '2px solid #D0D0D0 !important'\n    }\n  }\n\n  themeModeBgClr() {\n    const clrMode = document.body.getAttribute('data-layout-color')\n    if (clrMode == 'dark') {\n      return '#282828 !important'\n    } else {\n      return '#F3F3F3 !important'\n    }\n  }\n\n  themeModeBorderTop() {\n    const clrMode = document.body.getAttribute('data-layout-color')\n    if (clrMode == 'dark') {\n      return '2px solid #000 !important'\n    } else {\n      return '2px solid #fff !important'\n    }\n  }\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['placeHolder']) {\n      this.insertAtCaret(this.placeHolder)\n\n    }\n\n    if (changes['reportId']) {\n      sessionStorage.setItem('reportId', this.reportId)\n    } \n\n    if (changes['UserRole']) { \n      this.getUserRoles()\n    }\n  }\n  ngAfterViewInit() {\n    this.initEditor();\n    this.checkPlaceholder();\n    this.setupHistory();\n    document.addEventListener('fullscreenchange', this.onFullscreenChange);\n  }\n\n  ngOnInit(): void {\n    this.init_Func(this.editorText)\n    document.addEventListener('selectionchange', () => {\n      this.checkActiveStates();\n      this.checkFormatBlock();\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   ngOnDestroy() {\n    // Cleanup the event listener when the component is destroyed\n    document.removeEventListener('fullscreenchange', this.onFullscreenChange);\n  }\n\n  IsOpen: boolean = false;\n\n    toggleFullscreen1() {\n      this.IsOpen = !this.IsOpen;\n      this.isOpen.emit(this.IsOpen)\n      if (this.IsOpen) { \n        this.fullscreen.enter(this.TextEditor.nativeElement);\n      } else {\n        this.fullscreen.exit()\n      }\n    }\n  \n  private onFullscreenChange = () => {\n    if (!document.fullscreenElement) {\n      // When fullscreen mode is exited\n      this.IsOpen = false;\n      this.isOpen.emit(this.IsOpen);\n    }\n  };\n  \n  // enterFullscreenVideo() {\n  //   console.log('event:', event);\n  //   const fullscreen = event;\n  //   this.isOpen = event;\n  //   if (fullscreen) {\n  //     this.fullscreen.enter(this.TextEditor.nativeElement);\n  //   } else {\n  //     this.fullscreen.exit()\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\n//         let container = this.selectedImage.parentElement;\n//         if (!container || container.className !== 'image-container') {\n//           container = document.createElement('div');\n//           container.className = 'image-container';\n//           container.style.position = 'relative';\n//           container.style.display = 'inline-block';\n//           this.selectedImage.parentNode?.insertBefore(container, this.selectedImage);\n//           container.appendChild(this.selectedImage);\n//         }\n//         const existingButton = container.querySelector('.image-edit-button');\n//         if (existingButton) {\n//           existingButton.remove();\n//         }\n\n//         const button = document.createElement('button');\n//         // button.textContent = 'Edit';\n//         button.innerText = 'Edit Image';\n\n//         button.className = 'image-edit-button btn btn-sm';\n//         button.style.position = 'absolute';\n//         button.style.top = '50%';\n//         button.style.left = '50%';\n//         button.style.transform = 'translate(-50%, -50%)';\n//         button.style.zIndex = '1000';\n//         button.style.backgroundColor = '#fff';\n//         button.style.border = '2px solid #fff';\n//         // button.style.padding = '10px';\n//         button.style.color = '#313a46';\n//         button.style.cursor = 'pointer';\n\n//         button.addEventListener('click', (e) => {\n//           e.stopPropagation();\n//           this.editImage();\n//         });\n\n//         container.appendChild(button);\n//       } else {\n//         this.selectedImage = null;\n//         this.selectedItemIndex = null;\n//       }\n//     });\n//   }\n  // }\n  getUserRoles() {\n    this.userRole = this.UserRole\n  }\n  // roleCheck() {\n  //   for (let i = 0; i < this.userRole.length; ++i) {\n  //     const roleName = []\n  //       roleName.push(this.userRole[i]?.name);\n  //     return this.userRole[i]?.name;\n  //   }\n  // }\n\n  roleCheck() {\n    let userRoleName: string[] = [];\n    for (let i = 0; i <= this.userRole.length; ++i) {\n      userRoleName.push(this.userRole[i]?.name);\n    }\n    return userRoleName;\n  }\n\n\n// private addClickListenerToImages() {\n//   const editor = document.getElementById('editor');\n//   const roles = this.roleCheck(); // Get user roles dynamically\n//   const isAdmin = roles.includes('Admin');\n//   const isCreator = roles.includes('Creator');\n//   const isApprover = roles.includes('Approver');\n  \n//   if (isCreator || isAdmin) {\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//         let container = this.selectedImage.parentElement;\n//         if (!container || container.className !== 'image-container') {\n//           container = document.createElement('div');\n//           container.className = 'image-container';\n//           container.style.position = 'relative';\n//           container.style.display = 'inline-block';  \n//           this.selectedImage.parentNode?.insertBefore(container, this.selectedImage);\n//           container.appendChild(this.selectedImage);\n//         }\n\n//         const existingButton = container.querySelector('.image-edit-button');\n//         if (existingButton) {\n//           existingButton.remove();\n//         }\n\n//         const button = document.createElement('button');\n//         button.textContent  = 'Edit Image';\n//         button.className = 'image-edit-button btn btn-sm';\n//         button.style.position = 'absolute';\n//         button.style.top = '50%';\n//         button.style.left = '50%';\n//         button.style.transform = 'translate(-50%, -50%)';\n//         button.style.zIndex = '1000';\n//         button.style.backgroundColor = '#fff'; \n//         button.style.border = '2px solid #fff'; \n//         button.style.color = '#313a46';\n//         button.style.cursor = 'pointer';\n//         button.style.userSelect = 'none';\n\n//         button.addEventListener('click', (e) => {\n//           e.stopPropagation();\n//           this.editImage();\n//         });\n\n//         container.appendChild(button);\n\n//       } else {\n//         this.selectedImage = null;\n//         this.selectedItemIndex = null;\n//         const buttons = document.querySelectorAll('.image-edit-button');\n//         buttons.forEach(button => button.remove());\n//       }\n//     });\n//   }\n//   }\n  // }\n  private addClickListenerToImages() {\n  const editor = document.getElementById('editor');\n  const roles = this.roleCheck(); // Get user roles dynamically\n  const isAdmin = roles.includes('Admin');\n  const isCreator = roles.includes('Creator');\n\n  if (isCreator || isAdmin) {\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          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          let container = this.selectedImage.parentElement;\n          if (!container || container.className !== 'image-container') {\n            container = document.createElement('div');\n            container.className = 'image-container';\n            container.style.position = 'relative';\n            container.style.display = 'inline-block';\n            this.selectedImage.parentNode?.insertBefore(container, this.selectedImage);\n            container.appendChild(this.selectedImage);\n          }\n\n          const existingButton = container.querySelector('.image-edit-button');\n          if (existingButton) {\n            existingButton.remove();\n          }\n\n          const button = document.createElement('button');\n          button.textContent = 'Edit Image';\n          button.className = 'image-edit-button btn btn-sm';\n          button.style.position = 'absolute';\n          button.style.top = '50%';\n          button.style.left = '50%';\n          button.style.transform = 'translate(-50%, -50%)';\n          button.style.zIndex = '1000';\n          button.style.backgroundColor = '#fff';\n          button.style.border = '2px solid #fff';\n          button.style.color = '#313a46';\n          button.style.cursor = 'pointer';\n          button.style.userSelect = 'none';\n\n          button.addEventListener('click', (e) => {\n            e.stopPropagation();\n            this.editImage();\n          });\n\n          container.appendChild(button);\n        } else {\n          this.removeEditButtons();\n        }\n      });\n\n      // Monitor editor content changes to handle image deletion\n      const observer = new MutationObserver(() => {\n        const buttons = editor.querySelectorAll('.image-edit-button');\n        buttons.forEach((button) => {\n          const container = button.parentElement;\n          if (container && !container.querySelector('img')) {\n            button.remove(); // Remove the button if the associated image is gone\n            container.remove(); // Clean up the container\n          }\n        });\n      });\n\n      // Observe changes in the editor\n      observer.observe(editor, { childList: true, subtree: true });\n    }\n  }\n}\n\nprivate removeEditButtons() {\n  const buttons = document.querySelectorAll('.image-edit-button');\n  buttons.forEach((button) => button.remove());\n  this.selectedImage = null;\n  this.selectedItemIndex = null;\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\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('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        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        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      }\n    });\n  }\n  }\n\nreplaceImageSrc(newSrc: string, index: number) {\n  const editor = document.getElementById('editor');\n  \n  if (editor) {\n    editor.focus()\n    const images = editor.getElementsByTagName('IMG');\n    if (index >= 0 ) {\n      images[index].setAttribute('src', newSrc);\n    } \n  }\n}\n\n\n\n  private initEditor() {\n    // Initialize editor content and listeners\n    const editor = document.getElementById('editor');\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 = VALUE;\n      this.onChange(VALUE);\n      this.editorTextChange.emit(VALUE);\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('editor');\n  //     if (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//   init_Func(html: any) {\n//   if (html) {\n//     let editor = document.getElementById('editor');\n//     if (editor) {\n//       // Initialize the editor with sanitized content\n      \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\n//       // Track caret position on mouse click\n//       editor.addEventListener('click', () => {\n//         if (editor) {  // Ensure editor is not null\n//           // this.trackCaretPosition(editor);\n//         }\n//       });\n//     }\n//   } else {\n//     this.selectedImage = null;\n//   }\n// }\n\n// private setEditorContent(html: string) {\n//   let editor = document.getElementById('editor');\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\n// private setupMutationObserver(editor: HTMLElement) {\n//   const observer = new MutationObserver(() => {\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\n// This function tracks the caret position based on the mouse click\nprivate trackCaretPosition(editor: HTMLElement) {\n  const selection = window.getSelection();\n  if (selection && selection.rangeCount > 0) {\n    const range = selection.getRangeAt(0);\n    const startNode = range.startContainer;\n    const startOffset = range.startOffset;\n\n\n    // You can use this information to insert content or perform actions based on the caret position\n    // Example: Save the current caret position for future use\n    this.currentCaretPosition = { node: startNode, offset: startOffset };\n  }\n  }\n  \n  // Method to get caret position and insert new data\nprivate insertAtCaret(newData: string): void {\n  const selection = window.getSelection();\n  \n  if (selection && selection.rangeCount > 0) {\n    // Get the current range (caret position)\n    const range = selection.getRangeAt(0);\n\n    // Create a document fragment to insert (allows handling HTML strings)\n    const fragment = document.createDocumentFragment();\n    const tempDiv = document.createElement('div');\n    tempDiv.innerHTML = newData;\n\n    // Append the new data to the fragment (supports HTML insertion)\n    while (tempDiv.firstChild) {\n      fragment.appendChild(tempDiv.firstChild);\n    }\n\n    // Insert the fragment at the caret position\n    range.deleteContents(); // Remove any selected content if applicable\n    range.insertNode(fragment);\n\n    // Move the caret after the inserted content\n    const lastChild = fragment.lastChild;\n\n    if (lastChild) {\n      range.setStartAfter(lastChild);\n      range.setEndAfter(lastChild);\n      selection.removeAllRanges();\n      selection.addRange(range);\n    }\n    let editor = document.getElementById('editor');\n    if (editor) {\n      this.moveCaretToEnd(editor)\n    }\n    \n    this.placeHolderRemove.emit()\n  }\n}\n\n\n//   // Move caret to the end of the editor content\n//   private 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//   }\n  \n  \n\n\n  init_Func(html: any) {\n  if (html) {\n    let editor = document.getElementById('editor');\n    if (editor) {\n      // Initialize the editor with sanitized content\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      //  Track caret position on mouse click\n      editor.addEventListener('click', () => {\n        if (editor) {  // Ensure editor is not null\n          this.trackCaretPosition(editor);\n        }\n      });\n    }\n  } else {\n    this.selectedImage = null;\n  }\n}\n\n\nprivate setEditorContent(html: string) {\n  let editor = document.getElementById('editor');\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\n//   init_Func(html: any) {\n//   if (html) {\n//     let editor = document.getElementById('editor');\n//     if (editor) {\n//       editor.focus();\n//       editor.innerHTML = html;\n\n//       // Sanitize the content and apply styles\n//       this.sanitizedContent = this.sanitizer.bypassSecurityTrustHtml(this.applyImageStyles(html));\n//       editor.innerHTML = this.sanitizedContent as string;\n\n//       // Place the caret at the end of the content\n//       const range = document.createRange();\n//       const selection = window.getSelection();\n      \n//       if (editor.lastChild) {\n//         // Set the range at the end of the editor's content\n//         range.selectNodeContents(editor);\n//         range.collapse(false); // collapse to the end\n//         selection?.removeAllRanges();\n//         selection?.addRange(range);\n//       }\n\n//       editor.addEventListener('input', () => {\n//         if (editor) {\n//           this.onModelChange(editor.innerHTML);\n\n//           // Ensure the caret remains at the end after new content is added\n//           const range = document.createRange();\n//           const selection = window.getSelection();\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//       });\n//     }\n//   } else {\n//     this.selectedImage = null;\n//   }\n// }\n\n  format(command: string, value?: any) {\n    const editor = document.getElementById('editor');\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          this.selectedFormatBlock = this.formatBlockDecode(tag);\n        }\n      }\n    }\n     this.checkActiveStates();\n     this.checkFormatBlock();\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() {\n    const editor = document.getElementById('editor');\n    if (editor) {\n      const formatBlock = document.queryCommandValue('formatBlock');\n      this.selectedFormatBlock = this.formatBlockDecode(formatBlock);\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() {\n    const editor = document.getElementById('editor');\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=\"${794}\" >`;\n  //         // Insert the image into the editor\n  //         document.execCommand('insertHTML', false, imgHTML);\n  //       };\n  //     };\n  //     reader.readAsDataURL(file);\n  //   }\n  // }\n\n  handleImageUpload(event: any) {\n  const file = event.target.files[0];\n  const editorElement = document.getElementById('editor'); // Reference to the editor\n\n  if (file && editorElement) {\n    const editorWidth = editorElement.offsetWidth; // Get the editor's width\n    const reader = new FileReader();\n\n    reader.onload = (e: any) => {\n      const img = new Image();\n      img.src = e.target.result;\n\n      img.onload = () => {\n        const imgWidth = img.width;\n\n        // If the image width exceeds the editor's width, fit it to the editor\n        const imgHTML =\n          imgWidth > editorWidth\n            ? `<img src=\"${img.src}\" style=\" max-width: ${700}px; height: auto;\">`\n            : `<img src=\"${img.src}\" style=\"width: ${imgWidth}px; height: auto;\">`;\n        this.newImageAdded.emit()\n        // Insert the image into the editor\n        document.execCommand('insertHTML', false, imgHTML);\n      };\n    };\n\n    reader.readAsDataURL(file);\n  }\n}\n\n\n\n  // addTable() {\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=\"width: ${tableWidth}px;\">`;\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=\" 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('editor');\n  //   if (editor) {\n  //     editor.focus();\n  //     document.execCommand('insertHTML', false, table);\n  //   }\n  //   this.tableAdded = true;\n  //   this.checkTableSelection();\n  // }\n\n  addTable() {\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=\"width: ${tableWidth}px;\">`;\n  for (let i = 0; i < 3; i++) { // Number of rows\n    table += `<tr style=\"border-bottom: ${this.themeModeClrVerticalLineForTable()}\">`; // Add border-bottom to the row\n    for (let j = 0; j < cols; j++) {\n      table += `<td style=\"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\n  const editor = document.getElementById('editor');\n  if (editor) {\n    editor.focus();\n    document.execCommand('insertHTML', false, table);\n  }\n\n  this.tableAdded = true;\n  this.checkTableSelection();\n}\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  addRow() {\n  if (this.selectedTable) {\n    let row = this.selectedTable.insertRow();\n\n    // Loop through the columns of the first row to determine the number of cells\n    for (let i = 0; i < this.selectedTable.rows[0].cells.length; i++) {\n      let cell = row.insertCell(i);\n      cell.innerHTML = '&nbsp;';\n\n      // Apply bottom border explicitly\n      cell.style.borderBottom = `2px solid ${this.themeModeClrVerticalLineColorForTable()}`; // You can replace 'black' with your theme color\n    }\n  }\n}\n\n//   addRow() {\n//   if (this.selectedTable) {\n//     let row = this.selectedTable.insertRow();\n//     row.style.borderBottom = this.themeModeClrVerticalLineForTable(); // Add bottom border to the row\n//     for (let i = 0; i < this.selectedTable.rows[0].cells.length; i++) {\n//       let cell = row.insertCell(i);\n//       cell.innerHTML = '&nbsp;';\n//     }\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  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.wordWrap = 'break-word';\n      cell.style.wordBreak = 'break-all';\n      cell.style.whiteSpace = 'normal';\n      cell.style.minWidth = `${minWidth}px`;\n      cell.style.borderBottom = `2px solid ${this.themeModeClrVerticalLineColorForTable()}`\n    }\n\n    // Update existing rows' bottom border\n    for (let i = 0; i < this.selectedTable.rows.length; i++) {\n      this.selectedTable.rows[i].style.borderBottom = this.themeModeClrVerticalLineForTable();\n    }\n  }\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  themeModeClrVerticalLineForTable() {\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 #5F5F5F !important'\n    }\n  }\n\n  themeModeClrVerticalLineColorForTable() {\n    const clrMode = document.body.getAttribute('data-layout-color')\n    if (clrMode == 'dark') {\n      return '#414141'\n    } else {\n      return '#5F5F5F'\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) {\n  //   const editor = document.getElementById('editor');\n  //   if (editor) {\n  //     editor.focus();\n  //     const color = event.target.value;\n  //     this.selectedTextColor = color;\n  //     document.execCommand('foreColor', false, color);\n  //   }\n  // }\n\n  // setBackgroundColor(event: any) {\n  //   const editor = document.getElementById('editor');\n  //   if (editor) {\n  //     editor.focus();\n  //     const color = event.target.value;\n  //     this.backgroundColor = color;\n  //     document.execCommand('hiliteColor', false, color);\n  //   }\n  // }\n\n  private savedSelection: Range | null = null;\n\nopenColorPicker(inputId: string) {\n  const inputElement = document.getElementById(inputId) as HTMLInputElement;\n  if (inputElement) {\n    // Save the current selection\n    const selection = window.getSelection();\n    if (selection && selection.rangeCount > 0) {\n      this.savedSelection = selection.getRangeAt(0);\n    }\n    inputElement.click();\n  }\n}\n\n// setTextColor(event: any) {\n//   if (this.savedSelection) {\n//     const color = event.target.value;\n//     this.selectedTextColor = color;\n\n//     // Restore the saved selection\n//     const selection = window.getSelection();\n//     if (selection) {\n//       selection.removeAllRanges();\n//       selection.addRange(this.savedSelection);\n\n//       // Apply the color using a span\n//       const range = this.savedSelection;\n//       const span = document.createElement('span');\n//       span.style.color = color;\n//       span.textContent = range.toString();\n\n//       // Replace the selected text with the styled span\n//       range.deleteContents();\n//       range.insertNode(span);\n\n//       // Clear the saved selection\n//       this.savedSelection = null;\n//     }\n//   }\n  // }\n  setTextColor(event: any) {\n  if (this.savedSelection) {\n    const color = event.target.value;\n    this.selectedTextColor = color;\n\n    // Restore the saved selection\n    const selection = window.getSelection();\n    if (selection && selection.rangeCount > 0) {\n      const range = this.savedSelection;\n      selection.removeAllRanges();\n      selection.addRange(range);\n\n      // Get selected elements\n      const selectedContent = range.cloneContents();\n      const elements = Array.from(selectedContent.querySelectorAll(\"*\")) as HTMLElement[]; // ✅ Explicitly cast to HTMLElement[]\n\n      // Apply color to each element without modifying structure\n      elements.forEach((el) => {\n        el.style.color = color;\n      });\n\n      // Apply color to the top-level text nodes (without wrapping them)\n      Array.from(selectedContent.childNodes).forEach((node) => {\n        if (node.nodeType === Node.TEXT_NODE && node.textContent?.trim() !== \"\") {\n          const parent = range.commonAncestorContainer.parentElement;\n          if (parent) {\n            parent.style.color = color;\n          }\n        }\n      });\n\n      // Replace selected content\n      range.deleteContents();\n      range.insertNode(selectedContent);\n\n      // Clear saved selection\n      this.savedSelection = null;\n    }\n  }\n}\n\n  setBackgroundColor(event: any) {\n  if (this.savedSelection) {\n    const color = event.target.value;\n    this.backgroundColor = color;\n\n    // Restore the saved selection\n    const selection = window.getSelection();\n    if (selection) {\n      selection.removeAllRanges();\n      selection.addRange(this.savedSelection);\n\n      // Apply the background color using a span\n      const range = this.savedSelection;\n      const span = document.createElement('span');\n      span.style.backgroundColor = color;\n      span.textContent = range.toString();\n\n      // Replace the selected text with the styled span\n      range.deleteContents();\n      range.insertNode(span);\n\n      // Clear the saved selection\n      this.savedSelection = null;\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)\n    this.selectedTextColor = event\n    document.execCommand('foreColor', false, event);\n    // this.logs.unshift([this.logs.length + 1, trigger, event]);\n  }\n  \n\n  editImage() {\n    let data \n    switch (this.editorFrom.name) {\n      case 'section-content':\n        data = { editIMG: true, from: 'htmlEditor', index: this.selectedItemIndex, id: this.editorFrom.id };\n        const compressedData: string = compress(JSON.stringify(this.imageEditUrl));\n        sessionStorage.setItem('editImageFromTemp', compressedData);\n        const compressedData2 = compress(JSON.stringify(this.sanitizedContent));\n        sessionStorage.setItem('textEditor', compressedData2);\n        // alert('go to editor!')\n        this.navigateToIMGEditor(data);\n        this.imageEdit.emit()\n        break;\n      case 'create-document':\n        this.imageEdit.emit()\n        data = { editIMG: true, from: 'createDocument', index: this.selectedItemIndex, id: this.editorFrom.id, section: this.editorFrom.section, reportSectionId: this.editorFrom.reportSectionId };\n        // this.openDialog(data)\n        const compressedData3 = compress(JSON.stringify(this.imageEditUrl));\n        const compressedData4 = compress(this.editorText);\n\n        sessionStorage.setItem('editImageFromTemp2', compressedData3);\n        sessionStorage.setItem('textEditor2', compressedData4);\n        this.navigateToIMGEditor(data);\n        break;\n      default:\n        null\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  openDialog( item: any): void {\n    // let data: any;\n    //   data = item\n    // const dialogRef = this.dialog.open(ImageEditorModalComponent,{\n    //   minWidth: '100%', minHeight: '100vh', panelClass: 'theme-2B2936' ,disableClose: true, data: data\n    // });\n    // dialogRef.afterClosed().subscribe(result => {\n    //   console.log('result ===> img = ', result)\n    //   const imgUrl = sessionStorage.getItem('editImageFromTemp2');\n    //     if (imgUrl) {\n    //       this.replaceImageSrc(imgUrl,  result.index.index);\n    //       sessionStorage.removeItem('editImageFromTemp2');\n    //     }\n    // });\n  }\n\n  replaceImageSRC(newSrc: string, index: number) {\n    const parser = new DOMParser();\n    const doc = parser.parseFromString(this.editorText, 'text/html');\n    const imgTags = doc.getElementsByTagName('img');\n\n  if (imgTags && imgTags.length > 0) {\n    if (index >= 0 && index < imgTags.length) {\n      // Update the src attribute of the img at the specified index\n      \n      imgTags[index].setAttribute('src', newSrc);\n      this.editorText = doc.body.innerHTML;\n    \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\n// onPaste(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  // onPaste(event: ClipboardEvent) {\n  //   event.preventDefault();\n  //   const clipboardData = event.clipboardData;\n  //   if (clipboardData) {\n  //     // Handle image data\n  //     const items = clipboardData.items;\n  //     for (let i = 0; i < items.length; i++) {\n  //       if (items[i].type.startsWith('image/')) {\n  //         const file = items[i].getAsFile();\n  //         if (file) {\n  //           const reader = new FileReader();\n  //           reader.onload = (e: any) => {\n  //             const imgHtml = `<img src=\"${e.target.result}\" alt=\"Pasted Image\" style=\"max-width: 100%;\"/>`;\n  //             this.insertHtmlAtCaret(imgHtml);\n  //           };\n  //           reader.readAsDataURL(file);\n  //           return; // Exit if an image is handled\n  //         }\n  //       }\n  //     }\n\n  //     // Handle text or table data\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  onPaste(event: ClipboardEvent) {\n    event.preventDefault();\n    const clipboardData = event.clipboardData;\n    if (clipboardData) {\n      for (let i = 0; i < clipboardData.items.length; i++) {\n        const item = clipboardData.items[i];\n\n        if (item.type.startsWith(\"image/\")) {\n          // Handle image paste\n          const file = item.getAsFile();\n          if (file) {\n            const reader = new FileReader();\n            reader.onload = (e: any) => {\n              const imgHtml = `<img src=\"${e.target.result}\" alt=\"Pasted Image\" style=\"max-width: 100%;\" />`;\n              this.insertHtmlAtCaret(imgHtml);\n            };\n            reader.readAsDataURL(file);\n            return;\n          }\n        } else if (item.type === \"text/html\") {\n          // Handle HTML paste\n          // const htmlData = clipboardData.getData(\"text/html\");\n          if (this.isTableData(clipboardData.getData('text/html'))) {\n            const html = this.convertTextToTable(clipboardData.getData('text/html'));\n            this.insertHtmlAtCaret(html);\n          } else {\n            this.insertHtmlAtCaret(clipboardData.getData('text/html'));\n          }\n          // this.insertHtmlAtCaret(htmlData);\n          return;\n        } else if (item.type === \"text/plain\") {\n          // Handle plain text paste\n          if (this.isTableData(clipboardData.getData('text/plain'))) {\n            const html = this.convertTextToTable(clipboardData.getData('text/plain'));\n            this.insertHtmlAtCaret(html);\n          } else {\n            this.insertHtmlAtCaret(clipboardData.getData('text/plain'));\n          }\n          // const plainText = clipboardData.getData(\"text/plain\");\n          // this.insertHtmlAtCaret(plainText);\n          return;\n        }\n      }\n    }\n  }\n\n  isExcelData(html: string): boolean {\n    return html.includes('xmlns:o=\"urn:schemas-microsoft-com:office:office\"') || \n          html.includes('xmlns:x=\"urn:schemas-microsoft-com:office:excel\"');\n  }\n\n  convertExcelHtmlToTable(html: string): string {\n    const parser = new DOMParser();\n    const doc = parser.parseFromString(html, 'text/html');\n    const table = doc.querySelector('table');\n    return table ? table.outerHTML : ''; // Extract only the table part\n  }\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\" >${cell}</td>`).join('');\n  //     return `<tr class=\"table-border-top\" style=\"border-top: ${this.themeModeTableBorderTop()}; width: 100% !important\">${cells}</tr>`;\n  //   }).join('');\n  //   return `<table>${tableRows}</table>`;\n  // }\n\n  convertTextToTable(text: string): string {\n    const rows = text.split('\\n').filter(row => row.trim() !== '');\n    const columnCount = rows[0]?.split('\\t').length || 1; // Get the number of columns from the first row\n    const columnWidth = 100 / columnCount; // Calculate column width\n\n    const tableRows = rows.map((row, index) => {\n      const cells = row.split('\\t').map(cell => `\n        <td class=\"px-1 py-1 text-truncate\" \n            style=\"max-width: ${columnWidth}%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;\">\n          ${cell}\n        </td>`).join('');\n\n      // Add a border-top for all rows except the first and border-bottom for the last row\n      const borderTop = index === 0 ? '' : `border-top: ${this.themeModeTableBorderTop()};`;\n      const borderBottom = index === rows.length - 1 ? `border-bottom: ${this.themeModeTableBorderTop()};` : '';\n\n      return `\n        <tr \n          style=\"${borderTop} ${borderBottom} width: 100% !important;\">\n          ${cells}\n        </tr>`;\n    }).join('');\n\n    return `\n      <table style=\"table-layout: fixed; width: 100%;\"> \n        ${tableRows}\n      </table>`;\n  }\n\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  themeModeTableBorderTop() {\n    const clrMode = document.body.getAttribute('data-layout-color')\n    if (clrMode == 'dark') {\n      return '1px solid #D0D0D0; !important'\n    } else {\n      return '1px solid #414141 !important'\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  clearTextEditor() {\n    this.editorTextClear.emit()\n  }\n\n  setupHistory() {\n    this.saveState();\n     const editor = document.getElementById('editor');\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('editor');\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('editor');\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('editor');\n  \n      if (editor) {\n        this.sanitizedContent = redoContent!;\n      }\n    }\n  }\n\n//   formatTextWithDates(text: string): string {\n//   // Regular expression to detect YYYY-MM-DD formatted dates\n//   const dateRegex = /\\b\\d{4}-\\d{2}-\\d{2}\\b/g;\n\n//   // Replace found dates with a formatted version\n//   return text.replace(dateRegex, (dateStr) => {\n//     // Convert the detected date string into a Date object\n//     const dateObj = new Date(dateStr);\n    \n//     // Format the date to 'Month Day, Year' (e.g., October 10, 2024)\n//     return dateObj.toLocaleDateString('en-US', {\n//       year: 'numeric',\n//       month: 'long',\n//       day: 'numeric',\n//     });\n//   });\n  // }\n  \n  formatTextWithDates(text: string): string {\n  // Regular expression to detect YYYY-MM-DD formatted dates\n  const dateRegex = /\\b\\d{4}-\\d{2}-\\d{2}\\b/g;\n\n  // Replace found dates with a formatted version\n  return text.replace(dateRegex, (dateStr) => {\n    // Convert the detected date string into a Date object\n    const dateObj = new Date(dateStr);\n\n    // Extract day, month, and year\n    const day = dateObj.getDate().toString().padStart(2, '0'); // Ensure day is two digits\n    const month = dateObj.toLocaleString('en-US', { month: 'short' }); // Get abbreviated month name\n    const year = dateObj.getFullYear(); // Get full year\n\n    // Format the date as 'dd/mmm/yyyy'\n    return `${day}/${month}/${year}`;\n  });\n}\n\n\n}","<div class=\"container els-text-editor px-0\" id=\"textEditor\" #fullscreen=\"ngxFullscreen\"\r\n                                        #textEditor\r\n                                            ngxFullscreen>\r\n    <div *ngIf=\"toolbarMode === 'fixed'\" class=\"btn-toolbar els-btn-toolbar p-2 py-2 mb-0\" role=\"toolbar\" [style.background]=\"themeModeBgClr()\"\r\n        [ngStyle]=\"{\r\n    'pointer-events': disableToolbar ? 'none' : 'auto',\r\n    'border-top-left-radius': IsOpen ? '0' : '20px',\r\n    'border-top-right-radius': IsOpen ? '0' : '20px'\r\n}\"\r\naria-label=\"Toolbar with button groups\"\r\nstyle=\"border-top-left-radius: 20px !important; border-top-right-radius: 20px !important;\"\r\n>\r\n        <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Header Options\">\r\n            <div ngbDropdown class=\"dropdown\">\r\n                <button\r\n                    class=\"btn btn-white els-form-select border els-toolbar-dropdown-button dropdown-toggle text-start\" [style.border-radius]=\"'5px'\"\r\n                    id=\"headerDropdown\" [style.border]=\"themeMode()\" [style.color]=\"themeModeClr()\" ngbDropdownToggle>\r\n                    <span>{{selectedFormatBlock | titlecase}}</span> <i class=\"mdi mdi-chevron-down \"></i>\r\n                </button>\r\n                <div ngbDropdownMenu aria-labelledby=\"headerDropdown\" class=\"els-text-format\"\r\n                    [style.border]=\"themeMode()\">\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" [style.color]=\"themeModeClr()\"\r\n                        (click)=\"format('formatBlock', '<h1>')\">\r\n                        <h1>Heading 1</h1>\r\n                    </button>\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" [style.color]=\"themeModeClr()\"\r\n                        (click)=\"format('formatBlock', '<h2>')\">\r\n                        <h2>Heading 2</h2>\r\n                    </button>\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" [style.color]=\"themeModeClr()\"\r\n                        (click)=\"format('formatBlock', '<h3>')\">\r\n                        <h3>Heading 3</h3>\r\n                    </button>\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" [style.color]=\"themeModeClr()\"\r\n                        (click)=\"format('formatBlock', '<h4>')\">\r\n                        <h4>Heading 4</h4>\r\n                    </button>\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" [style.color]=\"themeModeClr()\"\r\n                        (click)=\"format('formatBlock', '<h5>')\">\r\n                        <h5>Heading 5</h5>\r\n                    </button>\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" [style.color]=\"themeModeClr()\"\r\n                        (click)=\"format('formatBlock', '<h6>')\">\r\n                        <h6>Heading 6</h6>\r\n                    </button>\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" [style.color]=\"themeModeClr()\"\r\n                        (click)=\"format('formatBlock', '<p>')\">\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            <!-- <select class=\"els-form-select \" style=\" font-weight: 700 !important; color: #fff;border: 2px solid #7D6D6D !important;\" \r\n                [(ngModel)]=\"selectedFont\" (change)=\"changeFont($event)\">\r\n                <option class=\"els-form-option\" *ngFor=\"let font of fonts\" [value]=\"font\">{{ font }}</option>\r\n            </select> -->\r\n            <div ngbDropdown class=\"dropdown\">\r\n                <button\r\n                    class=\"btn btn-white els-form-select border els-toolbar-dropdown-button dropdown-toggle text-start\"\r\n                    id=\"headerDropdown\" style=\"width: 100px\" [style.border]=\"themeMode()\" [style.color]=\"themeModeClr()\"\r\n                    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                    [style.border]=\"themeMode()\">\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" *ngFor=\"let font of fonts\"\r\n                        (click)=\"changeFont(font)\" [style.color]=\"themeModeClr()\">\r\n                        <span>{{ font }}</span>\r\n                    </button>\r\n                </div>\r\n            </div>\r\n        </div>\r\n        <div class=\"py-0\"  style=\"height: fit-content;\" [style.color]=\"themeModeClr()\">\r\n            <div class=\"btn-group els-button-group me-2 mr-2 \" role=\"group\" aria-label=\"Text Formatting\">\r\n                <button type=\"button\" class=\"btn btn-white els-toolbar-button\" [class.active]=\"isBoldActive\"\r\n                    (click)=\"format('bold')\">\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')\">\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')\">\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')\">\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>\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>\r\n                <div class=\"vertical-line ms-2 border\" [style.border-left]=\"themeModeClrVerticalLine()\"></div>\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)=\"format('insertOrderedList')\"><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')\"><i 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 text-dark\"\r\n                            (click)=\"format('justifyLeft')\"><i class=\"mdi mdi-format-align-left\"></i></button>\r\n                        <button type=\"button\" class=\"btn btn-white els-toolbar-button text-dark\"\r\n                            (click)=\"format('justifyCenter')\"><i class=\"mdi mdi-format-align-center\"></i></button>\r\n                        <button type=\"button\" class=\"btn btn-white els-toolbar-button text-dark\"\r\n                            (click)=\"format('justifyRight')\"><i class=\"mdi mdi-format-align-right\"></i></button>\r\n                        <button type=\"button\" class=\"btn btn-white els-toolbar-button text-dark\"\r\n                            (click)=\"format('justifyFull')\"><i class=\"mdi mdi-format-align-justify\"></i></button>\r\n                    </div>\r\n                </div>\r\n                <div class=\"vertical-line ms-2 border\" [style.border-left]=\"themeModeClrVerticalLine()\"></div>\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')\">\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')\">\r\n                    <i class=\"mdi mdi-format-superscript\"></i>\r\n                </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)=\"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()\"><i\r\n                        class=\"mdi mdi-image\"></i></button>\r\n                <input type=\"file\" id=\"imageInput\" style=\"display: none;\" (change)=\"handleImageUpload($event)\" accept=\"image/*\">\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\"\r\n                    (click)=\"addRow()\"><i 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=\"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            </div> -->\r\n            <div class=\"btn-group els-button-group\" 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                    style=\" width: fit-content !important;\">\r\n                    <i class=\"mdi mdi-close-circle\"></i>\r\n                </button>\r\n            </div>\r\n            <div class=\"btn-group els-button-group\" role=\"group\" aria-label=\"Table Options\">\r\n                <button class=\"btn btn-white els-toolbar-button\" (click)=\"toggleFullscreen1()\">\r\n                    <ng-container *ngIf=\"IsOpen; else fullscreenIcon\">\r\n                        <i class=\"mdi mdi-fullscreen-exit\"></i> <!-- Collapse Icon -->\r\n                    </ng-container>\r\n                    <ng-template #fullscreenIcon>\r\n                        <i class=\"mdi mdi-fullscreen\"></i> <!-- Expand Icon -->\r\n                    </ng-template>\r\n                </button>\r\n            </div>\r\n        </div>\r\n    </div>\r\n    <div *ngIf=\"toolbarMode === 'bubble'\" class=\"bubble-toolbar border p-2\"\r\n        [ngStyle]=\"{'top.px': toolbarTop, 'left.px': toolbarLeft, 'display': showToolbar ? 'block' : 'none'}\">\r\n        <div class=\"btn-group els-button-group\" role=\"group\" aria-label=\"Font Options\">\r\n            <select class=\"els-form-select\" [(ngModel)]=\"selectedFont\" (change)=\"changeFont($event)\">\r\n                <option *ngFor=\"let font of fonts\" [value]=\"font\">{{ font }}</option>\r\n            </select>\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]=\"isBoldActive\"\r\n                (click)=\"format('bold')\">\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')\">\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')\">\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')\">\r\n                <i class=\"mdi mdi-format-strikethrough-variant\"></i>\r\n            </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)=\"format('blockquote')\"><i\r\n                        class=\"mdi mdi-format-quote-close\"></i></button>\r\n                <button type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"insertCodeBlock()\"><i \r\n                        class=\"mdi mdi-code-tags\"></i></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)=\"format('insertOrderedList')\"><i\r\n                    class=\"mdi mdi-format-list-numbered\"></i></button>\r\n            <button type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"format('insertUnorderedList')\"><i\r\n                    class=\"mdi mdi-format-list-bulleted\"></i></button>\r\n            <!-- <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Color Formatting\"> -->\r\n            <div class=\"btn-group\" role=\"group\" aria-label=\"Text Color\">\r\n                <!-- <div ngbDropdown class=\"ql-align\">\r\n                                <button type=\"button\" class=\"btn btn-outline-primary arrow-none text-secondary\" id=\"dropdownBasic1\"\r\n                                    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: 300px;\">\r\n                                    <color-sketch color=\"#fff\" (onChangeComplete)=\"setTextColor($event)\"></color-sketch>\r\n                                </div>\r\n                            </div> -->\r\n                <!-- <div class=\"btn btn-white els-toolbar-button custom-color-trigger\" ngx-colors-trigger [(ngModel)]=\"color\"\r\n                                (ngModelChange)=\"logEvent($event, 'ngModelChange')\"\r\n                                (change)=\"logEvent($event, 'change')\"\r\n                                (input)=\"logEvent($event, 'input')\"\r\n                                >\r\n                                <i class=\"mdi mdi-format-color-text icon-with-underline\" [style.color]=\"color\"\r\n                                    [style]=\"{color: color}\"></i>\r\n                                <ngx-colors style=\"display: none;\" ></ngx-colors>\r\n                            </div> -->\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>\r\n\r\n            <!-- <div class=\"btn-group\" role=\"group\" aria-label=\"Background Color\">\r\n                            <input type=\"color\" id=\"bgColorPicker\" style=\"display: none;\" (change)=\"setBackgroundColor($event)\">\r\n                            <button type=\"button\" class=\"btn btn-white els-toolbar-button\"\r\n                                (click)=\"openColorPicker('bgColorPicker')\">\r\n                                <i class=\"mdi mdi-alpha-a-box\"></i>\r\n                            </button>\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 style=\"width: 0px !important;\" id=\"bgColorPicker\" [cpPresetColors]=\"['#fff', '#000', '#2889e9', '#e920e9', '#fff500', 'rgb(236,64,64)']\"\r\n                                [(colorPicker)]=\"color\" (change)=\"setBackgroundColor($event)\" /> -->\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>\r\n\r\n\r\n            <!-- </div> -->\r\n        </div>\r\n        <!-- <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Header Options\">\r\n                    <div class=\"dropdown\">\r\n                            <button class=\"btn btn-white els-toolbar-button dropdown-toggle\" type=\"button\" id=\"headerDropdown\"\r\n                                    data-toggle=\"dropdown\" aria-haspopup=\"true\" aria-expanded=\"false\">\r\n                                    <i class=\"mdi mdi-format-header-1\"></i>\r\n                            </button>\r\n                            <div class=\"dropdown-menu\" aria-labelledby=\"headerDropdown\">\r\n                                    <button class=\"dropdown-item\" type=\"button\" (click)=\"format('formatBlock', '<h1>')\"><i\r\n                                                    class=\"mdi mdi-format-header-1\"></i> Heading 1</button>\r\n                                    <button class=\"dropdown-item\" type=\"button\" (click)=\"format('formatBlock', '<h2>')\"><i\r\n                                                    class=\"mdi mdi-format-header-2\"></i> Heading 2</button>\r\n                                    <button class=\"dropdown-item\" type=\"button\" (click)=\"format('formatBlock', '<h3>')\"><i\r\n                                                    class=\"mdi mdi-format-header-3\"></i> Heading 3</button>\r\n                                    <button class=\"dropdown-item\" type=\"button\" (click)=\"format('formatBlock', '<h4>')\"><i\r\n                                                    class=\"mdi mdi-format-header-4\"></i> Heading 4</button>\r\n                                    <button class=\"dropdown-item\" type=\"button\" (click)=\"format('formatBlock', '<h5>')\"><i\r\n                                                    class=\"mdi mdi-format-header-5\"></i> Heading 5</button>\r\n                                    <button class=\"dropdown-item\" type=\"button\" (click)=\"format('formatBlock', '<h6>')\"><i\r\n                                                    class=\"mdi mdi-format-header-6\"></i> Heading 6</button>\r\n                            </div>\r\n                    </div>\r\n            </div> -->\r\n        <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Header Options\">\r\n            <div ngbDropdown class=\"dropdown\">\r\n                <button class=\"btn btn-white els-toolbar-dropdown-button dropdown-toggle\" id=\"headerDropdown\"\r\n                    ngbDropdownToggle>\r\n                    <span style=\"width: 85px;\">{{selectedFormatBlock | titlecase}}</span> <i\r\n                        class=\"mdi mdi-chevron-down text-dark\"></i>\r\n                </button>\r\n                <div ngbDropdownMenu aria-labelledby=\"headerDropdown\">\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"format('formatBlock', '<h1>')\">\r\n                        <h1>Heading 1</h1>\r\n                    </button>\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"format('formatBlock', '<h2>')\">\r\n                        <h2>Heading 2</h2>\r\n                    </button>\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"format('formatBlock', '<h3>')\">\r\n                        <h3>Heading 3</h3>\r\n                    </button>\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"format('formatBlock', '<h4>')\">\r\n                        <h4>Heading 4</h4>\r\n                    </button>\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"format('formatBlock', '<h5>')\">\r\n                        <h5>Heading 5</h5>\r\n                    </button>\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"format('formatBlock', '<h6>')\">\r\n                        <h6>Heading 6</h6>\r\n                    </button>\r\n                    <button class=\"dropdown-item pb-0\" type=\"button\" (click)=\"format('formatBlock', '<p>')\">\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 mr-2\" role=\"group\" aria-label=\"Text Formatting\">\r\n            <!-- <button type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"format('superscript')\"><i\r\n                        class=\"mdi mdi-format-superscript\"></i></button>\r\n                <button type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"format('subscript')\"><i\r\n                        class=\"mdi mdi-format-subscript\"></i></button> -->\r\n            <button type=\"button\" class=\"btn btn-white els-toolbar-button\" [class.active]=\"isSubscriptActive\"\r\n                (click)=\"format('subscript')\">\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')\">\r\n                <i class=\"mdi mdi-format-superscript\"></i>\r\n            </button>\r\n        </div>\r\n        <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Text Formatting\">\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\" (click)=\"format('justifyLeft')\"><i\r\n                            class=\"mdi mdi-format-align-left\"></i></button>\r\n                    <button type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"format('justifyCenter')\"><i\r\n                            class=\"mdi mdi-format-align-center\"></i></button>\r\n                    <button type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"format('justifyRight')\"><i\r\n                            class=\"mdi mdi-format-align-right\"></i></button>\r\n                    <button type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"format('justifyFull')\"><i\r\n                            class=\"mdi mdi-format-align-justify\"></i></button>\r\n                </div>\r\n            </div>\r\n        </div>\r\n\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)=\"format('removeFormat')\"><i\r\n                    class=\"mdi mdi-format-clear\"></i></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)=\"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()\"><i\r\n                    class=\"mdi mdi-image\"></i></button>\r\n            <input type=\"file\" id=\"imageInput\" style=\"display: none;\" (change)=\"handleImageUpload($event)\" accept=\"image/*\">\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\r\n\r\n        <!-- <div class=\"btn btn-white els-toolbar-button custom-color-trigger\">\r\n        <i class=\"mdi mdi-format-color-text icon-with-underline\" [style.color]=\"color\"></i>\r\n        <ngx-colors [(ngModel)]=\"color\" (change)=\"colorChanged($event)\"></ngx-colors>\r\n    </div> -->\r\n        <!-- <div class=\"btn-group els-button-group\" ngbDropdown aria-label=\"Table Options\">\r\n                <button class=\"btn btn-white els-toolbar-button\" ngbDropdownToggle  (click)=\"addTable()\">\r\n                    <i class=\"mdi mdi-table\"></i>\r\n                </button>\r\n            \r\n                <div ngbDropdownMenu *ngIf=\"isTableSelected || tableAdded\">\r\n                    <button class=\"dropdown-item\" (click)=\"addRow()\">\r\n                        <i class=\"mdi mdi-table-row-plus-after\"></i> Add Row\r\n                    </button>\r\n                    <button class=\"dropdown-item\" (click)=\"deleteRow()\">\r\n                        <i class=\"mdi mdi-table-row-remove\"></i> Delete Row\r\n                    </button>\r\n                    <button class=\"dropdown-item\" (click)=\"addColumn()\">\r\n                        <i class=\"mdi mdi-table-column-plus-after\"></i> Add Column\r\n                    </button>\r\n                    <button class=\"dropdown-item\" (click)=\"deleteColumn()\">\r\n                        <i class=\"mdi mdi-table-column-remove\"></i> Delete Column\r\n                    </button>\r\n                    <div class=\"dropdown-divider\"></div>\r\n                    <div class=\"dropdown-item\">\r\n                        <label for=\"tableWidth\">Table Width</label>\r\n                        <input type=\"number\" id=\"tableWidth\" class=\"form-control\" (change)=\"adjustTableWidth($event)\"\r\n                            placeholder=\"Width\">\r\n                    </div>\r\n                    <div class=\"dropdown-item\">\r\n                        <label for=\"cellWidth\">Cell Width</label>\r\n                        <input type=\"number\" id=\"cellWidth\" class=\"form-control\" (change)=\"adjustCellWidth($event)\"\r\n                            placeholder=\"Width\">\r\n                    </div>\r\n                    <div class=\"dropdown-item\">\r\n                        <label for=\"cellHeight\">Cell Height</label>\r\n                        <input type=\"number\" id=\"cellHeight\" class=\"form-control\" (change)=\"adjustCellHeight($event)\"\r\n                            placeholder=\"Height\">\r\n                    </div>\r\n                </div>\r\n            </div> -->\r\n    </div>\r\n    <!-- <div contenteditable=\"true\" id=\"editor\" class=\"p-3 custom-scrollbar non-focus\" #editor\r\n        style=\"position: relative !important;border-bottom-left-radius: 20px !important; border-bottom-right-radius: 20px !important; border-bottom-left-radius: 20px !important;\" [style.background]=\"themeModeBgClr()\" [style.border-top]=\"themeModeBorderTop()\"\r\n        [ngStyle]=\"{'font-family': selectedFont, 'font-size': selectedFontSize + 'px'}\" [style]=\"style\"\r\n        [style.min-height]=\"IsOpen ? '85vh !important' :  '405px !important'\"\r\n        (input)=\"onModelChange($event)\" placeholder=\"Insert text here ...\" readonly (mouseup)=\"onTextSelect($event)\"\r\n        [innerHTML]=\"sanitizedContent\" (paste)=\"onPaste($event)\" (focus)=\"onFocus()\" (blur)=\"onBlur()\"\r\n        (click)=\"checkTableSelection($event)\">\r\n    </div> -->\r\n    <!-- <div contenteditable=\"true\" id=\"editor\" class=\"p-3 custom-scrollbar non-focus overflow-auto\" #editor\r\n         style=\"position: relative !important;\r\n               \" [style.background]=\"themeModeBgClr()\"\r\n        [style.border-top]=\"themeModeBorderTop()\"\r\n        \r\n        [ngStyle]=\"{'font-family': selectedFont, 'font-size': selectedFontSize + 'px',\r\n           'border-bottom-left-radius': isOpen ? '0' :'20px',\r\n           'border-bottom-right-radius': isOpen ? '0' :'20px'\r\n        }\"\r\n        [style.min-height]=\"IsOpen ? '93vh' : '405px'\" (input)=\"onModelChange($event)\" placeholder=\"Insert text here ...\"\r\n        readonly (mouseup)=\"onTextSelect($event)\" [innerHTML]=\"sanitizedContent\" (paste)=\"onPaste($event)\"\r\n        (focus)=\"onFocus()\" (blur)=\"onBlur()\" (click)=\"checkTableSelection($event)\">\r\n    </div> -->\r\n    <div contenteditable=\"true\" id=\"editor\" class=\"p-3 custom-scrollbar non-focus overflow-auto\" #editor\r\n        style=\"position: relative !important; overflow: auto;\" [style.background]=\"themeModeBgClr()\"\r\n        [style.border-top]=\"themeModeBorderTop()\" [ngStyle]=\"{\r\n                'font-family': selectedFont, \r\n                'font-size': selectedFontSize + 'px',\r\n                'border-bottom-left-radius': IsOpen ? '0' :'20px',\r\n                'border-bottom-right-radius': IsOpen ? '0' :'20px',\r\n                'min-height': IsOpen ? '93vh' : '405px',\r\n                'max-height': IsOpen ? '93vh' : '405px'\r\n            }\" placeholder=\"Insert text here ...\" readonly (mouseup)=\"onTextSelect($event)\"\r\n        (input)=\"onModelChange($event)\" [innerHTML]=\"sanitizedContent\" (paste)=\"onPaste($event)\" (focus)=\"onFocus()\"\r\n        (blur)=\"onBlur()\" (click)=\"checkTableSelection($event)\">\r\n    </div>\r\n\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\r\n</div>"]}