el-text-editor 0.0.89 → 0.0.90

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.
@@ -1459,13 +1459,91 @@ export class ElTextEditorComponent {
1459
1459
  // }
1460
1460
  // }
1461
1461
  // }
1462
+ // setTextColor(event: any) {
1463
+ // console.log("Clicked setTextColor");
1464
+ // if (!this.savedSelection) {
1465
+ // console.warn("No saved selection available!");
1466
+ // return;
1467
+ // }
1468
+ // const color = event.target.value;
1469
+ // this.selectedTextColor = color;
1470
+ // const selection = window.getSelection();
1471
+ // if (!selection || selection.rangeCount === 0) {
1472
+ // console.error("No valid selection found!");
1473
+ // return;
1474
+ // }
1475
+ // selection.removeAllRanges();
1476
+ // selection.addRange(this.savedSelection);
1477
+ // const range = this.savedSelection;
1478
+ // const getTableCell = (node: Node | null): HTMLElement | null => {
1479
+ // let currentNode = node;
1480
+ // if (currentNode && currentNode.nodeType === Node.TEXT_NODE) {
1481
+ // currentNode = currentNode.parentNode;
1482
+ // }
1483
+ // while (currentNode && currentNode instanceof HTMLElement) {
1484
+ // if (currentNode.tagName === "TD" || currentNode.tagName === "TH") {
1485
+ // return currentNode;
1486
+ // }
1487
+ // currentNode = currentNode.parentElement;
1488
+ // }
1489
+ // return null;
1490
+ // };
1491
+ // const tableCell =
1492
+ // getTableCell(range.commonAncestorContainer) ||
1493
+ // getTableCell(range.startContainer) ||
1494
+ // getTableCell(range.endContainer);
1495
+ // if (tableCell) {
1496
+ // console.log(`Processing ${tableCell.tagName} element`);
1497
+ // const selectedText = selection.toString();
1498
+ // if (selectedText) {
1499
+ // console.log(`Selected text in ${tableCell.tagName}:`, selectedText);
1500
+ // const textNodes: Text[] = [];
1501
+ // const walker = document.createTreeWalker(
1502
+ // tableCell,
1503
+ // NodeFilter.SHOW_TEXT,
1504
+ // null
1505
+ // );
1506
+ // let node: Text | null;
1507
+ // while ((node = walker.nextNode() as Text | null)) {
1508
+ // textNodes.push(node);
1509
+ // }
1510
+ // for (const textNode of textNodes) {
1511
+ // const text = textNode.textContent || "";
1512
+ // const index = text.indexOf(selectedText);
1513
+ // if (index !== -1) {
1514
+ // console.log(
1515
+ // `Found selected text in ${tableCell.tagName} text node`
1516
+ // );
1517
+ // const span = document.createElement("span");
1518
+ // span.style.color = color;
1519
+ // span.textContent = selectedText;
1520
+ // const beforeText = text.slice(0, index);
1521
+ // const afterText = text.slice(index + selectedText.length);
1522
+ // const fragment = document.createDocumentFragment();
1523
+ // if (beforeText)
1524
+ // fragment.appendChild(document.createTextNode(beforeText));
1525
+ // fragment.appendChild(span);
1526
+ // if (afterText)
1527
+ // fragment.appendChild(document.createTextNode(afterText));
1528
+ // textNode.replaceWith(fragment);
1529
+ // break; // Apply only once per selection
1530
+ // }
1531
+ // }
1532
+ // }
1533
+ // } else {
1534
+ // console.log("No TH or TD element found in selection");
1535
+ // return;
1536
+ // }
1537
+ // this.savedSelection = null;
1538
+ // }
1462
1539
  setTextColor(event) {
1463
- console.log("Clicked setTextColor");
1540
+ console.log("clicked");
1464
1541
  if (!this.savedSelection) {
1465
1542
  console.warn("No saved selection available!");
1466
1543
  return;
1467
1544
  }
1468
1545
  const color = event.target.value;
1546
+ console.log("color", color);
1469
1547
  this.selectedTextColor = color;
1470
1548
  const selection = window.getSelection();
1471
1549
  if (!selection || selection.rangeCount === 0) {
@@ -1475,59 +1553,57 @@ export class ElTextEditorComponent {
1475
1553
  selection.removeAllRanges();
1476
1554
  selection.addRange(this.savedSelection);
1477
1555
  const range = this.savedSelection;
1478
- const getTableCell = (node) => {
1556
+ const getParentElement = (node) => {
1479
1557
  let currentNode = node;
1480
1558
  if (currentNode && currentNode.nodeType === Node.TEXT_NODE) {
1481
1559
  currentNode = currentNode.parentNode;
1482
1560
  }
1483
1561
  while (currentNode && currentNode instanceof HTMLElement) {
1484
- if (currentNode.tagName === "TD" || currentNode.tagName === "TH") {
1485
- return currentNode;
1486
- }
1487
- currentNode = currentNode.parentElement;
1562
+ return currentNode;
1488
1563
  }
1489
1564
  return null;
1490
1565
  };
1491
- const tableCell = getTableCell(range.commonAncestorContainer) ||
1492
- getTableCell(range.startContainer) ||
1493
- getTableCell(range.endContainer);
1494
- if (tableCell) {
1495
- console.log(`Processing ${tableCell.tagName} element`);
1496
- const selectedText = selection.toString();
1497
- if (selectedText) {
1498
- console.log(`Selected text in ${tableCell.tagName}:`, selectedText);
1499
- const textNodes = [];
1500
- const walker = document.createTreeWalker(tableCell, NodeFilter.SHOW_TEXT, null);
1501
- let node;
1502
- while ((node = walker.nextNode())) {
1503
- textNodes.push(node);
1504
- }
1505
- for (const textNode of textNodes) {
1506
- const text = textNode.textContent || "";
1507
- const index = text.indexOf(selectedText);
1508
- if (index !== -1) {
1509
- console.log(`Found selected text in ${tableCell.tagName} text node`);
1510
- const span = document.createElement("span");
1511
- span.style.color = color;
1512
- span.textContent = selectedText;
1513
- const beforeText = text.slice(0, index);
1514
- const afterText = text.slice(index + selectedText.length);
1515
- const fragment = document.createDocumentFragment();
1516
- if (beforeText)
1517
- fragment.appendChild(document.createTextNode(beforeText));
1518
- fragment.appendChild(span);
1519
- if (afterText)
1520
- fragment.appendChild(document.createTextNode(afterText));
1521
- textNode.replaceWith(fragment);
1522
- break; // Apply only once per selection
1523
- }
1524
- }
1525
- }
1566
+ const parentElement = getParentElement(range.commonAncestorContainer) ||
1567
+ getParentElement(range.startContainer) ||
1568
+ getParentElement(range.endContainer);
1569
+ if (!parentElement) {
1570
+ console.error("No valid parent element found!");
1571
+ return;
1526
1572
  }
1527
- else {
1528
- console.log("No TH or TD element found in selection");
1573
+ // **Handle Table Cell Case**
1574
+ if (parentElement.tagName === "TD") {
1575
+ parentElement.style.color = color; // Apply color directly to cell
1529
1576
  return;
1530
1577
  }
1578
+ // **Handle Normal Text Case**
1579
+ const selectedText = selection.toString();
1580
+ if (selectedText) {
1581
+ const textNodes = [];
1582
+ const walker = document.createTreeWalker(parentElement, NodeFilter.SHOW_TEXT, null);
1583
+ let node;
1584
+ while ((node = walker.nextNode())) {
1585
+ textNodes.push(node);
1586
+ }
1587
+ for (const textNode of textNodes) {
1588
+ const text = textNode.textContent || "";
1589
+ const index = text.indexOf(selectedText);
1590
+ if (index !== -1) {
1591
+ const span = document.createElement("span");
1592
+ span.style.color = color;
1593
+ span.textContent = selectedText;
1594
+ const beforeText = text.slice(0, index);
1595
+ const afterText = text.slice(index + selectedText.length);
1596
+ const fragment = document.createDocumentFragment();
1597
+ if (beforeText)
1598
+ fragment.appendChild(document.createTextNode(beforeText));
1599
+ fragment.appendChild(span);
1600
+ if (afterText)
1601
+ fragment.appendChild(document.createTextNode(afterText));
1602
+ textNode.replaceWith(fragment);
1603
+ break; // Apply only once per selection
1604
+ }
1605
+ }
1606
+ }
1531
1607
  this.savedSelection = null;
1532
1608
  }
1533
1609
  setBackgroundColor(event) {
@@ -2002,4 +2078,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImpor
2002
2078
  type: ViewChild,
2003
2079
  args: ['fullscreen']
2004
2080
  }] } });
2005
- //# 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":"AAAA,OAAO,EAAiB,SAAS,EAAE,KAAK,EAAU,MAAM,EAAE,YAAY,EAAE,UAAU,EAAE,SAAS,EAAmD,MAAM,eAAe,CAAC;AACtK,OAAO,EAAqC,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAMtF,yGAAyG;AACzG,OAAO,EAAE,QAAQ,EAAc,MAAM,WAAW,CAAC;;;;;;;;AAajD,MAAM,OAAO,qBAAqB;IAsFhC,YACU,MAAc,EACd,KAAqB,EACrB,QAAmB,EACnB,SAAuB;QAHvB,WAAM,GAAN,MAAM,CAAQ;QACd,UAAK,GAAL,KAAK,CAAgB;QACrB,aAAQ,GAAR,QAAQ,CAAW;QACnB,cAAS,GAAT,SAAS,CAAc;QAxFxB,eAAU,GAAW,EAAE,CAAC;QASxB,gBAAW,GAAgC,OAAO,CAAC;QACnD,oBAAe,GAAY,IAAI,CAAC,CAAC,0BAA0B;QAC1D,0BAAqB,GAA0B,IAAI,YAAY,EAAW,CAAC,CAAC,qBAAqB;QACjG,qBAAgB,GAAG,IAAI,YAAY,EAAU,CAAC;QAC9C,yBAAoB,GAAG,IAAI,YAAY,EAAO,CAAC;QAC/C,oBAAe,GAAG,IAAI,YAAY,EAAO,CAAC;QAC1C,cAAS,GAAG,IAAI,YAAY,EAAO,CAAC;QACpC,eAAU,GAAG,IAAI,YAAY,EAAO,CAAC;QACrC,sBAAiB,GAAG,IAAI,YAAY,EAAO,CAAC;QAC5C,WAAM,GAAG,IAAI,YAAY,EAAO,CAAC;QACjC,kBAAa,GAAG,IAAI,YAAY,EAAO,CAAC;QAEzC,UAAK,GAAW,EAAE,CAAC;QAS5B,gBAAW,GAAG,KAAK,CAAC;QACpB,eAAU,GAAG,CAAC,CAAC;QACf,gBAAW,GAAG,CAAC,CAAC;QAEhB,UAAK,GAAG,CAAC,OAAO,EAAE,aAAa,EAAE,SAAS,EAAE,iBAAiB,EAAE,SAAS,CAAC,CAAC;QAC1E,cAAS,GAAG,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;QACrD,iBAAY,GAAG,OAAO,CAAC;QACvB,qBAAgB,GAAG,EAAE,CAAC;QACtB,oBAAe,GAAG,KAAK,CAAC;QACxB,eAAU,GAAG,KAAK,CAAC;QACnB,kBAAa,GAA4B,IAAI,CAAC;QAC9C,yBAAoB,GAAG,IAAI,CAAC;QAC5B,iBAAY,GAAgC,IAAI,CAAC;QAEjD,iBAAY,GAAY,KAAK,CAAC;QAC9B,mBAAc,GAAY,KAAK,CAAC;QAChC,sBAAiB,GAAY,KAAK,CAAC;QACnC,0BAAqB,GAAY,KAAK,CAAC;QACvC,sBAAiB,GAAY,KAAK,CAAC;QACnC,wBAAmB,GAAY,KAAK,CAAC;QAErC,wBAAmB,GAAW,QAAQ,CAAA;QAEtC,kBAAa,GAA4B,IAAI,CAAC;QAC9C,iBAAY,GAAW,EAAE,CAAC;QAC1B,mBAAc,GAAG,CAAC,CAAC;QACnB,mBAAc,GAAG,CAAC,CAAC;QACnB,sBAAiB,GAAG,CAAC,CAAC;QACtB,sBAAiB,GAAG,CAAC,CAAC;QACtB,0BAAqB,GAAG,CAAC,CAAC;QAC1B,2BAAsB,GAAG,CAAC,CAAC;QAC3B,yBAAoB,GAAiE,IAAI,CAAC;QAE1F,cAAS,GAAa,EAAE,CAAC;QACzB,cAAS,GAAa,EAAE,CAAC;QACzB,YAAO,GAAa,EAAE,CAAC;QACvB,iBAAY,GAAG,CAAC,CAAC,CAAC;QAGlB,aAAQ,GAAQ,GAAG,EAAE,GAAE,CAAC,CAAC;QACzB,cAAS,GAAQ,GAAG,EAAE,GAAE,CAAC,CAAC;QAC1B,UAAK,GAAQ,MAAM,CAAC;QAGpB,sBAAiB,GAAkB,IAAI,CAAC;QAExC,gBAAW,GAAmD,IAAI,CAAC;QAEnE,iBAAY,GAAY,KAAK,CAAC;QAE9B,aAAQ,GAAU,EAAE,CAAC;QACrB,mBAAc,GAAY,KAAK,CAAC;QAwGhC,WAAM,GAAY,KAAK,CAAC;QAYhB,uBAAkB,GAAG,GAAG,EAAE;YAChC,IAAI,CAAC,QAAQ,CAAC,iBAAiB,EAAE;gBAC/B,iCAAiC;gBACjC,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;gBACpB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;aAC/B;QACH,CAAC,CAAC;QAm1CF,qCAAqC;QACrC,2DAA2D;QAC3D,wBAAwB;QACxB,4BAA4B;QAC5B,MAAM;QACN,IAAI;QAEJ,6BAA6B;QAC7B,sDAAsD;QACtD,kBAAkB;QAClB,sBAAsB;QACtB,wCAAwC;QACxC,sCAAsC;QACtC,uDAAuD;QACvD,MAAM;QACN,IAAI;QAEJ,mCAAmC;QACnC,sDAAsD;QACtD,kBAAkB;QAClB,sBAAsB;QACtB,wCAAwC;QACxC,oCAAoC;QACpC,yDAAyD;QACzD,MAAM;QACN,IAAI;QAEI,mBAAc,GAAiB,IAAI,CAAC;QA/9C1C,IAAI,CAAC,YAAY,EAAE,CAAA;IAGrB,CAAC;IAED,SAAS;QACP,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,mBAAmB,CAAC,CAAA;QAC/D,IAAI,OAAO,IAAI,MAAM,EAAE;YACrB,OAAO,8BAA8B,CAAA;SACtC;aAAM;YACL,OAAO,8BAA8B,CAAA;SACtC;IACH,CAAC;IAED,YAAY;QACV,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,mBAAmB,CAAC,CAAA;QAC/D,IAAI,OAAO,IAAI,MAAM,EAAE;YACrB,OAAO,iBAAiB,CAAA;SACzB;aAAM;YACL,OAAO,iBAAiB,CAAA;SACzB;IACH,CAAC;IAED,wBAAwB;QACtB,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,mBAAmB,CAAC,CAAA;QAC/D,IAAI,OAAO,IAAI,MAAM,EAAE;YACrB,OAAO,8BAA8B,CAAA;SACtC;aAAM;YACL,OAAO,8BAA8B,CAAA;SACtC;IACH,CAAC;IAED,cAAc;QACZ,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,mBAAmB,CAAC,CAAA;QAC/D,IAAI,OAAO,IAAI,MAAM,EAAE;YACrB,OAAO,oBAAoB,CAAA;SAC5B;aAAM;YACL,OAAO,oBAAoB,CAAA;SAC5B;IACH,CAAC;IAED,kBAAkB;QAChB,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,mBAAmB,CAAC,CAAA;QAC/D,IAAI,OAAO,IAAI,MAAM,EAAE;YACrB,OAAO,2BAA2B,CAAA;SACnC;aAAM;YACL,OAAO,2BAA2B,CAAA;SACnC;IACH,CAAC;IACD,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,aAAa,CAAC,EAAE;YAC1B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,CAAA;SAErC;QAED,IAAI,OAAO,CAAC,UAAU,CAAC,EAAE;YACvB,cAAc,CAAC,OAAO,CAAC,UAAU,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAA;SAClD;QAED,IAAI,OAAO,CAAC,UAAU,CAAC,EAAE;YACvB,IAAI,CAAC,YAAY,EAAE,CAAA;SACpB;IACH,CAAC;IACD,eAAe;QACb,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACxB,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,QAAQ,CAAC,gBAAgB,CAAC,kBAAkB,EAAE,IAAI,CAAC,kBAAkB,CAAC,CAAC;IACzE,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA;QAC/B,QAAQ,CAAC,gBAAgB,CAAC,iBAAiB,EAAE,GAAG,EAAE;YAChD,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACzB,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC1B,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAChC,IAAI,CAAC,0BAA0B,EAAE,CAAC;QAClC,+CAA+C;QAC/C,6CAA6C;QAC7C,0BAA0B;QAC1B,kEAAkE;QAClE,oBAAoB;QACpB,uDAAuD;QACvD,QAAQ;QACR,sDAAsD;QACtD,MAAM;QACN,KAAK;IACP,CAAC;IAEA,WAAW;QACV,6DAA6D;QAC7D,QAAQ,CAAC,mBAAmB,CAAC,kBAAkB,EAAE,IAAI,CAAC,kBAAkB,CAAC,CAAC;IAC5E,CAAC;IAIC,iBAAiB;QACf,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC;QAC3B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;QAC7B,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;SACtD;aAAM;YACL,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAA;SACvB;IACH,CAAC;IAUH,2BAA2B;IAC3B,kCAAkC;IAClC,8BAA8B;IAC9B,yBAAyB;IACzB,sBAAsB;IACtB,4DAA4D;IAC5D,aAAa;IACb,6BAA6B;IAC7B,MAAM;IAEN,IAAI;IAEJ,UAAU,CAAC,KAAU;QACnB,IAAI,KAAK,KAAK,SAAS,EAAE;YACvB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;YACxB,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;SACjC;IACH,CAAC;IAEH,wCAAwC;IACxC,sDAAsD;IACtD,kBAAkB;IAClB,oDAAoD;IACpD,oDAAoD;IACpD,wCAAwC;IACxC,2DAA2D;IAC3D,sDAAsD;IAEtD,4DAA4D;IAC5D,yEAAyE;IACzE,uDAAuD;IACvD,qDAAqD;IACrD,mDAAmD;IACnD,sDAAsD;IACtD,wFAAwF;IACxF,uDAAuD;IACvD,YAAY;IACZ,gFAAgF;IAChF,gCAAgC;IAChC,qCAAqC;IACrC,YAAY;IAEZ,2DAA2D;IAC3D,0CAA0C;IAC1C,2CAA2C;IAE3C,6DAA6D;IAC7D,8CAA8C;IAC9C,oCAAoC;IACpC,qCAAqC;IACrC,4DAA4D;IAC5D,wCAAwC;IACxC,iDAAiD;IACjD,kDAAkD;IAClD,4CAA4C;IAC5C,0CAA0C;IAC1C,2CAA2C;IAE3C,oDAAoD;IACpD,iCAAiC;IACjC,8BAA8B;IAC9B,cAAc;IAEd,yCAAyC;IACzC,iBAAiB;IACjB,qCAAqC;IACrC,yCAAyC;IACzC,UAAU;IACV,UAAU;IACV,MAAM;IACJ,IAAI;IACJ,YAAY;QACV,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAA;IAC/B,CAAC;IACD,gBAAgB;IAChB,qDAAqD;IACrD,0BAA0B;IAC1B,+CAA+C;IAC/C,qCAAqC;IACrC,MAAM;IACN,IAAI;IAEJ,SAAS;QACP,IAAI,YAAY,GAAa,EAAE,CAAC;QAChC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,EAAE,CAAC,EAAE;YAC9C,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC;SAC3C;QACD,OAAO,YAAY,CAAC;IACtB,CAAC;IAGH,uCAAuC;IACvC,sDAAsD;IACtD,kEAAkE;IAClE,6CAA6C;IAC7C,iDAAiD;IACjD,mDAAmD;IAEnD,gCAAgC;IAChC,oBAAoB;IACpB,oDAAoD;IACpD,oDAAoD;IACpD,wCAAwC;IACxC,2DAA2D;IAC3D,sDAAsD;IACtD,4DAA4D;IAC5D,yEAAyE;IACzE,uDAAuD;IACvD,qDAAqD;IACrD,mDAAmD;IACnD,wDAAwD;IACxD,wFAAwF;IACxF,uDAAuD;IACvD,YAAY;IAEZ,gFAAgF;IAChF,gCAAgC;IAChC,qCAAqC;IACrC,YAAY;IAEZ,2DAA2D;IAC3D,8CAA8C;IAC9C,6DAA6D;IAC7D,8CAA8C;IAC9C,oCAAoC;IACpC,qCAAqC;IACrC,4DAA4D;IAC5D,wCAAwC;IACxC,kDAAkD;IAClD,mDAAmD;IACnD,0CAA0C;IAC1C,2CAA2C;IAC3C,4CAA4C;IAE5C,oDAAoD;IACpD,iCAAiC;IACjC,8BAA8B;IAC9B,cAAc;IAEd,yCAAyC;IAEzC,iBAAiB;IACjB,qCAAqC;IACrC,yCAAyC;IACzC,2EAA2E;IAC3E,sDAAsD;IACtD,UAAU;IACV,UAAU;IACV,MAAM;IACN,MAAM;IACJ,IAAI;IACI,wBAAwB;QAChC,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;QACjD,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC,6BAA6B;QAC7D,MAAM,OAAO,GAAG,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;QACxC,MAAM,SAAS,GAAG,KAAK,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;QAE5C,IAAI,SAAS,IAAI,OAAO,EAAE;YACxB,IAAI,MAAM,EAAE;gBACV,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC,KAAK,EAAE,EAAE;oBACzC,MAAM,MAAM,GAAG,KAAK,CAAC,MAAqB,CAAC;oBAC3C,IAAI,MAAM,CAAC,OAAO,KAAK,KAAK,EAAE;wBAC5B,IAAI,CAAC,aAAa,GAAG,MAA0B,CAAC;wBAChD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC;wBAC3C,MAAM,MAAM,GAAG,MAAM,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC;wBACjD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;4BACzC,IAAI,MAAM,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,aAAa,EAAE;gCACpC,IAAI,CAAC,iBAAiB,GAAG,CAAC,CAAC;gCAC3B,MAAM;6BACP;yBACF;wBACC,IAAI,SAAS,GAAG,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC;wBACjD,IAAI,CAAC,SAAS,IAAI,SAAS,CAAC,SAAS,KAAK,iBAAiB,EAAE;4BAC3D,SAAS,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;4BAC1C,SAAS,CAAC,SAAS,GAAG,iBAAiB,CAAC;4BACxC,SAAS,CAAC,KAAK,CAAC,QAAQ,GAAG,UAAU,CAAC;4BACtC,SAAS,CAAC,KAAK,CAAC,OAAO,GAAG,cAAc,CAAC;4BACzC,IAAI,CAAC,aAAa,CAAC,UAAU,EAAE,YAAY,CAAC,SAAS,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;4BAC3E,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;yBAC3C;wBAED,MAAM,cAAc,GAAG,SAAS,CAAC,aAAa,CAAC,oBAAoB,CAAC,CAAC;wBACrE,IAAI,cAAc,EAAE;4BAClB,cAAc,CAAC,MAAM,EAAE,CAAC;yBACzB;wBAED,MAAM,MAAM,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;wBAChD,MAAM,CAAC,WAAW,GAAG,YAAY,CAAC;wBAClC,MAAM,CAAC,SAAS,GAAG,8BAA8B,CAAC;wBAClD,MAAM,CAAC,KAAK,CAAC,QAAQ,GAAG,UAAU,CAAC;wBACnC,MAAM,CAAC,KAAK,CAAC,GAAG,GAAG,KAAK,CAAC;wBACzB,MAAM,CAAC,KAAK,CAAC,IAAI,GAAG,KAAK,CAAC;wBAC1B,MAAM,CAAC,KAAK,CAAC,SAAS,GAAG,uBAAuB,CAAC;wBACjD,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC;wBAC7B,MAAM,CAAC,KAAK,CAAC,eAAe,GAAG,MAAM,CAAC;wBACtC,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,gBAAgB,CAAC;wBACvC,MAAM,CAAC,KAAK,CAAC,KAAK,GAAG,SAAS,CAAC;wBAC/B,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,SAAS,CAAC;wBAChC,MAAM,CAAC,KAAK,CAAC,UAAU,GAAG,MAAM,CAAC;wBAEjC,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE;4BACrC,CAAC,CAAC,eAAe,EAAE,CAAC;4BACpB,IAAI,CAAC,SAAS,EAAE,CAAC;wBACnB,CAAC,CAAC,CAAC;wBAEH,SAAS,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;qBAC/B;yBAAM;wBACL,IAAI,CAAC,iBAAiB,EAAE,CAAC;qBAC1B;gBACH,CAAC,CAAC,CAAC;gBAEH,0DAA0D;gBAC1D,MAAM,QAAQ,GAAG,IAAI,gBAAgB,CAAC,GAAG,EAAE;oBACzC,MAAM,OAAO,GAAG,MAAM,CAAC,gBAAgB,CAAC,oBAAoB,CAAC,CAAC;oBAC9D,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE;wBACzB,MAAM,SAAS,GAAG,MAAM,CAAC,aAAa,CAAC;wBACvC,IAAI,SAAS,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,CAAC,EAAE;4BAChD,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC,oDAAoD;4BACrE,SAAS,CAAC,MAAM,EAAE,CAAC,CAAC,yBAAyB;yBAC9C;oBACH,CAAC,CAAC,CAAC;gBACL,CAAC,CAAC,CAAC;gBAEH,gCAAgC;gBAChC,QAAQ,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;aAC9D;SACF;IACH,CAAC;IAEO,iBAAiB;QACvB,MAAM,OAAO,GAAG,QAAQ,CAAC,gBAAgB,CAAC,oBAAoB,CAAC,CAAC;QAChE,OAAO,CAAC,OAAO,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC;QAC7C,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;QAC1B,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;IAChC,CAAC;IAGC,uCAAuC;IACvC,oDAAoD;IACpD,gBAAgB;IAChB,kDAAkD;IAClD,kDAAkD;IAClD,sCAAsC;IACtC,yDAAyD;IACzD,oDAAoD;IAEpD,+CAA+C;IAC/C,2DAA2D;IAC3D,kDAAkD;IAClD,kDAAkD;IAClD,wCAAwC;IACxC,mBAAmB;IACnB,YAAY;IACZ,UAAU;IAEV,6CAA6C;IAC7C,+BAA+B;IAC/B,UAAU;IACV,eAAe;IACf,mCAAmC;IACnC,uCAAuC;IACvC,QAAQ;IACR,QAAQ;IACR,IAAI;IACJ,IAAI;IAEI,0BAA0B;QAClC,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;QACjD,IAAI,MAAM,EAAE;YACV,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC,KAAK,EAAE,EAAE;gBACzC,MAAM,MAAM,GAAG,KAAK,CAAC,MAAqB,CAAC;gBAC3C,IAAI,MAAM,CAAC,OAAO,KAAK,KAAK,EAAE;oBAC5B,IAAI,CAAC,aAAa,GAAG,MAA0B,CAAC;oBAChD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC;oBAC3C,MAAM,MAAM,GAAG,MAAM,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC;oBAClD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;wBACtC,IAAI,MAAM,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,aAAa,EAAE;4BACpC,IAAI,CAAC,iBAAiB,GAAG,CAAC,CAAC;4BAC3B,MAAM;yBACP;qBACF;iBACF;qBAAM;oBACL,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;iBAC3B;gBACD,IAAI,MAAM,CAAC,OAAO,KAAK,IAAI,IAAI,MAAM,CAAC,OAAO,KAAK,IAAI,EAAE;oBACtD,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,OAAO,CAAC,OAAO,CAAqB,CAAC;oBACjE,MAAM,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,oBAAoB,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;oBACtE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;wBACrC,IAAI,KAAK,CAAC,CAAC,CAAC,KAAK,MAAM,EAAE;4BACvB,IAAI,CAAC,iBAAiB,GAAG,CAAC,CAAC;4BAC3B,MAAM;yBACP;qBACF;iBACF;qBAAM;oBACL,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;iBAC3B;gBAED,IAAI,MAAM,CAAC,OAAO,KAAK,GAAG,IAAI,MAAM,CAAC,OAAO,KAAK,MAAM,IAAI,MAAM,CAAC,OAAO,KAAK,KAAK,EAAE;oBACnF,MAAM,UAAU,GAAG,MAAM,CAAC,oBAAoB,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;oBAC/D,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;wBAC1C,IAAI,UAAU,CAAC,CAAC,CAAC,KAAK,MAAM,EAAE;4BAC5B,IAAI,CAAC,iBAAiB,GAAG,CAAC,CAAC;4BAC3B,MAAM;yBACP;qBACF;iBACF;YACH,CAAC,CAAC,CAAC;SACJ;IACD,CAAC;IAEH,eAAe,CAAC,MAAc,EAAE,KAAa;QAC3C,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;QAEjD,IAAI,MAAM,EAAE;YACV,MAAM,CAAC,KAAK,EAAE,CAAA;YACd,MAAM,MAAM,GAAG,MAAM,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC;YAClD,IAAI,KAAK,IAAI,CAAC,EAAG;gBACf,MAAM,CAAC,KAAK,CAAC,CAAC,YAAY,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;aAC3C;SACF;IACH,CAAC;IAIS,UAAU;QAChB,0CAA0C;QAC1C,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;QAEjD,IAAI,MAAM,EAAE;YACV,MAAM,CAAC,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC;YACnC,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE,GAAG,EAAE;gBACpC,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;YACvC,CAAC,CAAC,CAAC;SACJ;QACD,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAED,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAED,gBAAgB,CAAE,UAAmB;QACnC,yCAAyC;IAC3C,CAAC;IAED,aAAa,CAAC,KAAU;QACtB,IAAI,KAAK,EAAE;YACT,MAAM,KAAK,GAAG,KAAK,CAAA;YACnB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;YACxB,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YACrB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SACnC;aAAM;YACL,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;SAC3B;IACH,CAAC;IAED,gBAAgB,CAAC,OAAe;QAC9B,MAAM,GAAG,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAC1C,GAAG,CAAC,SAAS,GAAG,OAAO,CAAC;QACxB,MAAM,MAAM,GAAG,GAAG,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;QAC3C,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;YACnB,IAAI,GAAG,CAAC,KAAK,CAAC,QAAQ,IAAI,OAAO,EAAE;gBACjC,GAAG,CAAC,KAAK,CAAC,QAAQ,GAAG,OAAO,CAAC;gBAC7B,mBAAmB;gBACnB,GAAG,CAAC,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC;aAC3B;iBAAM;gBACL,GAAG,CAAC,KAAK,CAAC,QAAQ,GAAG,MAAM,CAAC;gBAC5B,GAAG,CAAC,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC;aAC3B;QACH,CAAC,CAAC,CAAC;QACH,OAAO,GAAG,CAAC,SAAS,CAAC;IACvB,CAAC;IAED,yBAAyB;IACzB,gBAAgB;IAChB,sDAAsD;IACtD,qBAAqB;IACrB,uBAAuB;IACvB,iCAAiC;IACjC,qGAAqG;IACrG,4DAA4D;IAC5D,iDAAiD;IACjD,wBAAwB;IACxB,2BAA2B;IAC3B,kDAAkD;IAClD,YAAY;IACZ,YAAY;IACZ,QAAQ;IACR,aAAa;IACb,iCAAiC;IACjC,MAAM;IACN,IAAI;IAEN,2BAA2B;IAC3B,gBAAgB;IAChB,sDAAsD;IACtD,oBAAoB;IACpB,wDAAwD;IAExD,qCAAqC;IAErC,+DAA+D;IAC/D,4CAA4C;IAE5C,iEAAiE;IACjE,qCAAqC;IAErC,+CAA+C;IAC/C,iDAAiD;IACjD,sDAAsD;IACtD,gDAAgD;IAChD,YAAY;IACZ,YAAY;IACZ,QAAQ;IACR,aAAa;IACb,iCAAiC;IACjC,MAAM;IACN,IAAI;IAEJ,2CAA2C;IAC3C,oDAAoD;IACpD,kBAAkB;IAClB,+CAA+C;IAC/C,mGAAmG;IACnG,0DAA0D;IAC1D,MAAM;IACN,IAAI;IAEJ,uDAAuD;IACvD,kDAAkD;IAClD,+CAA+C;IAC/C,4CAA4C;IAC5C,QAAQ;IAER,uFAAuF;IACvF,IAAI;IAEJ,mEAAmE;IAC3D,kBAAkB,CAAC,MAAmB;QAC5C,MAAM,SAAS,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC;QACxC,IAAI,SAAS,IAAI,SAAS,CAAC,UAAU,GAAG,CAAC,EAAE;YACzC,MAAM,KAAK,GAAG,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;YACtC,MAAM,SAAS,GAAG,KAAK,CAAC,cAAc,CAAC;YACvC,MAAM,WAAW,GAAG,KAAK,CAAC,WAAW,CAAC;YAGtC,gGAAgG;YAChG,0DAA0D;YAC1D,IAAI,CAAC,oBAAoB,GAAG,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,EAAE,WAAW,EAAE,CAAC;SACtE;IACD,CAAC;IAED,mDAAmD;IAC7C,aAAa,CAAC,OAAe;QACnC,MAAM,SAAS,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC;QAExC,IAAI,SAAS,IAAI,SAAS,CAAC,UAAU,GAAG,CAAC,EAAE;YACzC,yCAAyC;YACzC,MAAM,KAAK,GAAG,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;YAEtC,sEAAsE;YACtE,MAAM,QAAQ,GAAG,QAAQ,CAAC,sBAAsB,EAAE,CAAC;YACnD,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YAC9C,OAAO,CAAC,SAAS,GAAG,OAAO,CAAC;YAE5B,gEAAgE;YAChE,OAAO,OAAO,CAAC,UAAU,EAAE;gBACzB,QAAQ,CAAC,WAAW,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;aAC1C;YAED,4CAA4C;YAC5C,KAAK,CAAC,cAAc,EAAE,CAAC,CAAC,4CAA4C;YACpE,KAAK,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;YAE3B,4CAA4C;YAC5C,MAAM,SAAS,GAAG,QAAQ,CAAC,SAAS,CAAC;YAErC,IAAI,SAAS,EAAE;gBACb,KAAK,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;gBAC/B,KAAK,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;gBAC7B,SAAS,CAAC,eAAe,EAAE,CAAC;gBAC5B,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;aAC3B;YACD,IAAI,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;YAC/C,IAAI,MAAM,EAAE;gBACV,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAA;aAC5B;YAED,IAAI,CAAC,iBAAiB,CAAC,IAAI,EAAE,CAAA;SAC9B;IACH,CAAC;IAGD,mDAAmD;IACnD,kDAAkD;IAClD,+CAA+C;IAC/C,4CAA4C;IAE5C,8BAA8B;IAC9B,0CAA0C;IAC1C,sDAAsD;IACtD,sCAAsC;IACtC,oCAAoC;IAEpC,QAAQ;IACR,MAAM;IAKJ,SAAS,CAAC,IAAS;QACnB,IAAI,IAAI,EAAE;YACR,IAAI,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;YAC/C,IAAI,MAAM,EAAE;gBACV,+CAA+C;gBAC/C,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;gBAE5B,sDAAsD;gBACtD,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC;gBAEnC,wDAAwD;gBACxD,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;gBAC5B,uCAAuC;gBACvC,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE,GAAG,EAAE;oBACpC,IAAI,MAAM,EAAE,EAAG,4BAA4B;wBACzC,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC;qBACjC;gBACH,CAAC,CAAC,CAAC;aACJ;SACF;aAAM;YACL,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;SAC3B;IACH,CAAC;IAGO,gBAAgB,CAAC,IAAY;QACnC,IAAI,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;QAC/C,IAAI,MAAM,EAAE;YACV,wCAAwC;YACxC,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,SAAS,CAAC,uBAAuB,CAAC,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC;YAC5F,MAAM,CAAC,SAAS,GAAG,IAAI,CAAC,gBAA0B,CAAC;SACpD;IACH,CAAC;IAEO,qBAAqB,CAAC,MAAmB;QAC/C,MAAM,QAAQ,GAAG,IAAI,gBAAgB,CAAC,GAAG,EAAE;YACzC,kDAAkD;YAClD,+BAA+B;YAC/B,wCAAwC;YACxC,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QACvC,CAAC,CAAC,CAAC;QAEH,QAAQ,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC,CAAC;IACpF,CAAC;IAEO,cAAc,CAAC,MAAmB;QACxC,MAAM,SAAS,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC;QACxC,MAAM,KAAK,GAAG,QAAQ,CAAC,WAAW,EAAE,CAAC;QAErC,IAAI,MAAM,CAAC,SAAS,EAAE;YACpB,KAAK,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC;YACjC,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,sBAAsB;YAC7C,SAAS,EAAE,eAAe,EAAE,CAAC;YAC7B,SAAS,EAAE,QAAQ,CAAC,KAAK,CAAC,CAAC;SAC5B;IACH,CAAC;IAED,2BAA2B;IAC3B,gBAAgB;IAChB,sDAAsD;IACtD,oBAAoB;IACpB,wBAAwB;IACxB,iCAAiC;IAEjC,iDAAiD;IACjD,qGAAqG;IACrG,4DAA4D;IAE5D,qDAAqD;IACrD,8CAA8C;IAC9C,iDAAiD;IAEjD,gCAAgC;IAChC,8DAA8D;IAC9D,4CAA4C;IAC5C,wDAAwD;IACxD,wCAAwC;IACxC,sCAAsC;IACtC,UAAU;IAEV,iDAAiD;IACjD,wBAAwB;IACxB,kDAAkD;IAElD,8EAA8E;IAC9E,kDAAkD;IAClD,qDAAqD;IAErD,oCAAoC;IACpC,gDAAgD;IAChD,4DAA4D;IAC5D,4CAA4C;IAC5C,0CAA0C;IAC1C,cAAc;IACd,YAAY;IACZ,YAAY;IACZ,QAAQ;IACR,aAAa;IACb,iCAAiC;IACjC,MAAM;IACN,IAAI;IAEF,MAAM,CAAC,OAAe,EAAE,KAAW;QACjC,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;QACjD,IAAI,MAAM,EAAE;YACV,MAAM,CAAC,KAAK,EAAE,CAAC;YACf,IAAI,OAAO,KAAK,WAAW,EAAE;gBAC3B,IAAI,CAAC,iBAAiB,GAAG,CAAC,IAAI,CAAC,iBAAiB,CAAC;gBACjD,QAAQ,CAAC,WAAW,CAAC,WAAW,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;aAC9C;iBAAM,IAAI,OAAO,KAAK,aAAa,EAAE;gBACpC,IAAI,CAAC,mBAAmB,GAAG,CAAC,IAAI,CAAC,mBAAmB,CAAC;gBACrD,QAAQ,CAAC,WAAW,CAAC,aAAa,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;gBAAA,CAAC;aACjD;iBAAM;gBACL,QAAQ,CAAC,WAAW,CAAC,OAAO,EAAE,KAAK,EAAE,KAAK,IAAI,EAAE,CAAC,CAAC;gBAClD,IAAI,KAAK,EAAE;oBACT,MAAM,GAAG,GAAG,KAAK,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC,CAAA;oBACpD,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC;iBACxD;aACF;SACF;QACA,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC3B,CAAC;IAED,iBAAiB;QACf,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC;QACvD,IAAI,CAAC,cAAc,GAAG,QAAQ,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAC;QAC3D,IAAI,CAAC,iBAAiB,GAAG,QAAQ,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;QACjE,IAAI,CAAC,qBAAqB,GAAG,QAAQ,CAAC,iBAAiB,CAAC,eAAe,CAAC,CAAC;QACzE,IAAI,CAAC,iBAAiB,GAAG,QAAQ,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;QACjE,IAAI,CAAC,mBAAmB,GAAG,QAAQ,CAAC,iBAAiB,CAAC,aAAa,CAAC,CAAC;IACvE,CAAC;IAED,gBAAgB;QACd,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;QACjD,IAAI,MAAM,EAAE;YACV,MAAM,WAAW,GAAG,QAAQ,CAAC,iBAAiB,CAAC,aAAa,CAAC,CAAC;YAC9D,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;YAC/D,yDAAyD;SAC1D;IACH,CAAC;IAED,iBAAiB,CAAC,IAAY;QAC5B,QAAQ,IAAI,EAAE;YACZ,KAAK,IAAI;gBACP,OAAO,WAAW,CAAC;gBACnB,MAAM;YACR,KAAK,IAAI;gBACP,OAAO,WAAW,CAAC;gBACnB,MAAM;YACR,KAAK,IAAI;gBACP,OAAO,WAAW,CAAC;gBACnB,MAAM;YACR,KAAK,IAAI;gBACP,OAAO,WAAW,CAAC;gBACnB,MAAM;YACR,KAAK,IAAI;gBACP,OAAO,WAAW,CAAC;gBACnB,MAAM;YACR,KAAK,IAAI;gBACP,OAAO,WAAW,CAAC;gBACnB,MAAM;YACR,KAAK,GAAG;gBACN,OAAO,QAAQ,CAAC;gBAChB,MAAM;YACR;gBACE,OAAO,QAAQ,CAAC;gBAChB,MAAM;SACT;IACH,CAAC;IAED,UAAU,CAAC,KAAU;QACnB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAC1B,QAAQ,CAAC,WAAW,CAAC,UAAU,EAAE,KAAK,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;IAC7D,CAAC;IAED,eAAe;QACb,MAAM,IAAI,GAAG;;;;;;;;;;;;;;KAcZ,CAAC;QACF,QAAQ,CAAC,WAAW,CAAC,YAAY,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;IAClD,CAAC;IAED,+BAA+B;IAC/B,kDAAkD;IAClD,oDAAoD;IACpD,kBAAkB;IAClB,8DAA8D;IAC9D,sDAAsD;IACtD,2CAA2C;IAC3C,mDAAmD;IACnD,yEAAyE;IACzE,UAAU;IACV,QAAQ;IACR,MAAM;IACN,IAAI;IACJ,cAAc,CAAC,KAAU;QACvB,MAAM,YAAY,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC;QAE3C,IAAI,YAAY,IAAI,YAAY,CAAC,UAAU,GAAG,CAAC,EAAE;YAC7C,MAAM,KAAK,GAAG,YAAY,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;YACzC,MAAM,IAAI,GAAG,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;YAC5C,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;YACnD,KAAK,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;SAChC;IACH,CAAC;IAED,OAAO;QACL,IAAI,GAAG,GAAG,MAAM,CAAC,uBAAuB,EAAE,SAAS,CAAC,CAAC;QACrD,IAAI,GAAG,EAAE;YACP,QAAQ,CAAC,WAAW,CAAC,YAAY,EAAE,KAAK,EAAE,GAAG,CAAC,CAAC;SAChD;IACH,CAAC;IAED,YAAY;QACV,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;QACjD,IAAI,MAAM,EAAE;YACV,MAAM,CAAC,KAAK,EAAE,CAAC;YACf,IAAI,UAAU,GAAG,QAAQ,CAAC,cAAc,CAAC,YAAY,CAAqB,CAAC;YAC3E,IAAI,UAAU,EAAE;gBACd,UAAU,CAAC,KAAK,EAAE,CAAC;aACpB;SACF;IACH,CAAC;IAED,kCAAkC;IAClC,wCAAwC;IACxC,gBAAgB;IAChB,uCAAuC;IACvC,oCAAoC;IACpC,iCAAiC;IACjC,mCAAmC;IACnC,6BAA6B;IAC7B,oEAAoE;IACpE,oEAAoE;IACpE,8CAA8C;IAC9C,8DAA8D;IAC9D,WAAW;IACX,SAAS;IACT,kCAAkC;IAClC,MAAM;IACN,IAAI;IAEJ,iBAAiB,CAAC,KAAU;QAC5B,MAAM,IAAI,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACnC,MAAM,aAAa,GAAG,QAAQ,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,CAAC,0BAA0B;QAEnF,IAAI,IAAI,IAAI,aAAa,EAAE;YACzB,MAAM,WAAW,GAAG,aAAa,CAAC,WAAW,CAAC,CAAC,yBAAyB;YACxE,MAAM,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;YAEhC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAM,EAAE,EAAE;gBACzB,MAAM,GAAG,GAAG,IAAI,KAAK,EAAE,CAAC;gBACxB,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC;gBAE1B,GAAG,CAAC,MAAM,GAAG,GAAG,EAAE;oBAChB,MAAM,QAAQ,GAAG,GAAG,CAAC,KAAK,CAAC;oBAE3B,sEAAsE;oBACtE,MAAM,OAAO,GACX,QAAQ,GAAG,WAAW;wBACpB,CAAC,CAAC,aAAa,GAAG,CAAC,GAAG,wBAAwB,GAAG,qBAAqB;wBACtE,CAAC,CAAC,aAAa,GAAG,CAAC,GAAG,mBAAmB,QAAQ,qBAAqB,CAAC;oBAC3E,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAA;oBACzB,mCAAmC;oBACnC,QAAQ,CAAC,WAAW,CAAC,YAAY,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC;gBACrD,CAAC,CAAC;YACJ,CAAC,CAAC;YAEF,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;SAC5B;IACH,CAAC;IAIC,eAAe;IACf,qDAAqD;IACrD,yCAAyC;IACzC,qFAAqF;IAErF,iEAAiE;IACjE,oDAAoD;IACpD,wBAAwB;IACxB,uCAAuC;IACvC,8IAA8I;IAC9I,QAAQ;IACR,wBAAwB;IACxB,MAAM;IACN,iCAAiC;IACjC,2DAA2D;IAC3D,wDAAwD;IACxD,kBAAkB;IAClB,sBAAsB;IACtB,wDAAwD;IACxD,MAAM;IACN,4BAA4B;IAC5B,gCAAgC;IAChC,IAAI;IAGJ,YAAY,CAAC,KAAU;QACrB,IAAI,KAAK,CAAC,GAAG,KAAK,KAAK,EAAE;YACvB,KAAK,CAAC,cAAc,EAAE,CAAC,CAAC,gCAAgC;YACxD,MAAM,SAAS,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC;YACxC,IAAI,CAAC,SAAS,IAAI,SAAS,CAAC,UAAU,KAAK,CAAC;gBAAE,OAAO;YAErD,MAAM,KAAK,GAAG,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;YACtC,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,CAAC,0CAA0C;YAC1F,OAAO,CAAC,SAAS,GAAG,0BAA0B,CAAC,CAAC,wCAAwC;YAExF,KAAK,CAAC,cAAc,EAAE,CAAC,CAAC,2BAA2B;YACnD,KAAK,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,+BAA+B;YAC1D,KAAK,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,CAAC,sCAAsC;YACpE,KAAK,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;YAC3B,SAAS,CAAC,eAAe,EAAE,CAAC;YAC5B,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;SAC3B;IACH,CAAC;IAEH,iBAAiB;IACjB,qDAAqD;IACrD,yCAAyC;IACzC,qFAAqF;IAErF,iEAAiE;IACjE,oDAAoD;IACpD,yHAAyH;IACzH,uCAAuC;IACvC,6IAA6I;IAC7I,QAAQ;IACR,wBAAwB;IACxB,MAAM;IACN,8BAA8B;IAE9B,sDAAsD;IACtD,kBAAkB;IAClB,sBAAsB;IACtB,wDAAwD;IACxD,MAAM;IAEN,4BAA4B;IAC5B,gCAAgC;IAChC,IAAI;IACJ,eAAe;IACf,4BAA4B;IAC5B,oBAAoB;IACpB,4CAA4C;IAE5C,6GAA6G;IAE7G,wBAAwB;IACxB,4IAA4I;IAC5I,qCAAqC;IACrC,yCAAyC;IACzC,qDAAqD;IACrD,2CAA2C;IAC3C,2CAA2C;IAC3C,+CAA+C;IAC/C,+CAA+C;IAC/C,6CAA6C;IAC7C,sDAAsD;IACtD,8DAA8D;IAC9D,2DAA2D;IAC3D,uDAAuD;IACvD,oDAAoD;IACpD,wBAAwB;IACxB,MAAM;IACN,sBAAsB;IAEtB,kCAAkC;IAClC,yFAAyF;IACzF,uCAAuC;IACvC,qDAAqD;IACrD,kDAAkD;IAClD,gDAAgD;IAChD,wDAAwD;IACxD,0DAA0D;IAC1D,sEAAsE;IACtE,QAAQ;IACR,wBAAwB;IACxB,MAAM;IACN,sCAAsC;IAEtC,sDAAsD;IACtD,kBAAkB;IAClB,sBAAsB;IACtB,wDAAwD;IACxD,MAAM;IAEN,4BAA4B;IAC5B,gCAAgC;IAEhC,sDAAsD;IACtD,mDAAmD;IACnD,wBAAwB;IACxB,mBAAmB;IACnB,sCAAsC;IACtC,4CAA4C;IAC5C,MAAM;IACN,sBAAsB;IACtB,qCAAqC;IACrC,MAAM;IACN,sBAAsB;IACtB,sCAAsC;IACtC,mCAAmC;IACnC,MAAM;IACN,gCAAgC;IAChC,mCAAmC;IACnC,MAAM;IACN,uCAAuC;IACvC,kCAAkC;IAClC,mCAAmC;IACnC,MAAM;IACN,sCAAsC;IACtC,kCAAkC;IAClC,MAAM;IACN,KAAK;IACL,sCAAsC;IACtC,IAAI;IAEJ,QAAQ;QACN,MAAM,UAAU,GAAG,GAAG,CAAC;QACvB,MAAM,IAAI,GAAG,CAAC,CAAC;QACf,MAAM,YAAY,GAAG,UAAU,GAAG,IAAI,CAAC;QAEvC,IAAI,KAAK,GAAG,+CAA+C,UAAU,kCAAkC,CAAC;QACxG,KAAK,IAAI,SAAS,CAAC;QAEnB,mBAAmB;QACnB,KAAK,IAAI,iDAAiD,IAAI,CAAC,gCAAgC,EAAE,qCAAqC,CAAC;QAEvI,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,EAAE,EAAE;YAC7B,KAAK,IAAI;;;;;;;kCAOqB,YAAY;;;;yCAIL,CAAC;SACvC;QAED,kCAAkC;QAClC,KAAK,IAAI,OAAO,CAAC;QAEjB,YAAY;QACZ,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;YAC1B,KAAK,IAAI,6BAA6B,IAAI,CAAC,gCAAgC,EAAE,IAAI,CAAC;YAClF,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,EAAE,EAAE;gBAC7B,KAAK,IAAI;;;qCAGsB,YAAY;;kEAEiB,CAAC;aAC9D;YACD,KAAK,IAAI,OAAO,CAAC;SAClB;QAED,KAAK,IAAI,uBAAuB,CAAC;QAEjC,4BAA4B;QAC5B,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;QACjD,IAAI,MAAM,EAAE;YACV,MAAM,CAAC,KAAK,EAAE,CAAC;YACf,QAAQ,CAAC,WAAW,CAAC,YAAY,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;SAClD;QAED,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QACvB,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAE3B,iDAAiD;QACjD,MAAM,KAAK,GAAG,QAAQ,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;QAC9C,KAAK,CAAC,SAAS,GAAG;;;;;;;;;;;;;;;;;;;;;;CAsBnB,CAAC;QACA,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;IACnC,CAAC;IAGD,4DAA4D;IAC5D,eAAe,CAAC,KAAU;QACxB,MAAM,aAAa,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC;QAEzC,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,MAAM,SAAS,GAAG,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,IAAI,CAAgB,CAAC;YAExE,IAAI,SAAS,EAAE;gBACb,MAAM,WAAW,GAAG,SAAS,CAAC,gBAAgB,CAAC,cAAc,CAAC,CAAC;gBAC/D,WAAW,CAAC,OAAO,CAAC,CAAC,IAAa,EAAE,EAAE;oBACnC,IAAoB,CAAC,KAAK,CAAC,eAAe,GAAG,aAAa,CAAC;gBAC9D,CAAC,CAAC,CAAC;aACJ;SACF;IACH,CAAC;IAIC,mBAAmB,CAAC,KAAkB;QACpC,IAAI,MAAM,GAAG,KAAK,EAAE,MAAqB,CAAC;QAC1C,IAAI,MAAM,IAAI,CAAC,MAAM,CAAC,OAAO,KAAK,IAAI,IAAI,MAAM,CAAC,OAAO,KAAK,IAAI,CAAC,EAAE;YAClE,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;YAC5B,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,OAAO,CAAC,OAAO,CAAqB,CAAC;SAClE;aAAM;YACL,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;YAC7B,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;SAC3B;QAED,2BAA2B;IAC7B,CAAC;IAED,gBAAgB;QACd,kDAAkD;QAClD,gBAAgB;QAChB,wFAAwF;QACxF,qCAAqC;QACrC,qIAAqI;QACrI,aAAa;QACb,8DAA8D;QAC9D,yBAAyB;QACzB,yCAAyC;QACzC,QAAQ;QACR,MAAM;QACN,IAAI;IACN,CAAC;IAED,OAAO;QACL,kDAAkD;QAClD,6CAA6C;QAC7C,2BAA2B;QAC3B,uCAAuC;QACvC,IAAI;IACN,CAAC;IAED,kCAAkC;IAClC,2BAA2B;IAC3B,IAAI;IAEJ,MAAM;QACJ,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC1B,CAAC;IAED,aAAa;IACb,8BAA8B;IAC9B,gDAAgD;IAChD,0EAA0E;IAC1E,sCAAsC;IACtC,mCAAmC;IACnC,+CAA+C;IAC/C,QAAQ;IACR,MAAM;IACN,IAAI;IAEJ,MAAM;QACN,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,GAAG,GAAG,IAAI,CAAC,aAAa,CAAC,SAAS,EAAE,CAAC;YAEzC,6EAA6E;YAC7E,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBAChE,IAAI,IAAI,GAAG,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;gBAC7B,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;gBAE1B,iCAAiC;gBACjC,IAAI,CAAC,KAAK,CAAC,YAAY,GAAG,aAAa,IAAI,CAAC,qCAAqC,EAAE,EAAE,CAAC,CAAC,gDAAgD;aACxI;SACF;IACH,CAAC;IAED,eAAe;IACf,8BAA8B;IAC9B,gDAAgD;IAChD,wGAAwG;IACxG,0EAA0E;IAC1E,sCAAsC;IACtC,mCAAmC;IACnC,QAAQ;IACR,MAAM;IACN,IAAI;IAGF,gBAAgB;IAChB,8BAA8B;IAC9B,wCAAwC;IACxC,MAAM;IACN,IAAI;IAEN,kBAAkB;IAClB,8BAA8B;IAC9B,0DAA0D;IAC1D,iCAAiC;IACjC,+CAA+C;IAC/C,yBAAyB;IACzB,wEAAwE;IACxE,qBAAqB;IACrB,qCAAqC;IACrC,YAAY;IACZ,UAAU;IACV,QAAQ;IACR,8CAA8C;IAC9C,MAAM;IACN,IAAI;IAEF,SAAS;QACT,MAAM,SAAS,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC;QACtC,IAAI,SAAS,EAAE;YACf,IAAI,CAAC,SAAS,CAAC,UAAU;gBAAE,OAAO;YAElC,MAAM,KAAK,GAAG,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;YACtC,MAAM,YAAY,GAAG,KAAK,CAAC,cAAc,CAAC;YAC1C,MAAM,GAAG,GAAG,YAAY,CAAC,aAAa,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC;YAEtD,IAAI,GAAG,EAAE;gBACP,MAAM,KAAK,GAAG,GAAG,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;gBACnC,IAAI,KAAK,EAAE;oBACT,KAAK,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;iBAC/B;aACF;SACF;IACH,CAAC;IAGC,gBAAgB;IAChB,8BAA8B;IAC9B,iEAAiE;IACjE,8DAA8D;IAC9D,mCAAmC;IACnC,+CAA+C;IAC/C,QAAQ;IACR,MAAM;IACN,IAAI;IAEN,kBAAkB;IAClB,8BAA8B;IAC9B,2FAA2F;IAC3F,yDAAyD;IACzD,iDAAiD;IAEjD,iEAAiE;IACjE,8DAA8D;IAC9D,mCAAmC;IACnC,+CAA+C;IAC/C,+CAA+C;IAC/C,4CAA4C;IAC5C,4CAA4C;IAC5C,0CAA0C;IAC1C,QAAQ;IAER,yCAAyC;IACzC,iEAAiE;IACjE,4EAA4E;IAC5E,gFAAgF;IAChF,UAAU;IACV,QAAQ;IACR,MAAM;IACJ,IAAI;IAEJ,gBAAgB;IAChB,4BAA4B;IAC5B,yFAAyF;IACzF,uDAAuD;IACvD,+CAA+C;IAE/C,+DAA+D;IAC/D,4DAA4D;IAC5D,iCAAiC;IACjC,0CAA0C;IAC1C,0CAA0C;IAC1C,wCAAwC;IACxC,6CAA6C;IAC7C,4FAA4F;IAC5F,MAAM;IAEN,2CAA2C;IAC3C,+DAA+D;IAC/D,+FAA+F;IAC/F,MAAM;IACN,IAAI;IACJ,IAAI;IAEJ,SAAS;QACP,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,MAAM,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,mBAAmB;YACpF,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC;YAClD,MAAM,QAAQ,GAAG,UAAU,GAAG,WAAW,CAAC;YAE1C,iDAAiD;YACjD,MAAM,eAAe,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC;iBAC/C,KAAK,CAAC,CAAC,CAAgB,CAAC;YAC3B,MAAM,aAAa,GAAG,eAAe;gBACnC,CAAC,CAAC,eAAe,CAAC,KAAK,CAAC,eAAe;gBACvC,CAAC,CAAC,EAAE,CAAC;YAEP,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBACvD,IAAI,IAAI,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;gBACrD,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;gBAC1B,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,YAAY,CAAC;gBACnC,IAAI,CAAC,KAAK,CAAC,SAAS,GAAG,WAAW,CAAC;gBACnC,IAAI,CAAC,KAAK,CAAC,UAAU,GAAG,QAAQ,CAAC;gBACjC,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,GAAG,QAAQ,IAAI,CAAC;gBACtC,IAAI,CAAC,KAAK,CAAC,YAAY,GAAG,mBAAmB,CAAC;gBAE9C,yFAAyF;gBAEzF,+CAA+C;gBAC/C,IAAI,CAAC,KAAK,CAAC,EAAE;oBACX,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;oBAClC,IAAI,CAAC,KAAK,CAAC,UAAU,GAAG,MAAM,CAAC;oBAC/B,IAAI,CAAC,KAAK,CAAC,SAAS,GAAG,OAAO,CAAC;oBAC/B,IAAI,CAAC,KAAK,CAAC,aAAa,GAAG,MAAM,CAAC;oBAClC,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,YAAY,CAAC;oBAClC,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,QAAQ,CAAC;oBAC/B,IAAI,CAAC,KAAK,CAAC,SAAS,GAAG,iBAAiB,CAAC;oBACzC,4CAA4C;oBAE5C,sDAAsD;oBACtD,IAAI,aAAa,EAAE;wBACjB,IAAI,CAAC,KAAK,CAAC,eAAe,GAAG,aAAa,CAAC;qBAC5C;iBACF;aACF;YAED,sCAAsC;YACtC,6DAA6D;YAC7D,oDAAoD;YACpD,+CAA+C;YAC/C,IAAI;YACJ,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBACvD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;oBAChE,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,YAAY,GAAG,mBAAmB,CAAC;iBAC9E;aACF;SACF;IACH,CAAC;IAMD,YAAY;QACZ,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,MAAM,CAAC,YAAY,EAAE;gBACvB,IAAI,SAAS,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC;gBACtC,IAAI,SAAS,EAAE;oBACb,IAAI,IAAI,GAAG,SAAS,CAAC,UAAU,EAAE,aAAa,EAAE,OAAO,CAAC,QAAQ,CAAyB,CAAC;oBAC1F,IAAI,IAAI,EAAE;wBACR,IAAI,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC;wBAC/B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;4BACvD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;yBAClD;qBACF;iBACF;aACF;SACF;IACH,CAAC;IAEC,gCAAgC;QAC9B,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,mBAAmB,CAAC,CAAA;QAC/D,IAAI,OAAO,IAAI,MAAM,EAAE;YACrB,OAAO,8BAA8B,CAAA;SACtC;aAAM;YACL,OAAO,8BAA8B,CAAA;SACtC;IACH,CAAC;IAED,qCAAqC;QACnC,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,mBAAmB,CAAC,CAAA;QAC/D,IAAI,OAAO,IAAI,MAAM,EAAE;YACrB,OAAO,SAAS,CAAA;SACjB;aAAM;YACL,OAAO,SAAS,CAAA;SACjB;IACH,CAAC;IAED,gBAAgB,CAAC,KAAU;QACzB,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC;SAC5D;IACH,CAAC;IAED,eAAe,CAAC,KAAU;QACxB,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBACvD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;oBAChE,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC;iBAC7E;aACF;SACF;IACH,CAAC;IAED,gBAAgB,CAAC,KAAU;QACzB,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBACvD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;oBAChE,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,GAAG,IAAI,CAAC;iBAC9E;aACF;SACF;IACH,CAAC;IAEO,aAAa,CAAC,OAAoB;QACxC,MAAM,KAAK,GAAG,QAAQ,CAAC,WAAW,EAAE,CAAC;QACrC,MAAM,GAAG,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC;QAChC,IAAI,GAAG,EAAE;YACT,KAAK,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC;YACpC,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YACtB,GAAG,CAAC,eAAe,EAAE,CAAC;YACtB,GAAG,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;SACnB;IACH,CAAC;IA+BH,eAAe,CAAC,OAAe;QAC7B,MAAM,YAAY,GAAG,QAAQ,CAAC,cAAc,CAAC,OAAO,CAAqB,CAAC;QAC1E,IAAI,YAAY,EAAE;YAChB,6BAA6B;YAC7B,MAAM,SAAS,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC;YACxC,IAAI,SAAS,IAAI,SAAS,CAAC,UAAU,GAAG,CAAC,EAAE;gBACzC,IAAI,CAAC,cAAc,GAAG,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;aAC/C;YACD,YAAY,CAAC,KAAK,EAAE,CAAC;SACtB;IACH,CAAC;IAED,6BAA6B;IAC7B,+BAA+B;IAC/B,wCAAwC;IACxC,sCAAsC;IAEtC,qCAAqC;IACrC,+CAA+C;IAC/C,uBAAuB;IACvB,qCAAqC;IACrC,iDAAiD;IAEjD,wCAAwC;IACxC,2CAA2C;IAC3C,qDAAqD;IACrD,kCAAkC;IAClC,6CAA6C;IAE7C,0DAA0D;IAC1D,gCAAgC;IAChC,gCAAgC;IAEhC,qCAAqC;IACrC,oCAAoC;IACpC,QAAQ;IACR,MAAM;IACJ,IAAI;IACN,+BAA+B;IAC/B,+BAA+B;IAC/B,wCAAwC;IACxC,sCAAsC;IAEtC,qCAAqC;IACrC,+CAA+C;IAC/C,mDAAmD;IACnD,2CAA2C;IAC3C,qCAAqC;IACrC,mCAAmC;IAEnC,iCAAiC;IACjC,uDAAuD;IACvD,mIAAmI;IAEnI,mEAAmE;IACnE,mCAAmC;IACnC,kCAAkC;IAClC,YAAY;IAEZ,2EAA2E;IAC3E,mEAAmE;IACnE,qFAAqF;IACrF,wEAAwE;IACxE,0BAA0B;IAC1B,0CAA0C;IAC1C,cAAc;IACd,YAAY;IACZ,YAAY;IAEZ,oCAAoC;IACpC,gCAAgC;IAChC,2CAA2C;IAE3C,iCAAiC;IACjC,oCAAoC;IACpC,QAAQ;IACR,MAAM;IACN,IAAI;IAEJ,YAAY,CAAC,KAAU;QACrB,OAAO,CAAC,GAAG,CAAC,sBAAsB,CAAC,CAAC;QACpC,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE;YACxB,OAAO,CAAC,IAAI,CAAC,+BAA+B,CAAC,CAAC;YAC9C,OAAO;SACR;QAED,MAAM,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC;QACjC,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QAC/B,MAAM,SAAS,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC;QAExC,IAAI,CAAC,SAAS,IAAI,SAAS,CAAC,UAAU,KAAK,CAAC,EAAE;YAC5C,OAAO,CAAC,KAAK,CAAC,2BAA2B,CAAC,CAAC;YAC3C,OAAO;SACR;QAED,SAAS,CAAC,eAAe,EAAE,CAAC;QAC5B,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QACxC,MAAM,KAAK,GAAG,IAAI,CAAC,cAAc,CAAC;QAElC,MAAM,YAAY,GAAG,CAAC,IAAiB,EAAsB,EAAE;YAC7D,IAAI,WAAW,GAAG,IAAI,CAAC;YACvB,IAAI,WAAW,IAAI,WAAW,CAAC,QAAQ,KAAK,IAAI,CAAC,SAAS,EAAE;gBAC1D,WAAW,GAAG,WAAW,CAAC,UAAU,CAAC;aACtC;YAED,OAAO,WAAW,IAAI,WAAW,YAAY,WAAW,EAAE;gBACxD,IAAI,WAAW,CAAC,OAAO,KAAK,IAAI,IAAI,WAAW,CAAC,OAAO,KAAK,IAAI,EAAE;oBAChE,OAAO,WAAW,CAAC;iBACpB;gBACD,WAAW,GAAG,WAAW,CAAC,aAAa,CAAC;aACzC;YACD,OAAO,IAAI,CAAC;QACd,CAAC,CAAC;QAEF,MAAM,SAAS,GACb,YAAY,CAAC,KAAK,CAAC,uBAAuB,CAAC;YAC3C,YAAY,CAAC,KAAK,CAAC,cAAc,CAAC;YAClC,YAAY,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;QAEnC,IAAI,SAAS,EAAE;YACb,OAAO,CAAC,GAAG,CAAC,cAAc,SAAS,CAAC,OAAO,UAAU,CAAC,CAAC;YACvD,MAAM,YAAY,GAAG,SAAS,CAAC,QAAQ,EAAE,CAAC;YAE1C,IAAI,YAAY,EAAE;gBAChB,OAAO,CAAC,GAAG,CAAC,oBAAoB,SAAS,CAAC,OAAO,GAAG,EAAE,YAAY,CAAC,CAAC;gBACpE,MAAM,SAAS,GAAW,EAAE,CAAC;gBAC7B,MAAM,MAAM,GAAG,QAAQ,CAAC,gBAAgB,CACtC,SAAS,EACT,UAAU,CAAC,SAAS,EACpB,IAAI,CACL,CAAC;gBACF,IAAI,IAAiB,CAAC;gBAEtB,OAAO,CAAC,IAAI,GAAG,MAAM,CAAC,QAAQ,EAAiB,CAAC,EAAE;oBAChD,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;iBACtB;gBAED,KAAK,MAAM,QAAQ,IAAI,SAAS,EAAE;oBAChC,MAAM,IAAI,GAAG,QAAQ,CAAC,WAAW,IAAI,EAAE,CAAC;oBACxC,MAAM,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;oBAEzC,IAAI,KAAK,KAAK,CAAC,CAAC,EAAE;wBAChB,OAAO,CAAC,GAAG,CACT,0BAA0B,SAAS,CAAC,OAAO,YAAY,CACxD,CAAC;wBAEF,MAAM,IAAI,GAAG,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;wBAC5C,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,KAAK,CAAC;wBACzB,IAAI,CAAC,WAAW,GAAG,YAAY,CAAC;wBAEhC,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC;wBACxC,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,YAAY,CAAC,MAAM,CAAC,CAAC;wBAE1D,MAAM,QAAQ,GAAG,QAAQ,CAAC,sBAAsB,EAAE,CAAC;wBACnD,IAAI,UAAU;4BACZ,QAAQ,CAAC,WAAW,CAAC,QAAQ,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC,CAAC;wBAC5D,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;wBAC3B,IAAI,SAAS;4BACX,QAAQ,CAAC,WAAW,CAAC,QAAQ,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC,CAAC;wBAE3D,QAAQ,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;wBAC/B,MAAM,CAAC,gCAAgC;qBACxC;iBACF;aACF;SACF;aAAM;YACL,OAAO,CAAC,GAAG,CAAC,wCAAwC,CAAC,CAAC;YACtD,OAAO;SACR;QAED,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;IAC7B,CAAC;IAEC,kBAAkB,CAAC,KAAU;QAC7B,IAAI,IAAI,CAAC,cAAc,EAAE;YACvB,MAAM,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC;YACjC,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;YAE7B,8BAA8B;YAC9B,MAAM,SAAS,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC;YACxC,IAAI,SAAS,EAAE;gBACb,SAAS,CAAC,eAAe,EAAE,CAAC;gBAC5B,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;gBAExC,0CAA0C;gBAC1C,MAAM,KAAK,GAAG,IAAI,CAAC,cAAc,CAAC;gBAClC,MAAM,IAAI,GAAG,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;gBAC5C,IAAI,CAAC,KAAK,CAAC,eAAe,GAAG,KAAK,CAAC;gBACnC,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC,QAAQ,EAAE,CAAC;gBAEpC,iDAAiD;gBACjD,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;gBAEvB,4BAA4B;gBAC5B,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;aAC5B;SACF;IACD,CAAC;IAED,6BAA6B;IAC7B,mCAAmC;IACnC,IAAI;IAEG,QAAQ,CAAC,KAAU,EAAE,OAAY;QACtC,MAAM,KAAK,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAA;QACxB,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAA;QAC9B,QAAQ,CAAC,WAAW,CAAC,WAAW,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;QAChD,6DAA6D;IAC/D,CAAC;IAGD,SAAS;QACP,IAAI,IAAI,CAAA;QACR,QAAQ,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE;YAC5B,KAAK,iBAAiB;gBACpB,IAAI,GAAG,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,YAAY,EAAE,KAAK,EAAE,IAAI,CAAC,iBAAiB,EAAE,EAAE,EAAE,IAAI,CAAC,UAAU,CAAC,EAAE,EAAE,CAAC;gBACpG,MAAM,cAAc,GAAW,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;gBAC3E,cAAc,CAAC,OAAO,CAAC,mBAAmB,EAAE,cAAc,CAAC,CAAC;gBAC5D,MAAM,eAAe,GAAG,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC;gBACxE,cAAc,CAAC,OAAO,CAAC,YAAY,EAAE,eAAe,CAAC,CAAC;gBACtD,yBAAyB;gBACzB,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;gBAC/B,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAA;gBACrB,MAAM;YACR,KAAK,iBAAiB;gBACpB,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAA;gBACrB,IAAI,GAAG,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,gBAAgB,EAAE,KAAK,EAAE,IAAI,CAAC,iBAAiB,EAAE,EAAE,EAAE,IAAI,CAAC,UAAU,CAAC,EAAE,EAAE,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,eAAe,EAAE,IAAI,CAAC,UAAU,CAAC,eAAe,EAAE,CAAC;gBAC5L,wBAAwB;gBACxB,MAAM,eAAe,GAAG,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;gBACpE,MAAM,eAAe,GAAG,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;gBAElD,cAAc,CAAC,OAAO,CAAC,oBAAoB,EAAE,eAAe,CAAC,CAAC;gBAC9D,cAAc,CAAC,OAAO,CAAC,aAAa,EAAE,eAAe,CAAC,CAAC;gBACvD,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;gBAC/B,MAAM;YACR;gBACE,IAAI,CAAA;gBACJ,kDAAkD;gBAClD,mDAAmD;gBACnD,+CAA+C;gBAC/C,2CAA2C;gBAC3C,MAAM;SACT;QACD,+CAA+C;QAC/C,oFAAoF;QACpF,mCAAmC;QACnC,mFAAmF;QACnF,0DAA0D;QAC1D,KAAK;IAEP,CAAC;IAED,UAAU,CAAE,IAAS;QACnB,iBAAiB;QACjB,gBAAgB;QAChB,iEAAiE;QACjE,qGAAqG;QACrG,MAAM;QACN,gDAAgD;QAChD,8CAA8C;QAC9C,iEAAiE;QACjE,oBAAoB;QACpB,2DAA2D;QAC3D,yDAAyD;QACzD,QAAQ;QACR,MAAM;IACR,CAAC;IAED,eAAe,CAAC,MAAc,EAAE,KAAa;QAC3C,MAAM,MAAM,GAAG,IAAI,SAAS,EAAE,CAAC;QAC/B,MAAM,GAAG,GAAG,MAAM,CAAC,eAAe,CAAC,IAAI,CAAC,UAAU,EAAE,WAAW,CAAC,CAAC;QACjE,MAAM,OAAO,GAAG,GAAG,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC;QAElD,IAAI,OAAO,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE;YACjC,IAAI,KAAK,IAAI,CAAC,IAAI,KAAK,GAAG,OAAO,CAAC,MAAM,EAAE;gBACxC,6DAA6D;gBAE7D,OAAO,CAAC,KAAK,CAAC,CAAC,YAAY,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;gBAC3C,IAAI,CAAC,UAAU,GAAG,GAAG,CAAC,IAAI,CAAC,SAAS,CAAC;aAEtC;SACF;IACD,CAAC;IAED,mBAAmB,CAAC,IAAS;QAC3B,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,qBAAqB,CAAC,EAAE,EAAE,WAAW,EAAE,EAAC,IAAI,EAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAC,EAAE,CAAC,CAAA;IAC/F,CAAC;IAED,2CAA2C;IAC3C,yCAAyC;IACzC,+CAA+C;IAC/C,mDAAmD;IACnD,+CAA+C;IAC/C,gCAAgC;IAChC,sDAAsD;IACtD,+DAA+D;IAC/D,iFAAiF;IACjF,mCAAmC;IACnC,iBAAiB;IACjB,oCAAoC;IACpC,UAAU;IACV,QAAQ;IACR,MAAM;IACN,IAAI;IAEL,YAAY,CAAC,KAAkB;QAC9B,IAAI,IAAI,CAAC,WAAW,KAAK,QAAQ,EAAE;YACjC,MAAM,SAAS,GAAG,MAAM,CAAC,YAAY,EAAE,CAAC;YACxC,IAAI,SAAS,IAAI,SAAS,CAAC,UAAU,GAAG,CAAC,EAAE;gBACzC,MAAM,KAAK,GAAG,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;gBACtC,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE;oBACpB,MAAM,IAAI,GAAG,KAAK,CAAC,qBAAqB,EAAE,CAAC;oBAC3C,MAAM,OAAO,GAAI,QAAQ,CAAC,eAAe,CAAC,SAAS,CAAC;oBACpD,MAAM,OAAO,GAAI,QAAQ,CAAC,eAAe,CAAC,UAAU,CAAC;oBACrD,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,GAAG,GAAG,OAAO,GAAG,EAAE,CAAC;oBAC1C,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,IAAI,GAAG,OAAO,GAAG,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC;oBAChE,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;iBACzB;qBAAM;oBACL,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;iBAC1B;aACF;iBAAM;gBACL,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;aAC1B;SACF;IACH,CAAC;IAGD,mCAAmC;IACnC,8BAA8B;IAC9B,iDAAiD;IACjD,2BAA2B;IAC3B,gEAAgE;IAChE,4CAA4C;IAC5C,4DAA4D;IAC5D,wCAAwC;IACxC,iBAAiB;IACjB,8CAA8C;IAC9C,UAAU;IACV,QAAQ;IACR,MAAM;IAEJ,mCAAmC;IACnC,4BAA4B;IAC5B,+CAA+C;IAC/C,yBAAyB;IACzB,2BAA2B;IAC3B,yCAAyC;IACzC,+CAA+C;IAC/C,kDAAkD;IAClD,6CAA6C;IAC7C,sBAAsB;IACtB,6CAA6C;IAC7C,0CAA0C;IAC1C,6GAA6G;IAC7G,+CAA+C;IAC/C,eAAe;IACf,wCAAwC;IACxC,mDAAmD;IACnD,YAAY;IACZ,UAAU;IACV,QAAQ;IAER,mCAAmC;IACnC,8DAA8D;IAC9D,0CAA0C;IAC1C,0DAA0D;IAC1D,sCAAsC;IACtC,eAAe;IACf,4CAA4C;IAC5C,QAAQ;IACR,MAAM;IACN,IAAI;IAEJ,OAAO,CAAC,KAAqB;QAC3B,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,MAAM,aAAa,GAAG,KAAK,CAAC,aAAa,CAAC;QAC1C,IAAI,aAAa,EAAE;YACjB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,aAAa,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBACnD,MAAM,IAAI,GAAG,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;gBAEpC,IAAI,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE;oBAClC,qBAAqB;oBACrB,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;oBAC9B,IAAI,IAAI,EAAE;wBACR,MAAM,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;wBAChC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAM,EAAE,EAAE;4BACzB,MAAM,OAAO,GAAG,aAAa,CAAC,CAAC,MAAM,CAAC,MAAM,kDAAkD,CAAC;4BAC/F,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC;wBAClC,CAAC,CAAC;wBACF,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;wBAC3B,OAAO;qBACR;iBACF;qBAAM,IAAI,IAAI,CAAC,IAAI,KAAK,WAAW,EAAE;oBACpC,oBAAoB;oBACpB,uDAAuD;oBACvD,IAAI,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,EAAE;wBACxD,MAAM,IAAI,GAAG,IAAI,CAAC,kBAAkB,CAAC,aAAa,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC;wBACzE,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;qBAC9B;yBAAM;wBACL,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC;qBAC5D;oBACD,oCAAoC;oBACpC,OAAO;iBACR;qBAAM,IAAI,IAAI,CAAC,IAAI,KAAK,YAAY,EAAE;oBACrC,0BAA0B;oBAC1B,IAAI,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,EAAE;wBACzD,MAAM,IAAI,GAAG,IAAI,CAAC,kBAAkB,CAAC,aAAa,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC;wBAC1E,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;qBAC9B;yBAAM;wBACL,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC;qBAC7D;oBACD,yDAAyD;oBACzD,qCAAqC;oBACrC,OAAO;iBACR;aACF;SACF;IACH,CAAC;IAED,WAAW,CAAC,IAAY;QACtB,OAAO,IAAI,CAAC,QAAQ,CAAC,mDAAmD,CAAC;YACnE,IAAI,CAAC,QAAQ,CAAC,kDAAkD,CAAC,CAAC;IAC1E,CAAC;IAED,uBAAuB,CAAC,IAAY;QAClC,MAAM,MAAM,GAAG,IAAI,SAAS,EAAE,CAAC;QAC/B,MAAM,GAAG,GAAG,MAAM,CAAC,eAAe,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC;QACtD,MAAM,KAAK,GAAG,GAAG,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;QACzC,OAAO,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,8BAA8B;IACrE,CAAC;IAKD,WAAW,CAAC,IAAY;QACtB,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QAC9B,OAAO,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;IAC3D,CAAC;IAED,6CAA6C;IAC7C,oEAAoE;IACpE,wCAAwC;IACxC,iGAAiG;IACjG,yIAAyI;IACzI,iBAAiB;IACjB,0CAA0C;IAC1C,IAAI;IAEJ,kBAAkB,CAAC,IAAY;QAC7B,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC;QAC/D,MAAM,WAAW,GAAG,IAAI,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC,+CAA+C;QACrG,MAAM,WAAW,GAAG,GAAG,GAAG,WAAW,CAAC,CAAC,yBAAyB;QAEhE,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE;YACxC,MAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC;;gCAEhB,WAAW;YAC/B,IAAI;cACF,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YAEnB,oFAAoF;YACpF,MAAM,SAAS,GAAG,KAAK,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,eAAe,IAAI,CAAC,uBAAuB,EAAE,GAAG,CAAC;YACtF,MAAM,YAAY,GAAG,KAAK,KAAK,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,kBAAkB,IAAI,CAAC,uBAAuB,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;YAE1G,OAAO;;mBAEM,SAAS,IAAI,YAAY;YAChC,KAAK;cACH,CAAC;QACX,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAEZ,OAAO;;UAED,SAAS;eACJ,CAAC;IACd,CAAC;IAID,iBAAiB,CAAC,IAAY;QAC5B,MAAM,KAAK,GAAG,MAAM,CAAC,YAAY,EAAE,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC;QACnD,IAAI,KAAK,EAAE;YACT,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YAC9C,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC;YACzB,MAAM,IAAI,GAAG,QAAQ,CAAC,sBAAsB,EAAE,CAAC;YAC/C,IAAI,IAAI,CAAC;YACT,OAAO,CAAC,IAAI,GAAG,OAAO,CAAC,UAAU,CAAC,EAAE;gBAClC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;aACxB;YACD,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YACvB,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;SACvB;IACH,CAAC;IAED,uBAAuB;QACrB,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,mBAAmB,CAAC,CAAA;QAC/D,IAAI,OAAO,IAAI,MAAM,EAAE;YACrB,OAAO,+BAA+B,CAAA;SACvC;aAAM;YACL,OAAO,8BAA8B,CAAA;SACtC;IACH,CAAC;IAGM,cAAc;QACnB,IAAI,IAAI,GAAQ,QAAQ,CAAC,cAAc,CAAC,YAAY,CAAC,CAAC;QACtD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;QACzB,IAAI,IAAI,CAAC,iBAAiB,EAAE;YAC1B,IAAI,CAAC,iBAAiB,EAAE,CAAC;SAC1B;aAAM,IAAI,IAAI,CAAC,oBAAoB,EAAE;YACpC,IAAI,CAAC,oBAAoB,EAAE,CAAC;SAC7B;aAAM,IAAI,IAAI,CAAC,uBAAuB,EAAE;YACvC,IAAI,CAAC,uBAAuB,EAAE,CAAC;SAChC;aAAM,IAAI,IAAI,CAAC,mBAAmB,EAAE;YACnC,IAAI,CAAC,mBAAmB,EAAE,CAAC;SAC5B;QACD,IAAI,CAAC,KAAK,GAAG;YACX,YAAY,EAAE,MAAM;YACpB,YAAY,EAAE,MAAM;SACrB,CAAA;IACH,CAAC;IAEM,eAAe;QACpB,IAAI,QAAQ,CAAC,cAAc,EAAE;YAC3B,QAAQ,CAAC,cAAc,EAAE,CAAC;YAC1B,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;YAC1B,IAAI,CAAC,KAAK,GAAG;gBACX,YAAY,EAAE,OAAO;gBACrB,YAAY,EAAE,OAAO;aACtB,CAAA;SACF;IACH,CAAC;IAED,eAAe;QACb,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,CAAA;IAC7B,CAAC;IAED,YAAY;QACV,IAAI,CAAC,SAAS,EAAE,CAAC;QAChB,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;QAElD,IAAI,MAAM,EAAE;YACV,MAAM,CAAC,gBAAgB,CAAC,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;SACxD;IACH,CAAC;IAED,OAAO;QACL,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;IAED,SAAS;QACP,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;QAEjD,IAAI,MAAM,EAAE;YACV,MAAM,aAAa,GAAG,MAAM,CAAC,SAAS,CAAC;YACvC,IAAI,IAAI,CAAC,YAAY,KAAK,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE;gBACjD,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;gBACjC,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;aACrB;iBAAM;gBACL,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC,CAAC;gBAC5D,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;gBACjC,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;aACrB;YACD,IAAI,CAAC,YAAY,EAAE,CAAC;SACrB;IACH,CAAC;IACD,IAAI;QACF,IAAI,IAAI,CAAC,YAAY,GAAG,CAAC,EAAE;YACzB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;YACrD,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;YAEjD,IAAI,MAAM,EAAE;gBACV,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;aACzD;SACF;IACH,CAAC;IAED,IAAI;QACF,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE;YAC7B,MAAM,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC;YACzC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,WAAY,CAAC,CAAC;YAChC,IAAI,CAAC,YAAY,EAAE,CAAC;YACpB,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;YAEjD,IAAI,MAAM,EAAE;gBACV,IAAI,CAAC,gBAAgB,GAAG,WAAY,CAAC;aACtC;SACF;IACH,CAAC;IAEH,gDAAgD;IAChD,+DAA+D;IAC/D,gDAAgD;IAEhD,oDAAoD;IACpD,kDAAkD;IAClD,6DAA6D;IAC7D,yCAAyC;IAEzC,uEAAuE;IACvE,mDAAmD;IACnD,yBAAyB;IACzB,uBAAuB;IACvB,wBAAwB;IACxB,UAAU;IACV,QAAQ;IACN,IAAI;IAEJ,mBAAmB,CAAC,IAAY;QAChC,0DAA0D;QAC1D,MAAM,SAAS,GAAG,wBAAwB,CAAC;QAE3C,+CAA+C;QAC/C,OAAO,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,CAAC,OAAO,EAAE,EAAE;YACzC,sDAAsD;YACtD,MAAM,OAAO,GAAG,IAAI,IAAI,CAAC,OAAO,CAAC,CAAC;YAElC,+BAA+B;YAC/B,MAAM,GAAG,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC,QAAQ,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,2BAA2B;YACtF,MAAM,KAAK,GAAG,OAAO,CAAC,cAAc,CAAC,OAAO,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC,6BAA6B;YAChG,MAAM,IAAI,GAAG,OAAO,CAAC,WAAW,EAAE,CAAC,CAAC,gBAAgB;YAEpD,mCAAmC;YACnC,OAAO,GAAG,GAAG,IAAI,KAAK,IAAI,IAAI,EAAE,CAAC;QACnC,CAAC,CAAC,CAAC;IACL,CAAC;;kHAlrEY,qBAAqB;sGAArB,qBAAqB,mrBANnB,CAAC;YACZ,OAAO,EAAE,iBAAiB;YAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,qBAAqB,CAAC;YACpD,KAAK,EAAE,IAAI;SACZ,CAAC,oPCnBJ,i9mCA2fM;2FDteO,qBAAqB;kBAVjC,SAAS;+BACE,aAAa,aAGV,CAAC;4BACZ,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,sBAAsB,CAAC;4BACpD,KAAK,EAAE,IAAI;yBACZ,CAAC;6KAIO,UAAU;sBAAlB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACI,qBAAqB;sBAA9B,MAAM;gBACG,gBAAgB;sBAAzB,MAAM;gBACG,oBAAoB;sBAA7B,MAAM;gBACG,eAAe;sBAAxB,MAAM;gBACG,SAAS;sBAAlB,MAAM;gBACG,UAAU;sBAAnB,MAAM;gBACG,iBAAiB;sBAA1B,MAAM;gBACG,MAAM;sBAAf,MAAM;gBACG,aAAa;sBAAtB,MAAM;gBAEE,KAAK;sBAAb,KAAK;gBAGmB,UAAU;sBAAlC,SAAS;uBAAC,YAAY;gBACE,UAAU;sBAAlC,SAAS;uBAAC,YAAY","sourcesContent":["import { AfterViewInit, Component, Input, OnInit, Output, EventEmitter, forwardRef, ViewChild, ElementRef, Renderer2, OnChanges, SimpleChanges } from '@angular/core';\r\nimport { ControlValueAccessor, FormControl, NG_VALUE_ACCESSOR } from '@angular/forms';\r\n// import { MatDialog } from '@angular/material/dialog';\r\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\r\nimport { Router, ActivatedRoute } from '@angular/router';\r\nimport { NgxFullscreenDirective } from '@ultimate/ngx-fullscreen';\r\nimport * as XLSX from 'xlsx';\r\n// import { ImageEditorModalComponent } from '../modals/image-editor-modal/image-editor-modal.component';\r\nimport { compress, decompress } from 'lz-string';\r\n\r\n\r\n@Component({\r\n  selector: 'text-editor',\r\n  templateUrl: './el-text-editor.component.html',\r\n  styleUrls: ['./el-text-editor.component.scss'],\r\n    providers: [{\r\n    provide: NG_VALUE_ACCESSOR,\r\n    useExisting: forwardRef(() => ElTextEditorComponent),\r\n    multi: true\r\n  }]\r\n})\r\nexport class ElTextEditorComponent implements ControlValueAccessor, AfterViewInit, OnChanges {\r\n\r\n  @Input() editorText: string = '';\r\n  @Input() editorFrom: any;\r\n  @Input() editorAction: any;\r\n  @Input() UserRole: any;\r\n  @Input() style: any;\r\n  @Input() disableToolbar: any;\r\n  @Input() placeHolder: any;\r\n  @Input() reportId: any;\r\n  @Input() backgroundImage: any;\r\n  @Input() toolbarMode: 'fixed' | 'bubble' | 'none' = 'fixed';\r\n  @Input() contentEditable: boolean = true; // Input for initial value\r\n  @Output() contentEditableChange: EventEmitter<boolean> = new EventEmitter<boolean>(); // Output for changes\r\n  @Output() editorTextChange = new EventEmitter<string>();\r\n  @Output() editorActionResponse = new EventEmitter<any>();\r\n  @Output() editorTextClear = new EventEmitter<any>();\r\n  @Output() imageEdit = new EventEmitter<any>();\r\n  @Output() imageEdit2 = new EventEmitter<any>();\r\n  @Output() placeHolderRemove = new EventEmitter<any>();\r\n  @Output() isOpen = new EventEmitter<any>();\r\n  @Output() newImageAdded = new EventEmitter<any>();\r\n  \r\n  @Input() value: string = '';\r\n\r\n  \r\n  @ViewChild('textEditor') TextEditor!:  ElementRef<Element>;\r\n  @ViewChild('fullscreen') fullscreen!: NgxFullscreenDirective\r\n    \r\n  sanitizedContent!: SafeHtml;\r\n\r\n\r\n  showToolbar = false;\r\n  toolbarTop = 0;\r\n  toolbarLeft = 0;\r\n\r\n  fonts = ['Arial', 'Courier New', 'Georgia', 'Times New Roman', 'Verdana'];\r\n  fontSizes = [10, 12, 14, 16, 18, 20, 24, 28, 32, 36];\r\n  selectedFont = 'Arial';\r\n  selectedFontSize = 14;\r\n  isTableSelected = false;\r\n  tableAdded = false;\r\n  selectedTable: HTMLTableElement | null = null;\r\n  isPlaceholderVisible = true;\r\n  selectedCell: HTMLTableCellElement | null = null;\r\n  \r\n  isBoldActive: boolean = false;\r\n  isItalicActive: boolean = false;\r\n  isUnderlineActive: boolean = false;\r\n  isStrikethroughActive: boolean = false;\r\n  isSubscriptActive: boolean = false;\r\n  isSuperscriptActive: boolean = false;\r\n\r\n  selectedFormatBlock: string = 'normal'\r\n\r\n  selectedImage: HTMLImageElement | null = null;\r\n  imageEditUrl: string = '';\r\n  imagePositionX = 0;\r\n  imagePositionY = 0;\r\n  imageResizeStartX = 0;\r\n  imageResizeStartY = 0;\r\n  imageResizeStartWidth = 0;\r\n  imageResizeStartHeight = 0;\r\n  imageResizeDirection: 'topLeft' | 'topRight' | 'bottomLeft' | 'bottomRight' | null = null;\r\n\r\n  undoStack: string[] = [];\r\n  redoStack: string[] = [];\r\n  history: string[] = [];\r\n  historyIndex = -1;\r\n  // editorText1 = ``;\r\n  selectedTextColor: any;\r\n  onChange: any = () => {};\r\n  onTouched: any = () => {};\r\n  color: any = '#ddd';\r\n  colorFormControl!: FormControl;\r\n  backgroundColor: any;\r\n  selectedItemIndex: number | null = null;\r\n\r\n  parsedTable: { headers: string[], rows: string[][] } | null = null;\r\n\r\n  isFullScreen: boolean = false;\r\n  currentCaretPosition: any;\r\n  userRole: any[] = [];\r\n  showEditButton: boolean = false;\r\n  tHeadBgColor: any;\r\n\r\n  constructor(\r\n    private router: Router,\r\n    private route: ActivatedRoute,\r\n    private renderer: Renderer2,\r\n    private sanitizer: DomSanitizer,\r\n  ) {\r\n    this.getUserRoles()\r\n\r\n    \r\n  }\r\n\r\n  themeMode() {\r\n    const clrMode = document.body.getAttribute('data-layout-color')\r\n    if (clrMode == 'dark') {\r\n      return '2px solid #403F4A !important'\r\n    } else {\r\n      return '2px solid #D0D0D0 !important'\r\n    }\r\n  }\r\n\r\n  themeModeClr() {\r\n    const clrMode = document.body.getAttribute('data-layout-color')\r\n    if (clrMode == 'dark') {\r\n      return '#fff !important'\r\n    } else {\r\n      return '#000 !important'\r\n    }\r\n  }\r\n\r\n  themeModeClrVerticalLine() {\r\n    const clrMode = document.body.getAttribute('data-layout-color')\r\n    if (clrMode == 'dark') {\r\n      return '2px solid #FFFFFF !important'\r\n    } else {\r\n      return '2px solid #D0D0D0 !important'\r\n    }\r\n  }\r\n\r\n  themeModeBgClr() {\r\n    const clrMode = document.body.getAttribute('data-layout-color')\r\n    if (clrMode == 'dark') {\r\n      return '#282828 !important'\r\n    } else {\r\n      return '#F3F3F3 !important'\r\n    }\r\n  }\r\n\r\n  themeModeBorderTop() {\r\n    const clrMode = document.body.getAttribute('data-layout-color')\r\n    if (clrMode == 'dark') {\r\n      return '2px solid #000 !important'\r\n    } else {\r\n      return '2px solid #fff !important'\r\n    }\r\n  }\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['placeHolder']) {\r\n      this.insertAtCaret(this.placeHolder)\r\n\r\n    }\r\n\r\n    if (changes['reportId']) {\r\n      sessionStorage.setItem('reportId', this.reportId)\r\n    } \r\n\r\n    if (changes['UserRole']) { \r\n      this.getUserRoles()\r\n    }\r\n  }\r\n  ngAfterViewInit() {\r\n    this.initEditor();\r\n    this.checkPlaceholder();\r\n    this.setupHistory();\r\n    document.addEventListener('fullscreenchange', this.onFullscreenChange);\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.init_Func(this.editorText)\r\n    document.addEventListener('selectionchange', () => {\r\n      this.checkActiveStates();\r\n      this.checkFormatBlock();\r\n    });\r\n    this.addClickListenerToImages();\r\n    this.addClickListenerToElements();\r\n    // this.route.queryParams.subscribe(params => {\r\n    //   const data = JSON.parse(params['data']);\r\n    //   if (data.editedIMG) {\r\n    //     const imgUrl = sessionStorage.getItem('editImageFromTemp');\r\n    //     if (imgUrl) {\r\n    //       this.replaceImageSrc(imgUrl, data.index.index)\r\n    //     }\r\n    //     sessionStorage.removeItem('editImageFromTemp');\r\n    //   }\r\n    // })\r\n  }\r\n\r\n   ngOnDestroy() {\r\n    // Cleanup the event listener when the component is destroyed\r\n    document.removeEventListener('fullscreenchange', this.onFullscreenChange);\r\n  }\r\n\r\n  IsOpen: boolean = false;\r\n\r\n    toggleFullscreen1() {\r\n      this.IsOpen = !this.IsOpen;\r\n      this.isOpen.emit(this.IsOpen)\r\n      if (this.IsOpen) { \r\n        this.fullscreen.enter(this.TextEditor.nativeElement);\r\n      } else {\r\n        this.fullscreen.exit()\r\n      }\r\n    }\r\n  \r\n  private onFullscreenChange = () => {\r\n    if (!document.fullscreenElement) {\r\n      // When fullscreen mode is exited\r\n      this.IsOpen = false;\r\n      this.isOpen.emit(this.IsOpen);\r\n    }\r\n  };\r\n  \r\n  // enterFullscreenVideo() {\r\n  //   console.log('event:', event);\r\n  //   const fullscreen = event;\r\n  //   this.isOpen = event;\r\n  //   if (fullscreen) {\r\n  //     this.fullscreen.enter(this.TextEditor.nativeElement);\r\n  //   } else {\r\n  //     this.fullscreen.exit()\r\n  //   }\r\n    \r\n  // }\r\n\r\n  writeValue(value: any): void {\r\n    if (value !== undefined) {\r\n      this.editorText = value;\r\n      this.initEditor();\r\n      this.init_Func(this.editorText);\r\n    }\r\n  }\r\n  \r\n//  private addClickListenerToImages() {\r\n//   const editor = document.getElementById('editor');\r\n//   if (editor) {\r\n//     editor.addEventListener('click', (event) => {\r\n//       const target = event.target as HTMLElement;\r\n//       if (target.tagName === 'IMG') {\r\n//         this.selectedImage = target as HTMLImageElement;\r\n//         this.imageEditUrl = this.selectedImage.src;\r\n\r\n//         let container = this.selectedImage.parentElement;\r\n//         if (!container || container.className !== 'image-container') {\r\n//           container = document.createElement('div');\r\n//           container.className = 'image-container';\r\n//           container.style.position = 'relative';\r\n//           container.style.display = 'inline-block';\r\n//           this.selectedImage.parentNode?.insertBefore(container, this.selectedImage);\r\n//           container.appendChild(this.selectedImage);\r\n//         }\r\n//         const existingButton = container.querySelector('.image-edit-button');\r\n//         if (existingButton) {\r\n//           existingButton.remove();\r\n//         }\r\n\r\n//         const button = document.createElement('button');\r\n//         // button.textContent = 'Edit';\r\n//         button.innerText = 'Edit Image';\r\n\r\n//         button.className = 'image-edit-button btn btn-sm';\r\n//         button.style.position = 'absolute';\r\n//         button.style.top = '50%';\r\n//         button.style.left = '50%';\r\n//         button.style.transform = 'translate(-50%, -50%)';\r\n//         button.style.zIndex = '1000';\r\n//         button.style.backgroundColor = '#fff';\r\n//         button.style.border = '2px solid #fff';\r\n//         // button.style.padding = '10px';\r\n//         button.style.color = '#313a46';\r\n//         button.style.cursor = 'pointer';\r\n\r\n//         button.addEventListener('click', (e) => {\r\n//           e.stopPropagation();\r\n//           this.editImage();\r\n//         });\r\n\r\n//         container.appendChild(button);\r\n//       } else {\r\n//         this.selectedImage = null;\r\n//         this.selectedItemIndex = null;\r\n//       }\r\n//     });\r\n//   }\r\n  // }\r\n  getUserRoles() {\r\n    this.userRole = this.UserRole\r\n  }\r\n  // roleCheck() {\r\n  //   for (let i = 0; i < this.userRole.length; ++i) {\r\n  //     const roleName = []\r\n  //       roleName.push(this.userRole[i]?.name);\r\n  //     return this.userRole[i]?.name;\r\n  //   }\r\n  // }\r\n\r\n  roleCheck() {\r\n    let userRoleName: string[] = [];\r\n    for (let i = 0; i <= this.userRole.length; ++i) {\r\n      userRoleName.push(this.userRole[i]?.name);\r\n    }\r\n    return userRoleName;\r\n  }\r\n\r\n\r\n// private addClickListenerToImages() {\r\n//   const editor = document.getElementById('editor');\r\n//   const roles = this.roleCheck(); // Get user roles dynamically\r\n//   const isAdmin = roles.includes('Admin');\r\n//   const isCreator = roles.includes('Creator');\r\n//   const isApprover = roles.includes('Approver');\r\n  \r\n//   if (isCreator || isAdmin) {\r\n//     if (editor) {\r\n//     editor.addEventListener('click', (event) => {\r\n//       const target = event.target as HTMLElement;\r\n//       if (target.tagName === 'IMG') {\r\n//         this.selectedImage = target as HTMLImageElement;\r\n//         this.imageEditUrl = this.selectedImage.src;\r\n//         let container = this.selectedImage.parentElement;\r\n//         if (!container || container.className !== 'image-container') {\r\n//           container = document.createElement('div');\r\n//           container.className = 'image-container';\r\n//           container.style.position = 'relative';\r\n//           container.style.display = 'inline-block';  \r\n//           this.selectedImage.parentNode?.insertBefore(container, this.selectedImage);\r\n//           container.appendChild(this.selectedImage);\r\n//         }\r\n\r\n//         const existingButton = container.querySelector('.image-edit-button');\r\n//         if (existingButton) {\r\n//           existingButton.remove();\r\n//         }\r\n\r\n//         const button = document.createElement('button');\r\n//         button.textContent  = 'Edit Image';\r\n//         button.className = 'image-edit-button btn btn-sm';\r\n//         button.style.position = 'absolute';\r\n//         button.style.top = '50%';\r\n//         button.style.left = '50%';\r\n//         button.style.transform = 'translate(-50%, -50%)';\r\n//         button.style.zIndex = '1000';\r\n//         button.style.backgroundColor = '#fff'; \r\n//         button.style.border = '2px solid #fff'; \r\n//         button.style.color = '#313a46';\r\n//         button.style.cursor = 'pointer';\r\n//         button.style.userSelect = 'none';\r\n\r\n//         button.addEventListener('click', (e) => {\r\n//           e.stopPropagation();\r\n//           this.editImage();\r\n//         });\r\n\r\n//         container.appendChild(button);\r\n\r\n//       } else {\r\n//         this.selectedImage = null;\r\n//         this.selectedItemIndex = null;\r\n//         const buttons = document.querySelectorAll('.image-edit-button');\r\n//         buttons.forEach(button => button.remove());\r\n//       }\r\n//     });\r\n//   }\r\n//   }\r\n  // }\r\n  private addClickListenerToImages() {\r\n  const editor = document.getElementById('editor');\r\n  const roles = this.roleCheck(); // Get user roles dynamically\r\n  const isAdmin = roles.includes('Admin');\r\n  const isCreator = roles.includes('Creator');\r\n\r\n  if (isCreator || isAdmin) {\r\n    if (editor) {\r\n      editor.addEventListener('click', (event) => {\r\n        const target = event.target as HTMLElement;\r\n        if (target.tagName === 'IMG') {\r\n          this.selectedImage = target as HTMLImageElement;\r\n          this.imageEditUrl = this.selectedImage.src;\r\n          const images = editor.getElementsByTagName('img');\r\n           for (let i = 0; i < images.length; i++) {\r\n          if (images[i] === this.selectedImage) {\r\n            this.selectedItemIndex = i;\r\n            break;\r\n          }\r\n        }\r\n          let container = this.selectedImage.parentElement;\r\n          if (!container || container.className !== 'image-container') {\r\n            container = document.createElement('div');\r\n            container.className = 'image-container';\r\n            container.style.position = 'relative';\r\n            container.style.display = 'inline-block';\r\n            this.selectedImage.parentNode?.insertBefore(container, this.selectedImage);\r\n            container.appendChild(this.selectedImage);\r\n          }\r\n\r\n          const existingButton = container.querySelector('.image-edit-button');\r\n          if (existingButton) {\r\n            existingButton.remove();\r\n          }\r\n\r\n          const button = document.createElement('button');\r\n          button.textContent = 'Edit Image';\r\n          button.className = 'image-edit-button btn btn-sm';\r\n          button.style.position = 'absolute';\r\n          button.style.top = '50%';\r\n          button.style.left = '50%';\r\n          button.style.transform = 'translate(-50%, -50%)';\r\n          button.style.zIndex = '1000';\r\n          button.style.backgroundColor = '#fff';\r\n          button.style.border = '2px solid #fff';\r\n          button.style.color = '#313a46';\r\n          button.style.cursor = 'pointer';\r\n          button.style.userSelect = 'none';\r\n\r\n          button.addEventListener('click', (e) => {\r\n            e.stopPropagation();\r\n            this.editImage();\r\n          });\r\n\r\n          container.appendChild(button);\r\n        } else {\r\n          this.removeEditButtons();\r\n        }\r\n      });\r\n\r\n      // Monitor editor content changes to handle image deletion\r\n      const observer = new MutationObserver(() => {\r\n        const buttons = editor.querySelectorAll('.image-edit-button');\r\n        buttons.forEach((button) => {\r\n          const container = button.parentElement;\r\n          if (container && !container.querySelector('img')) {\r\n            button.remove(); // Remove the button if the associated image is gone\r\n            container.remove(); // Clean up the container\r\n          }\r\n        });\r\n      });\r\n\r\n      // Observe changes in the editor\r\n      observer.observe(editor, { childList: true, subtree: true });\r\n    }\r\n  }\r\n}\r\n\r\nprivate removeEditButtons() {\r\n  const buttons = document.querySelectorAll('.image-edit-button');\r\n  buttons.forEach((button) => button.remove());\r\n  this.selectedImage = null;\r\n  this.selectedItemIndex = null;\r\n}\r\n\r\n\r\n  // private addClickListenerToImages() {\r\n  // const editor = document.getElementById('editor');\r\n  // if (editor) {\r\n  //   editor.addEventListener('click', (event) => {\r\n  //     const target = event.target as HTMLElement;\r\n  //     if (target.tagName === 'IMG') {\r\n  //       this.selectedImage = target as HTMLImageElement;\r\n  //       this.imageEditUrl = this.selectedImage.src;\r\n\r\n  //       // Get the index of the selected image\r\n  //       const images = editor.getElementsByTagName('img');\r\n  //       for (let i = 0; i < images.length; i++) {\r\n  //         if (images[i] === this.selectedImage) {\r\n  //           this.selectedItemIndex = i;\r\n  //           break;\r\n  //         }\r\n  //       }\r\n\r\n  //       if (this.toolbarMode === 'bubble') {\r\n  //         this.onTextSelect();\r\n  //       }\r\n  //     } else {\r\n  //       this.selectedImage = null;\r\n  //       this.selectedItemIndex = null;\r\n  //     }\r\n  //   });\r\n  // }\r\n  // }\r\n  \r\n  private addClickListenerToElements() {\r\n  const editor = document.getElementById('editor');\r\n  if (editor) {\r\n    editor.addEventListener('click', (event) => {\r\n      const target = event.target as HTMLElement;\r\n      if (target.tagName === 'IMG') {\r\n        this.selectedImage = target as HTMLImageElement;\r\n        this.imageEditUrl = this.selectedImage.src;\r\n        const images = editor.getElementsByTagName('img');\r\n        for (let i = 0; i < images.length; i++) {\r\n          if (images[i] === this.selectedImage) {\r\n            this.selectedItemIndex = i;\r\n            break;\r\n          }\r\n        }\r\n      } else {\r\n        this.selectedImage = null;\r\n      }\r\n      if (target.tagName === 'TD' || target.tagName === 'TH') {\r\n        this.selectedTable = target.closest('table') as HTMLTableElement;\r\n        const cells = this.selectedTable.getElementsByTagName(target.tagName);\r\n        for (let i = 0; i < cells.length; i++) {\r\n          if (cells[i] === target) {\r\n            this.selectedItemIndex = i;\r\n            break;\r\n          }\r\n        }\r\n      } else {\r\n        this.selectedTable = null;\r\n      }\r\n\r\n      if (target.tagName === 'P' || target.tagName === 'SPAN' || target.tagName === 'DIV') {\r\n        const paragraphs = editor.getElementsByTagName(target.tagName);\r\n        for (let i = 0; i < paragraphs.length; i++) {\r\n          if (paragraphs[i] === target) {\r\n            this.selectedItemIndex = i;\r\n            break;\r\n          }\r\n        }\r\n      }\r\n    });\r\n  }\r\n  }\r\n\r\nreplaceImageSrc(newSrc: string, index: number) {\r\n  const editor = document.getElementById('editor');\r\n  \r\n  if (editor) {\r\n    editor.focus()\r\n    const images = editor.getElementsByTagName('IMG');\r\n    if (index >= 0 ) {\r\n      images[index].setAttribute('src', newSrc);\r\n    } \r\n  }\r\n}\r\n\r\n\r\n\r\n  private initEditor() {\r\n    // Initialize editor content and listeners\r\n    const editor = document.getElementById('editor');\r\n\r\n    if (editor) {\r\n      editor.innerHTML = this.editorText;\r\n      editor.addEventListener('input', () => {\r\n        this.onModelChange(editor.innerHTML);\r\n      });\r\n    }\r\n    this.checkPlaceholder();\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  setDisabledState?(isDisabled: boolean): void {\r\n    // Handle the disabled state if necessary\r\n  }\r\n\r\n  onModelChange(value: any): void {\r\n    if (value) {\r\n      const VALUE = value\r\n      this.editorText = VALUE;\r\n      this.onChange(VALUE);\r\n      this.editorTextChange.emit(VALUE);\r\n    } else {\r\n      this.selectedImage = null;\r\n    }\r\n  }\r\n\r\n  applyImageStyles(content: string): string {\r\n    const div = document.createElement('div');\r\n    div.innerHTML = content;\r\n    const images = div.querySelectorAll('img');\r\n    images.forEach(img => {\r\n      if (img.style.maxWidth >= '700px') {\r\n        img.style.maxWidth = '700px';\r\n        // img.width = 300;\r\n        img.style.height = 'auto';\r\n      } else {\r\n        img.style.maxWidth = '100%';\r\n        img.style.height = 'auto';\r\n      }\r\n    });\r\n    return div.innerHTML;\r\n  }\r\n\r\n  // init_Func(html: any) {\r\n  //   if (html) {\r\n  //     let editor = document.getElementById('editor');\r\n  //     if (editor) { \r\n  //       editor.focus()\r\n  //       editor.innerHTML = html;\r\n  //       this.sanitizedContent = this.sanitizer.bypassSecurityTrustHtml(this.applyImageStyles(html));\r\n  //       editor.innerHTML = this.sanitizedContent as string;\r\n  //       editor.addEventListener('input', () => {\r\n  //         if (editor) {\r\n  //           editor.focus()\r\n  //           this.onModelChange(editor.innerHTML);\r\n  //         }\r\n  //       });\r\n  //     }\r\n  //   } else {\r\n  //     this.selectedImage = null;\r\n  //   }\r\n  // }\r\n  \r\n//   init_Func(html: any) {\r\n//   if (html) {\r\n//     let editor = document.getElementById('editor');\r\n//     if (editor) {\r\n//       // Initialize the editor with sanitized content\r\n      \r\n//       this.setEditorContent(html);\r\n\r\n//       // Set up a MutationObserver to handle content changes\r\n//       this.setupMutationObserver(editor);\r\n\r\n//       // Move the caret to the end after initial content setup\r\n//       this.moveCaretToEnd(editor);\r\n\r\n//       // Track caret position on mouse click\r\n//       editor.addEventListener('click', () => {\r\n//         if (editor) {  // Ensure editor is not null\r\n//           // this.trackCaretPosition(editor);\r\n//         }\r\n//       });\r\n//     }\r\n//   } else {\r\n//     this.selectedImage = null;\r\n//   }\r\n// }\r\n\r\n// private setEditorContent(html: string) {\r\n//   let editor = document.getElementById('editor');\r\n//   if (editor) {\r\n//     // Sanitize and apply styles to the HTML\r\n//     this.sanitizedContent = this.sanitizer.bypassSecurityTrustHtml(this.applyImageStyles(html));\r\n//     editor.innerHTML = this.sanitizedContent as string;\r\n//   }\r\n// }\r\n\r\n// private setupMutationObserver(editor: HTMLElement) {\r\n//   const observer = new MutationObserver(() => {\r\n//     // Update model with the current content\r\n//     this.onModelChange(editor.innerHTML);\r\n//   });\r\n\r\n//   observer.observe(editor, { childList: true, subtree: true, characterData: true });\r\n// }\r\n\r\n// This function tracks the caret position based on the mouse click\r\nprivate trackCaretPosition(editor: HTMLElement) {\r\n  const selection = window.getSelection();\r\n  if (selection && selection.rangeCount > 0) {\r\n    const range = selection.getRangeAt(0);\r\n    const startNode = range.startContainer;\r\n    const startOffset = range.startOffset;\r\n\r\n\r\n    // You can use this information to insert content or perform actions based on the caret position\r\n    // Example: Save the current caret position for future use\r\n    this.currentCaretPosition = { node: startNode, offset: startOffset };\r\n  }\r\n  }\r\n  \r\n  // Method to get caret position and insert new data\r\nprivate insertAtCaret(newData: string): void {\r\n  const selection = window.getSelection();\r\n  \r\n  if (selection && selection.rangeCount > 0) {\r\n    // Get the current range (caret position)\r\n    const range = selection.getRangeAt(0);\r\n\r\n    // Create a document fragment to insert (allows handling HTML strings)\r\n    const fragment = document.createDocumentFragment();\r\n    const tempDiv = document.createElement('div');\r\n    tempDiv.innerHTML = newData;\r\n\r\n    // Append the new data to the fragment (supports HTML insertion)\r\n    while (tempDiv.firstChild) {\r\n      fragment.appendChild(tempDiv.firstChild);\r\n    }\r\n\r\n    // Insert the fragment at the caret position\r\n    range.deleteContents(); // Remove any selected content if applicable\r\n    range.insertNode(fragment);\r\n\r\n    // Move the caret after the inserted content\r\n    const lastChild = fragment.lastChild;\r\n\r\n    if (lastChild) {\r\n      range.setStartAfter(lastChild);\r\n      range.setEndAfter(lastChild);\r\n      selection.removeAllRanges();\r\n      selection.addRange(range);\r\n    }\r\n    let editor = document.getElementById('editor');\r\n    if (editor) {\r\n      this.moveCaretToEnd(editor)\r\n    }\r\n    \r\n    this.placeHolderRemove.emit()\r\n  }\r\n}\r\n\r\n\r\n//   // Move caret to the end of the editor content\r\n//   private moveCaretToEnd(editor: HTMLElement) {\r\n//     const selection = window.getSelection();\r\n//     const range = document.createRange();\r\n    \r\n//     if (editor.lastChild) {\r\n//       range.selectNodeContents(editor);\r\n//       range.collapse(false); // Collapse to the end\r\n//       selection?.removeAllRanges();\r\n//       selection?.addRange(range);\r\n      \r\n//     }\r\n//   }\r\n  \r\n  \r\n\r\n\r\n  init_Func(html: any) {\r\n  if (html) {\r\n    let editor = document.getElementById('editor');\r\n    if (editor) {\r\n      // Initialize the editor with sanitized content\r\n      this.setEditorContent(html);\r\n\r\n      // Set up a MutationObserver to handle content changes\r\n      this.setupMutationObserver(editor);\r\n      \r\n      // Move the caret to the end after initial content setup\r\n      this.moveCaretToEnd(editor);\r\n      //  Track caret position on mouse click\r\n      editor.addEventListener('click', () => {\r\n        if (editor) {  // Ensure editor is not null\r\n          this.trackCaretPosition(editor);\r\n        }\r\n      });\r\n    }\r\n  } else {\r\n    this.selectedImage = null;\r\n  }\r\n}\r\n\r\n\r\nprivate setEditorContent(html: string) {\r\n  let editor = document.getElementById('editor');\r\n  if (editor) {\r\n    // Sanitize and apply styles to the HTML\r\n    this.sanitizedContent = this.sanitizer.bypassSecurityTrustHtml(this.applyImageStyles(html));\r\n    editor.innerHTML = this.sanitizedContent as string;\r\n  }\r\n}\r\n\r\nprivate setupMutationObserver(editor: HTMLElement) {\r\n  const observer = new MutationObserver(() => {\r\n    // Move the caret to the end after content changes\r\n    // this.moveCaretToEnd(editor);\r\n    // Update model with the current content\r\n    this.onModelChange(editor.innerHTML);\r\n  });\r\n\r\n  observer.observe(editor, { childList: true, subtree: true, characterData: true });\r\n}\r\n\r\nprivate moveCaretToEnd(editor: HTMLElement) {\r\n  const selection = window.getSelection();\r\n  const range = document.createRange();\r\n  \r\n  if (editor.lastChild) {\r\n    range.selectNodeContents(editor);\r\n    range.collapse(false); // Collapse to the end\r\n    selection?.removeAllRanges();\r\n    selection?.addRange(range);\r\n  }\r\n}\r\n\r\n//   init_Func(html: any) {\r\n//   if (html) {\r\n//     let editor = document.getElementById('editor');\r\n//     if (editor) {\r\n//       editor.focus();\r\n//       editor.innerHTML = html;\r\n\r\n//       // Sanitize the content and apply styles\r\n//       this.sanitizedContent = this.sanitizer.bypassSecurityTrustHtml(this.applyImageStyles(html));\r\n//       editor.innerHTML = this.sanitizedContent as string;\r\n\r\n//       // Place the caret at the end of the content\r\n//       const range = document.createRange();\r\n//       const selection = window.getSelection();\r\n      \r\n//       if (editor.lastChild) {\r\n//         // Set the range at the end of the editor's content\r\n//         range.selectNodeContents(editor);\r\n//         range.collapse(false); // collapse to the end\r\n//         selection?.removeAllRanges();\r\n//         selection?.addRange(range);\r\n//       }\r\n\r\n//       editor.addEventListener('input', () => {\r\n//         if (editor) {\r\n//           this.onModelChange(editor.innerHTML);\r\n\r\n//           // Ensure the caret remains at the end after new content is added\r\n//           const range = document.createRange();\r\n//           const selection = window.getSelection();\r\n          \r\n//           if (editor.lastChild) {\r\n//             range.selectNodeContents(editor);\r\n//             range.collapse(false); // collapse to the end\r\n//             selection?.removeAllRanges();\r\n//             selection?.addRange(range);\r\n//           }\r\n//         }\r\n//       });\r\n//     }\r\n//   } else {\r\n//     this.selectedImage = null;\r\n//   }\r\n// }\r\n\r\n  format(command: string, value?: any) {\r\n    const editor = document.getElementById('editor');\r\n    if (editor) {\r\n      editor.focus();\r\n      if (command === 'subscript') {\r\n        this.isSubscriptActive = !this.isSubscriptActive;\r\n        document.execCommand('subscript', false, '');\r\n      } else if (command === 'superscript') {\r\n        this.isSuperscriptActive = !this.isSuperscriptActive;\r\n        document.execCommand('superscript', false, '');;\r\n      } else {\r\n        document.execCommand(command, false, value ?? '');\r\n        if (value) {\r\n          const tag = value.toLowerCase().replace(/[<>]/g, '')\r\n          this.selectedFormatBlock = this.formatBlockDecode(tag);\r\n        }\r\n      }\r\n    }\r\n     this.checkActiveStates();\r\n     this.checkFormatBlock();\r\n  }\r\n\r\n  checkActiveStates() {\r\n    this.isBoldActive = document.queryCommandState('bold');\r\n    this.isItalicActive = document.queryCommandState('italic');\r\n    this.isUnderlineActive = document.queryCommandState('underline');\r\n    this.isStrikethroughActive = document.queryCommandState('strikethrough');\r\n    this.isSubscriptActive = document.queryCommandState('subscript');\r\n    this.isSuperscriptActive = document.queryCommandState('superscript');\r\n  }\r\n\r\n  checkFormatBlock() {\r\n    const editor = document.getElementById('editor');\r\n    if (editor) {\r\n      const formatBlock = document.queryCommandValue('formatBlock');\r\n      this.selectedFormatBlock = this.formatBlockDecode(formatBlock);\r\n      // You can further handle the formatBlock value as needed\r\n    }\r\n  }\r\n\r\n  formatBlockDecode(data: string): any {\r\n    switch (data) {\r\n      case 'h1':\r\n        return 'heading 1';\r\n        break;\r\n      case 'h2':\r\n        return 'heading 2';\r\n        break;\r\n      case 'h3':\r\n        return 'heading 3';\r\n        break;\r\n      case 'h4':\r\n        return 'heading 4';\r\n        break;\r\n      case 'h5':\r\n        return 'heading 5';\r\n        break;\r\n      case 'h6':\r\n        return 'heading 6';\r\n        break;\r\n      case 'p':\r\n        return 'normal';\r\n        break;\r\n      default:\r\n        return 'normal';\r\n        break;\r\n    }\r\n  }\r\n\r\n  changeFont(event: any) {\r\n    this.selectedFont = event;\r\n    document.execCommand('fontName', false, this.selectedFont);\r\n  }\r\n\r\n  insertCodeBlock() {\r\n    const code = `\r\n      <pre style=\"font-size: 12px;\r\n                  color: white;\r\n                  background-color: black;\r\n                  overflow-x: auto;\r\n                  margin-bottom: 5px;\r\n                  margin-top: 5px;\r\n                  padding: 5px 10px;\">\r\n        <code style=\"display: block;\r\n                     white-space: pre-wrap;\r\n                     height: auto;\r\n                     font-family: Menlo, Monaco, Consolas, 'Courier New', monospace;\r\n                     font-size: 14px;\" class=\"language-html\">Insert code here...</code>\r\n      </pre>\r\n    `;\r\n    document.execCommand('insertHTML', false, code);\r\n  }\r\n\r\n  // changeFontSize(event: any) {\r\n  //   document.execCommand('fontSize', false, '7');\r\n  //   let editor = document.getElementById('editor');\r\n  //   if (editor) {\r\n  //     let fontElements = editor.getElementsByTagName('font');\r\n  //     for (let i = 0; i < fontElements.length; i++) {\r\n  //       if (fontElements[i].size == \"7\") {\r\n  //         fontElements[i].removeAttribute(\"size\");\r\n  //         fontElements[i].style.fontSize = this.selectedFontSize + 'px';\r\n  //       }\r\n  //     }\r\n  //   }\r\n  // }\r\n  changeFontSize(event: any) {\r\n    const selectedText = window.getSelection();\r\n    \r\n    if (selectedText && selectedText.rangeCount > 0) {\r\n        const range = selectedText.getRangeAt(0);\r\n        const span = document.createElement('span');\r\n        span.style.fontSize = this.selectedFontSize + 'px';\r\n        range.surroundContents(span);\r\n    }\r\n  }\r\n\r\n  addLink() {\r\n    let url = prompt(\"Enter the link here: \", \"http://\");\r\n    if (url) {\r\n      document.execCommand(\"createLink\", false, url);\r\n    }\r\n  }\r\n\r\n  insertsImage() {\r\n    const editor = document.getElementById('editor');\r\n    if (editor) {\r\n      editor.focus();\r\n      let imageInput = document.getElementById('imageInput') as HTMLInputElement;\r\n      if (imageInput) {\r\n        imageInput.click();\r\n      }\r\n    }\r\n  }\r\n\r\n  // handleImageUpload(event: any) {\r\n  //   const file = event.target.files[0];\r\n  //   if (file) {\r\n  //     const reader = new FileReader();\r\n  //     reader.onload = (e: any) => {\r\n  //       const img = new Image();\r\n  //       img.src = e.target.result;\r\n  //       img.onload = () => {\r\n  //         // Create the HTML string with the exact width and height\r\n  //         const imgHTML = `<img src=\"${img.src}\" width=\"${794}\" >`;\r\n  //         // Insert the image into the editor\r\n  //         document.execCommand('insertHTML', false, imgHTML);\r\n  //       };\r\n  //     };\r\n  //     reader.readAsDataURL(file);\r\n  //   }\r\n  // }\r\n\r\n  handleImageUpload(event: any) {\r\n  const file = event.target.files[0];\r\n  const editorElement = document.getElementById('editor'); // Reference to the editor\r\n\r\n  if (file && editorElement) {\r\n    const editorWidth = editorElement.offsetWidth; // Get the editor's width\r\n    const reader = new FileReader();\r\n\r\n    reader.onload = (e: any) => {\r\n      const img = new Image();\r\n      img.src = e.target.result;\r\n\r\n      img.onload = () => {\r\n        const imgWidth = img.width;\r\n\r\n        // If the image width exceeds the editor's width, fit it to the editor\r\n        const imgHTML =\r\n          imgWidth > editorWidth\r\n            ? `<img src=\"${img.src}\" style=\" max-width: ${700}px; height: auto;\">`\r\n            : `<img src=\"${img.src}\" style=\"width: ${imgWidth}px; height: auto;\">`;\r\n        this.newImageAdded.emit()\r\n        // Insert the image into the editor\r\n        document.execCommand('insertHTML', false, imgHTML);\r\n      };\r\n    };\r\n\r\n    reader.readAsDataURL(file);\r\n  }\r\n}\r\n\r\n\r\n\r\n  // addTable() {\r\n  //   const tableWidth = 825; // Table width in pixels\r\n  //   const cols = 3; // Number of columns\r\n  //   const cellMinWidth = tableWidth / cols; // Calculate minimum width for each cell\r\n\r\n  //   let table = `<br /><table style=\"width: ${tableWidth}px;\">`;\r\n  //   for (let i = 0; i < 3; i++) { // Number of rows\r\n  //     table += '<tr >';\r\n  //     for (let j = 0; j < cols; j++) {\r\n  //       table += `<td style=\" word-wrap: break-word; word-break: break-all; white-space: normal; min-width: ${cellMinWidth}px;\">&nbsp;</td>`;\r\n  //     }\r\n  //     table += '</tr>';\r\n  //   }\r\n  //     table += '</table><br/ >';\r\n  //     // document.execCommand('insertHTML', false, table);\r\n  //     const editor = document.getElementById('editor');\r\n  //   if (editor) {\r\n  //     editor.focus();\r\n  //     document.execCommand('insertHTML', false, table);\r\n  //   }\r\n  //   this.tableAdded = true;\r\n  //   this.checkTableSelection();\r\n  // }\r\n\r\n\r\n  handleTabKey(event: any) {\r\n    if (event.key === \"Tab\") {\r\n      event.preventDefault(); // Stop default tabbing behavior\r\n      const selection = window.getSelection();\r\n      if (!selection || selection.rangeCount === 0) return;\r\n\r\n      const range = selection.getRangeAt(0);\r\n      const tabNode = document.createElement(\"span\"); // Create a span element for the tab space\r\n      tabNode.innerHTML = \"&nbsp;&nbsp;&nbsp;&nbsp;\"; // Four non-breaking spaces to mimic tab\r\n      \r\n      range.deleteContents(); // Remove any selected text\r\n      range.insertNode(tabNode); // Insert the tab space as span\r\n      range.setStartAfter(tabNode); // Move cursor after the inserted span\r\n      range.setEndAfter(tabNode);\r\n      selection.removeAllRanges();\r\n      selection.addRange(range);\r\n    }\r\n  }\r\n  \r\n//   addTable() {\r\n//   const tableWidth = 825; // Table width in pixels\r\n//   const cols = 3; // Number of columns\r\n//   const cellMinWidth = tableWidth / cols; // Calculate minimum width for each cell\r\n\r\n//   let table = `<br /><table style=\"width: ${tableWidth}px;\">`;\r\n//   for (let i = 0; i < 3; i++) { // Number of rows\r\n//     table += `<tr style=\"border-bottom: ${this.themeModeClrVerticalLineForTable()}\">`; // Add border-bottom to the row\r\n//     for (let j = 0; j < cols; j++) {\r\n//       table += `<td style=\"word-wrap: break-word; word-break: break-all; white-space: normal; min-width: ${cellMinWidth}px;\">&nbsp;</td>`;\r\n//     }\r\n//     table += '</tr>';\r\n//   }\r\n//   table += '</table><br/>';\r\n\r\n//   const editor = document.getElementById('editor');\r\n//   if (editor) {\r\n//     editor.focus();\r\n//     document.execCommand('insertHTML', false, table);\r\n//   }\r\n\r\n//   this.tableAdded = true;\r\n//   this.checkTableSelection();\r\n// }\r\n// addTable() {\r\n//   const tableWidth = 825;\r\n//   const cols = 3;\r\n//   const cellMinWidth = tableWidth / cols;\r\n\r\n//   let table = `<br /><table id=\"customTable\" style=\"width: ${tableWidth}px; border-collapse: collapse;\">`;\r\n\r\n//   table += `<tbody>`;\r\n//   table += `<tr id=\"tableHeaderRow\" style=\"border-bottom: ${this.themeModeClrVerticalLineForTable()};\" (click)=\"checkTableSelection()\">`;\r\n//   for (let j = 0; j < cols; j++) {\r\n//     table += `<td class=\"header-cell\" \r\n//               style=\"border-top: 2px solid black; \r\n//                      font-weight: bold; \r\n//                      text-align: start; \r\n//                      word-wrap: break-word; \r\n//                      word-break: break-all; \r\n//                      white-space: normal; \r\n//                      min-width: ${cellMinWidth}px; \r\n//                      background-color: inherit !important; \r\n//                     //  pointer-events: none !important;\r\n//                      display: table-cell !important;\r\n//                      position: static !important;\r\n// height:28px;\"></td>`;\r\n//   }\r\n//   table += `</tr>`;\r\n\r\n//   for (let i = 0; i < 3; i++) {\r\n//     table += `<tr style=\"border-bottom: ${this.themeModeClrVerticalLineForTable()}\">`;\r\n//     for (let j = 0; j < cols; j++) {\r\n//       table += `<td style=\"word-wrap: break-word; \r\n//                         word-break: break-all; \r\n//                         white-space: normal; \r\n//                         min-width: ${cellMinWidth}px;\r\n//                         display: table-cell !important;\r\n//                         position: static !important;\">&nbsp;</td>`;\r\n//     }\r\n//     table += \"</tr>\";\r\n//   }\r\n//   table += `</tbody></table><br/>`;\r\n\r\n//   const editor = document.getElementById(\"editor\");\r\n//   if (editor) {\r\n//     editor.focus();\r\n//     document.execCommand(\"insertHTML\", false, table);\r\n//   }\r\n\r\n//   this.tableAdded = true;\r\n//   this.checkTableSelection();\r\n\r\n//   // Add styles to prevent table structure breaking\r\n//   const style = document.createElement(\"style\");\r\n//   style.innerHTML = `\r\n//   #customTable {\r\n//     table-layout: fixed !important;\r\n//     border-collapse: collapse !important;\r\n//   }\r\n//   #customTable tr {\r\n//     display: table-row !important;\r\n//   }\r\n//   #customTable td {\r\n//     display: table-cell !important;\r\n//     position: static !important;\r\n//   }\r\n//   #customTable .header-cell {\r\n//     position: static !important;\r\n//   }\r\n//   #customTable .header-cell > span {\r\n//     display: inline !important;\r\n//     position: static !important;\r\n//   }\r\n//   #customTable .header-cell:hover {\r\n//     cursor: default !important;\r\n//   }\r\n// `;\r\n//   document.head.appendChild(style);\r\n// }\r\n\r\naddTable() {\r\n  const tableWidth = 825;\r\n  const cols = 3;\r\n  const cellMinWidth = tableWidth / cols;\r\n\r\n  let table = `<br /><table id=\"customTable\" style=\"width: ${tableWidth}px; border-collapse: collapse;\">`;\r\n  table += `<tbody>`;\r\n\r\n  // Table Header Row\r\n  table += `<tr id=\"tableHeaderRow\" style=\"border-bottom: ${this.themeModeClrVerticalLineForTable()};\" onclick=\"checkTableSelection()\">`;\r\n\r\n  for (let j = 0; j < cols; j++) {\r\n    table += `<td class=\"header-cell\" \r\n              style=\"border-top: 2px solid black; \r\n                     font-weight: bold; \r\n                     text-align: start; \r\n                     word-wrap: break-word; \r\n                     word-break: break-all; \r\n                     white-space: normal; \r\n                     min-width: ${cellMinWidth}px; \r\n                     background-color: inherit !important; \r\n                     display: table-cell !important;\r\n                     position: static !important;\r\n                     height:28px;\"></td>`;\r\n  }\r\n\r\n  // Properly closing the header row\r\n  table += `</tr>`;\r\n\r\n  // Data Rows\r\n  for (let i = 0; i < 3; i++) {\r\n    table += `<tr style=\"border-bottom: ${this.themeModeClrVerticalLineForTable()}\">`;\r\n    for (let j = 0; j < cols; j++) {\r\n      table += `<td style=\"word-wrap: break-word; \r\n                        word-break: break-all; \r\n                        white-space: normal; \r\n                        min-width: ${cellMinWidth}px;\r\n                        display: table-cell !important;\r\n                        position: static !important;\">&nbsp;</td>`;\r\n    }\r\n    table += `</tr>`;\r\n  }\r\n\r\n  table += `</tbody></table><br/>`;\r\n\r\n  // Inserting into the editor\r\n  const editor = document.getElementById(\"editor\");\r\n  if (editor) {\r\n    editor.focus();\r\n    document.execCommand(\"insertHTML\", false, table);\r\n  }\r\n\r\n  this.tableAdded = true;\r\n  this.checkTableSelection();\r\n\r\n  // Add styles to prevent table structure breaking\r\n  const style = document.createElement(\"style\");\r\n  style.innerHTML = `\r\n  #customTable {\r\n    table-layout: fixed !important;\r\n    border-collapse: collapse !important;\r\n  }\r\n  #customTable tr {\r\n    display: table-row !important;\r\n  }\r\n  #customTable td {\r\n    display: table-cell !important;\r\n    position: static !important;\r\n  }\r\n  #customTable .header-cell {\r\n    position: static !important;\r\n  }\r\n  #customTable .header-cell > span {\r\n    display: inline !important;\r\n    position: static !important;\r\n  }\r\n  #customTable .header-cell:hover {\r\n    cursor: default !important;\r\n  }\r\n`;\r\n  document.head.appendChild(style);\r\n}\r\n\r\n\r\n// Function to change the first row (thead) background color\r\nsetTheadBgColor(event: any) {\r\n  const selectedColor = event.target.value;\r\n\r\n  if (this.selectedTable) {\r\n    const headerRow = this.selectedTable.querySelector(\"tr\") as HTMLElement;\r\n\r\n    if (headerRow) {\r\n      const headerCells = headerRow.querySelectorAll(\".header-cell\");\r\n      headerCells.forEach((cell: Element) => {\r\n        (cell as HTMLElement).style.backgroundColor = selectedColor;\r\n      });\r\n    }\r\n  }\r\n}\r\n\r\n\r\n\r\n  checkTableSelection(event?: MouseEvent) {\r\n    let target = event?.target as HTMLElement;\r\n    if (target && (target.tagName === 'TD' || target.tagName === 'TH')) {\r\n      this.isTableSelected = true;\r\n      this.selectedTable = target.closest('table') as HTMLTableElement;\r\n    } else {\r\n      this.isTableSelected = false;\r\n      this.selectedTable = null;\r\n    }\r\n    \r\n    // this.checkPlaceholder();\r\n  }\r\n\r\n  checkPlaceholder() {\r\n    // let editor = document.getElementById('editor');\r\n    // if (editor) {\r\n    //   this.isPlaceholderVisible = editor.innerHTML === '' || editor.innerHTML === '<br>';\r\n    //   if (this.isPlaceholderVisible) {\r\n    //     // editor.innerHTML = '<span class=\"placeholder\" style=\"background: transparent; color: #000000\">Insert text here ...</span>';\r\n    //   } else {\r\n    //     let placeholder = editor.querySelector('.placeholder');\r\n    //     if (placeholder) {\r\n    //       editor.removeChild(placeholder);\r\n    //     }\r\n    //   }\r\n    // }\r\n  }\r\n\r\n  onFocus() {\r\n    // let editor = document.getElementById('editor');\r\n    // if (editor && this.isPlaceholderVisible) {\r\n    //   editor.innerHTML = '';\r\n    //   this.isPlaceholderVisible = false;\r\n    // }\r\n  }\r\n\r\n  // colorChange(newColor: string) {\r\n  //   this.color = newColor;\r\n  // }\r\n\r\n  onBlur() {\r\n    this.checkPlaceholder();\r\n  }\r\n\r\n  // addRow() {\r\n  //   if (this.selectedTable) {\r\n  //     let row = this.selectedTable.insertRow();\r\n  //     for (let i = 0; i < this.selectedTable.rows[0].cells.length; i++) {\r\n  //       let cell = row.insertCell(i);\r\n  //       cell.innerHTML = '&nbsp;';\r\n  //       cell.style.border = '1px solid black';\r\n  //     }\r\n  //   }\r\n  // }\r\n\r\n  addRow() {\r\n  if (this.selectedTable) {\r\n    let row = this.selectedTable.insertRow();\r\n\r\n    // Loop through the columns of the first row to determine the number of cells\r\n    for (let i = 0; i < this.selectedTable.rows[0].cells.length; i++) {\r\n      let cell = row.insertCell(i);\r\n      cell.innerHTML = '&nbsp;';\r\n\r\n      // Apply bottom border explicitly\r\n      cell.style.borderBottom = `2px solid ${this.themeModeClrVerticalLineColorForTable()}`; // You can replace 'black' with your theme color\r\n    }\r\n  }\r\n}\r\n\r\n//   addRow() {\r\n//   if (this.selectedTable) {\r\n//     let row = this.selectedTable.insertRow();\r\n//     row.style.borderBottom = this.themeModeClrVerticalLineForTable(); // Add bottom border to the row\r\n//     for (let i = 0; i < this.selectedTable.rows[0].cells.length; i++) {\r\n//       let cell = row.insertCell(i);\r\n//       cell.innerHTML = '&nbsp;';\r\n//     }\r\n//   }\r\n// }\r\n\r\n\r\n  // deleteRow() {\r\n  //   if (this.selectedTable) {\r\n  //     this.selectedTable.deleteRow(-1);\r\n  //   }\r\n  // }\r\n\r\n//   deleteRow() {\r\n//   if (this.selectedTable) {\r\n//     let rowIndex = this.selectedTable.rows.length - 1; \r\n//     if (window.getSelection) {\r\n//       let selection = window.getSelection();\r\n//       if (selection) {\r\n//         let row = selection.anchorNode?.parentElement?.closest('tr');\r\n//         if (row) {\r\n//           rowIndex = row.rowIndex;\r\n//         }\r\n//       }\r\n//     }\r\n//     this.selectedTable.deleteRow(rowIndex);\r\n//   }\r\n// }\r\n\r\n  deleteRow() {\r\n  const selection = window.getSelection();\r\n    if (selection) {\r\n    if (!selection.rangeCount) return;\r\n\r\n    const range = selection.getRangeAt(0);\r\n    const selectedNode = range.startContainer;\r\n    const row = selectedNode.parentElement?.closest('tr');\r\n\r\n    if (row) {\r\n      const table = row.closest('table');\r\n      if (table) {\r\n        table.deleteRow(row.rowIndex);\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n\r\n  // addColumn() {\r\n  //   if (this.selectedTable) {\r\n  //     for (let i = 0; i < this.selectedTable.rows.length; i++) {\r\n  //       let cell = this.selectedTable.rows[i].insertCell(-1);\r\n  //       cell.innerHTML = '&nbsp;';\r\n  //       cell.style.border = '1px solid black';\r\n  //     }\r\n  //   }\r\n  // }\r\n\r\n//   addColumn() {\r\n//   if (this.selectedTable) {\r\n//     const columnCount = this.selectedTable.rows[0].cells.length + 1; // New column count\r\n//     const tableWidth = this.selectedTable.offsetWidth;\r\n//     const minWidth = tableWidth / columnCount;\r\n\r\n//     for (let i = 0; i < this.selectedTable.rows.length; i++) {\r\n//       let cell = this.selectedTable.rows[i].insertCell(-1);\r\n//       cell.innerHTML = '&nbsp;';\r\n//       cell.style.border = '1px solid black';\r\n//       cell.style.minWidth = `${minWidth}px`;\r\n//       cell.style.wordWrap = 'break-word';\r\n//       cell.style.wordBreak = 'break-all';\r\n//       cell.style.whiteSpace = 'normal';\r\n//     }\r\n\r\n//     // Update existing cells' minWidth\r\n//     for (let i = 0; i < this.selectedTable.rows.length; i++) {\r\n//       for (let j = 0; j < this.selectedTable.rows[i].cells.length; j++) {\r\n//         this.selectedTable.rows[i].cells[j].style.minWidth = `${minWidth}px`;\r\n//       }\r\n//     }\r\n//   }\r\n  // }\r\n  \r\n  // addColumn() {\r\n  // if (this.selectedTable) {\r\n  //   const columnCount = this.selectedTable.rows[0].cells.length + 1; // New column count\r\n  //   const tableWidth = this.selectedTable.offsetWidth;\r\n  //   const minWidth = tableWidth / columnCount;\r\n\r\n  //   for (let i = 0; i < this.selectedTable.rows.length; i++) {\r\n  //     let cell = this.selectedTable.rows[i].insertCell(-1);\r\n  //     cell.innerHTML = '&nbsp;';\r\n  //     cell.style.wordWrap = 'break-word';\r\n  //     cell.style.wordBreak = 'break-all';\r\n  //     cell.style.whiteSpace = 'normal';\r\n  //     cell.style.minWidth = `${minWidth}px`;\r\n  //     cell.style.borderBottom = `2px solid ${this.themeModeClrVerticalLineColorForTable()}`\r\n  //   }\r\n\r\n  //   // Update existing rows' bottom border\r\n  //   for (let i = 0; i < this.selectedTable.rows.length; i++) {\r\n  //     this.selectedTable.rows[i].style.borderBottom = this.themeModeClrVerticalLineForTable();\r\n  //   }\r\n  // }\r\n  // }\r\n\r\n  addColumn() {\r\n    if (this.selectedTable) {\r\n      const columnCount = this.selectedTable.rows[0].cells.length + 1; // New column count\r\n      const tableWidth = this.selectedTable.offsetWidth;\r\n      const minWidth = tableWidth / columnCount;\r\n\r\n      // Get the current header background color if any\r\n      const firstHeaderCell = this.selectedTable.rows[0]\r\n        .cells[0] as HTMLElement;\r\n      const headerBgColor = firstHeaderCell\r\n        ? firstHeaderCell.style.backgroundColor\r\n        : \"\";\r\n\r\n      for (let i = 0; i < this.selectedTable.rows.length; i++) {\r\n        let cell = this.selectedTable.rows[i].insertCell(-1);\r\n        cell.innerHTML = \"&nbsp;\";\r\n        cell.style.wordWrap = \"break-word\";\r\n        cell.style.wordBreak = \"break-all\";\r\n        cell.style.whiteSpace = \"normal\";\r\n        cell.style.minWidth = `${minWidth}px`;\r\n        cell.style.borderBottom = \"1px solid #d3d3d3\";\r\n\r\n        // cell.style.borderBottom = `2px solid ${this.themeModeClrVerticalLineColorForTable()}`;\r\n\r\n        // If it's the first row, make it a header cell\r\n        if (i === 0) {\r\n          cell.classList.add(\"header-cell\");\r\n          cell.style.fontWeight = \"bold\";\r\n          cell.style.textAlign = \"start\";\r\n          cell.style.pointerEvents = \"none\";\r\n          cell.style.display = \"table-cell\";\r\n          cell.style.position = \"static\";\r\n          cell.style.borderTop = \"2px solid black\";\r\n          // cell.innerText = `Header ${columnCount}`;\r\n\r\n          // Apply the same background color as existing headers\r\n          if (headerBgColor) {\r\n            cell.style.backgroundColor = headerBgColor;\r\n          }\r\n        }\r\n      }\r\n\r\n      // Update existing rows' bottom border\r\n      // for (let i = 0; i < this.selectedTable.rows.length; i++) {\r\n      //   this.selectedTable.rows[i].style.borderBottom =\r\n      //     this.themeModeClrVerticalLineForTable();\r\n      // }\r\n      for (let i = 0; i < this.selectedTable.rows.length; i++) {\r\n        for (let j = 0; j < this.selectedTable.rows[i].cells.length; j++) {\r\n          this.selectedTable.rows[i].cells[j].style.borderBottom = \"1px solid #d3d3d3\";\r\n        }\r\n      }\r\n    }\r\n  }\r\n  \r\n\r\n\r\n\r\n\r\n  deleteColumn() {\r\n  if (this.selectedTable) {\r\n    if (window.getSelection) {\r\n      let selection = window.getSelection();\r\n      if (selection) {\r\n        let cell = selection.anchorNode?.parentElement?.closest('td, th') as HTMLTableCellElement;\r\n        if (cell) {\r\n          let cellIndex = cell.cellIndex;\r\n          for (let i = 0; i < this.selectedTable.rows.length; i++) {\r\n            this.selectedTable.rows[i].deleteCell(cellIndex);\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n  themeModeClrVerticalLineForTable() {\r\n    const clrMode = document.body.getAttribute('data-layout-color')\r\n    if (clrMode == 'dark') {\r\n      return '2px solid #414141 !important'\r\n    } else {\r\n      return '2px solid #5F5F5F !important'\r\n    }\r\n  }\r\n\r\n  themeModeClrVerticalLineColorForTable() {\r\n    const clrMode = document.body.getAttribute('data-layout-color')\r\n    if (clrMode == 'dark') {\r\n      return '#414141'\r\n    } else {\r\n      return '#5F5F5F'\r\n    }\r\n  }\r\n\r\n  adjustTableWidth(event: any) {\r\n    if (this.selectedTable) {\r\n      this.selectedTable.style.width = event.target.value + 'px';\r\n    }\r\n  }\r\n\r\n  adjustCellWidth(event: any) {\r\n    if (this.selectedTable) {\r\n      for (let i = 0; i < this.selectedTable.rows.length; i++) {\r\n        for (let j = 0; j < this.selectedTable.rows[i].cells.length; j++) {\r\n          this.selectedTable.rows[i].cells[j].style.width = event.target.value + 'px';\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  adjustCellHeight(event: any) {\r\n    if (this.selectedTable) {\r\n      for (let i = 0; i < this.selectedTable.rows.length; i++) {\r\n        for (let j = 0; j < this.selectedTable.rows[i].cells.length; j++) {\r\n          this.selectedTable.rows[i].cells[j].style.height = event.target.value + 'px';\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  private setCaretToEnd(element: HTMLElement) {\r\n    const range = document.createRange();\r\n    const sel = window.getSelection();\r\n      if (sel) {\r\n      range.selectNodeContents(element);\r\n    range.collapse(false);\r\n    sel.removeAllRanges();\r\n    sel.addRange(range);\r\n    }\r\n  }\r\n\r\n  // openColorPicker(inputId: string) {\r\n  //   const inputElement = document.getElementById(inputId);\r\n  //   if (inputElement) {\r\n  //     inputElement.click();\r\n  //   }\r\n  // }\r\n\r\n  // setTextColor(event: any) {\r\n  //   const editor = document.getElementById('editor');\r\n  //   if (editor) {\r\n  //     editor.focus();\r\n  //     const color = event.target.value;\r\n  //     this.selectedTextColor = color;\r\n  //     document.execCommand('foreColor', false, color);\r\n  //   }\r\n  // }\r\n\r\n  // setBackgroundColor(event: any) {\r\n  //   const editor = document.getElementById('editor');\r\n  //   if (editor) {\r\n  //     editor.focus();\r\n  //     const color = event.target.value;\r\n  //     this.backgroundColor = color;\r\n  //     document.execCommand('hiliteColor', false, color);\r\n  //   }\r\n  // }\r\n\r\n  private savedSelection: Range | null = null;\r\n\r\nopenColorPicker(inputId: string) {\r\n  const inputElement = document.getElementById(inputId) as HTMLInputElement;\r\n  if (inputElement) {\r\n    // Save the current selection\r\n    const selection = window.getSelection();\r\n    if (selection && selection.rangeCount > 0) {\r\n      this.savedSelection = selection.getRangeAt(0);\r\n    }\r\n    inputElement.click();\r\n  }\r\n}\r\n\r\n// setTextColor(event: any) {\r\n//   if (this.savedSelection) {\r\n//     const color = event.target.value;\r\n//     this.selectedTextColor = color;\r\n\r\n//     // Restore the saved selection\r\n//     const selection = window.getSelection();\r\n//     if (selection) {\r\n//       selection.removeAllRanges();\r\n//       selection.addRange(this.savedSelection);\r\n\r\n//       // Apply the color using a span\r\n//       const range = this.savedSelection;\r\n//       const span = document.createElement('span');\r\n//       span.style.color = color;\r\n//       span.textContent = range.toString();\r\n\r\n//       // Replace the selected text with the styled span\r\n//       range.deleteContents();\r\n//       range.insertNode(span);\r\n\r\n//       // Clear the saved selection\r\n//       this.savedSelection = null;\r\n//     }\r\n//   }\r\n  // }\r\n//   setTextColor(event: any) {\r\n//   if (this.savedSelection) {\r\n//     const color = event.target.value;\r\n//     this.selectedTextColor = color;\r\n\r\n//     // Restore the saved selection\r\n//     const selection = window.getSelection();\r\n//     if (selection && selection.rangeCount > 0) {\r\n//       const range = this.savedSelection;\r\n//       selection.removeAllRanges();\r\n//       selection.addRange(range);\r\n\r\n//       // Get selected elements\r\n//       const selectedContent = range.cloneContents();\r\n//       const elements = Array.from(selectedContent.querySelectorAll(\"*\")) as HTMLElement[]; // ✅ Explicitly cast to HTMLElement[]\r\n\r\n//       // Apply color to each element without modifying structure\r\n//       elements.forEach((el) => {\r\n//         el.style.color = color;\r\n//       });\r\n\r\n//       // Apply color to the top-level text nodes (without wrapping them)\r\n//       Array.from(selectedContent.childNodes).forEach((node) => {\r\n//         if (node.nodeType === Node.TEXT_NODE && node.textContent?.trim() !== \"\") {\r\n//           const parent = range.commonAncestorContainer.parentElement;\r\n//           if (parent) {\r\n//             parent.style.color = color;\r\n//           }\r\n//         }\r\n//       });\r\n\r\n//       // Replace selected content\r\n//       range.deleteContents();\r\n//       range.insertNode(selectedContent);\r\n\r\n//       // Clear saved selection\r\n//       this.savedSelection = null;\r\n//     }\r\n//   }\r\n// }\r\n\r\nsetTextColor(event: any) {\r\n  console.log(\"Clicked setTextColor\");\r\n  if (!this.savedSelection) {\r\n    console.warn(\"No saved selection available!\");\r\n    return;\r\n  }\r\n\r\n  const color = event.target.value;\r\n  this.selectedTextColor = color;\r\n  const selection = window.getSelection();\r\n\r\n  if (!selection || selection.rangeCount === 0) {\r\n    console.error(\"No valid selection found!\");\r\n    return;\r\n  }\r\n\r\n  selection.removeAllRanges();\r\n  selection.addRange(this.savedSelection);\r\n  const range = this.savedSelection;\r\n\r\n  const getTableCell = (node: Node | null): HTMLElement | null => {\r\n    let currentNode = node;\r\n    if (currentNode && currentNode.nodeType === Node.TEXT_NODE) {\r\n      currentNode = currentNode.parentNode;\r\n    }\r\n\r\n    while (currentNode && currentNode instanceof HTMLElement) {\r\n      if (currentNode.tagName === \"TD\" || currentNode.tagName === \"TH\") {\r\n        return currentNode;\r\n      }\r\n      currentNode = currentNode.parentElement;\r\n    }\r\n    return null;\r\n  };\r\n\r\n  const tableCell =\r\n    getTableCell(range.commonAncestorContainer) ||\r\n    getTableCell(range.startContainer) ||\r\n    getTableCell(range.endContainer);\r\n\r\n  if (tableCell) {\r\n    console.log(`Processing ${tableCell.tagName} element`);\r\n    const selectedText = selection.toString();\r\n\r\n    if (selectedText) {\r\n      console.log(`Selected text in ${tableCell.tagName}:`, selectedText);\r\n      const textNodes: Text[] = [];\r\n      const walker = document.createTreeWalker(\r\n        tableCell,\r\n        NodeFilter.SHOW_TEXT,\r\n        null\r\n      );\r\n      let node: Text | null;\r\n\r\n      while ((node = walker.nextNode() as Text | null)) {\r\n        textNodes.push(node);\r\n      }\r\n\r\n      for (const textNode of textNodes) {\r\n        const text = textNode.textContent || \"\";\r\n        const index = text.indexOf(selectedText);\r\n\r\n        if (index !== -1) {\r\n          console.log(\r\n            `Found selected text in ${tableCell.tagName} text node`\r\n          );\r\n\r\n          const span = document.createElement(\"span\");\r\n          span.style.color = color;\r\n          span.textContent = selectedText;\r\n\r\n          const beforeText = text.slice(0, index);\r\n          const afterText = text.slice(index + selectedText.length);\r\n\r\n          const fragment = document.createDocumentFragment();\r\n          if (beforeText)\r\n            fragment.appendChild(document.createTextNode(beforeText));\r\n          fragment.appendChild(span);\r\n          if (afterText)\r\n            fragment.appendChild(document.createTextNode(afterText));\r\n\r\n          textNode.replaceWith(fragment);\r\n          break; // Apply only once per selection\r\n        }\r\n      }\r\n    }\r\n  } else {\r\n    console.log(\"No TH or TD element found in selection\");\r\n    return;\r\n  }\r\n\r\n  this.savedSelection = null;\r\n}\r\n\r\n  setBackgroundColor(event: any) {\r\n  if (this.savedSelection) {\r\n    const color = event.target.value;\r\n    this.backgroundColor = color;\r\n\r\n    // Restore the saved selection\r\n    const selection = window.getSelection();\r\n    if (selection) {\r\n      selection.removeAllRanges();\r\n      selection.addRange(this.savedSelection);\r\n\r\n      // Apply the background color using a span\r\n      const range = this.savedSelection;\r\n      const span = document.createElement('span');\r\n      span.style.backgroundColor = color;\r\n      span.textContent = range.toString();\r\n\r\n      // Replace the selected text with the styled span\r\n      range.deleteContents();\r\n      range.insertNode(span);\r\n\r\n      // Clear the saved selection\r\n      this.savedSelection = null;\r\n    }\r\n  }\r\n  }\r\n  \r\n  // colorChanged(event: any) {\r\n  //   this.color = event.color.hex; \r\n  // }\r\n\r\n  public logEvent(event: any, trigger: any) {\r\n    const color = event;\r\n    this.setTextColor(color)\r\n    this.selectedTextColor = event\r\n    document.execCommand('foreColor', false, event);\r\n    // this.logs.unshift([this.logs.length + 1, trigger, event]);\r\n  }\r\n  \r\n\r\n  editImage() {\r\n    let data \r\n    switch (this.editorFrom.name) {\r\n      case 'section-content':\r\n        data = { editIMG: true, from: 'htmlEditor', index: this.selectedItemIndex, id: this.editorFrom.id };\r\n        const compressedData: string = compress(JSON.stringify(this.imageEditUrl));\r\n        sessionStorage.setItem('editImageFromTemp', compressedData);\r\n        const compressedData2 = compress(JSON.stringify(this.sanitizedContent));\r\n        sessionStorage.setItem('textEditor', compressedData2);\r\n        // alert('go to editor!')\r\n        this.navigateToIMGEditor(data);\r\n        this.imageEdit.emit()\r\n        break;\r\n      case 'create-document':\r\n        this.imageEdit.emit()\r\n        data = { editIMG: true, from: 'createDocument', index: this.selectedItemIndex, id: this.editorFrom.id, section: this.editorFrom.section, reportSectionId: this.editorFrom.reportSectionId };\r\n        // this.openDialog(data)\r\n        const compressedData3 = compress(JSON.stringify(this.imageEditUrl));\r\n        const compressedData4 = compress(this.editorText);\r\n\r\n        sessionStorage.setItem('editImageFromTemp2', compressedData3);\r\n        sessionStorage.setItem('textEditor2', compressedData4);\r\n        this.navigateToIMGEditor(data);\r\n        break;\r\n      default:\r\n        null\r\n        // sessionStorage.removeItem('editImageFromTemp');\r\n        // sessionStorage.removeItem('editImageFromTemp2');\r\n        // sessionStorage.removeItem('templateEditor');\r\n        // sessionStorage.removeItem('textEditor');\r\n        break;\r\n    }\r\n    // if (this.editorFrom === 'section-content') {\r\n    //   const data = {editIMG: true, from: 'htmlEditor', index: this.selectedItemIndex}\r\n    //   this.navigateToIMGEditor(data)\r\n    //   sessionStorage.setItem('editImageFromTemp', JSON.stringify(this.imageEditUrl))\r\n    //   sessionStorage.setItem('textEditor', this.editorText)\r\n    // } \r\n    \r\n  }\r\n\r\n  openDialog( item: any): void {\r\n    // let data: any;\r\n    //   data = item\r\n    // const dialogRef = this.dialog.open(ImageEditorModalComponent,{\r\n    //   minWidth: '100%', minHeight: '100vh', panelClass: 'theme-2B2936' ,disableClose: true, data: data\r\n    // });\r\n    // dialogRef.afterClosed().subscribe(result => {\r\n    //   console.log('result ===> img = ', result)\r\n    //   const imgUrl = sessionStorage.getItem('editImageFromTemp2');\r\n    //     if (imgUrl) {\r\n    //       this.replaceImageSrc(imgUrl,  result.index.index);\r\n    //       sessionStorage.removeItem('editImageFromTemp2');\r\n    //     }\r\n    // });\r\n  }\r\n\r\n  replaceImageSRC(newSrc: string, index: number) {\r\n    const parser = new DOMParser();\r\n    const doc = parser.parseFromString(this.editorText, 'text/html');\r\n    const imgTags = doc.getElementsByTagName('img');\r\n\r\n  if (imgTags && imgTags.length > 0) {\r\n    if (index >= 0 && index < imgTags.length) {\r\n      // Update the src attribute of the img at the specified index\r\n      \r\n      imgTags[index].setAttribute('src', newSrc);\r\n      this.editorText = doc.body.innerHTML;\r\n    \r\n    } \r\n  } \r\n  }\r\n\r\n  navigateToIMGEditor(data: any) {\r\n    this.router.navigate(['/admin/image-editor'], { queryParams: {data : JSON.stringify(data)} })\r\n  }\r\n\r\n  //  onTextSelect(event: MouseEvent): void {\r\n  //   if (this.toolbarMode === 'bubble') {\r\n  //     const selection = window.getSelection();\r\n  //     if (selection && selection.rangeCount > 0) {\r\n  //       const range = selection.getRangeAt(0);\r\n  //       if (!range.collapsed) {\r\n  //         const rect = range.getBoundingClientRect();\r\n  //         this.toolbarTop = rect.bottom + window.scrollY + 10;\r\n  //         this.toolbarLeft = rect.left + window.scrollX + (rect.width / 2) - 50;\r\n  //         this.showToolbar = true;\r\n  //       } else {\r\n  //         this.showToolbar = false;\r\n  //       }\r\n  //     }\r\n  //   }\r\n  // }\r\n\r\n onTextSelect(event?: MouseEvent): void {\r\n  if (this.toolbarMode === 'bubble') {\r\n    const selection = window.getSelection();\r\n    if (selection && selection.rangeCount > 0) {\r\n      const range = selection.getRangeAt(0);\r\n      if (!range.collapsed) {\r\n        const rect = range.getBoundingClientRect();\r\n        const scrollY =  document.documentElement.scrollTop;\r\n        const scrollX =  document.documentElement.scrollLeft;\r\n        this.toolbarTop = rect.top + scrollY - 75;\r\n        this.toolbarLeft = rect.left + scrollX + (rect.width / 2) - 325;\r\n        this.showToolbar = true;\r\n      } else {\r\n        this.showToolbar = false;\r\n      }\r\n    } else {\r\n      this.showToolbar = false;\r\n    }\r\n  }\r\n}\r\n\r\n\r\n// onPaste(event: ClipboardEvent) {\r\n//     event.preventDefault();\r\n//     const clipboardData = event.clipboardData;\r\n//     if (clipboardData) {\r\n//       const pastedText = clipboardData.getData('text/plain');\r\n//       if (this.isTableData(pastedText)) {\r\n//         const html = this.convertTextToTable(pastedText);\r\n//         this.insertHtmlAtCaret(html);\r\n//       } else {\r\n//         this.insertHtmlAtCaret(pastedText);\r\n//       }\r\n//     }\r\n//   }\r\n\r\n  // onPaste(event: ClipboardEvent) {\r\n  //   event.preventDefault();\r\n  //   const clipboardData = event.clipboardData;\r\n  //   if (clipboardData) {\r\n  //     // Handle image data\r\n  //     const items = clipboardData.items;\r\n  //     for (let i = 0; i < items.length; i++) {\r\n  //       if (items[i].type.startsWith('image/')) {\r\n  //         const file = items[i].getAsFile();\r\n  //         if (file) {\r\n  //           const reader = new FileReader();\r\n  //           reader.onload = (e: any) => {\r\n  //             const imgHtml = `<img src=\"${e.target.result}\" alt=\"Pasted Image\" style=\"max-width: 100%;\"/>`;\r\n  //             this.insertHtmlAtCaret(imgHtml);\r\n  //           };\r\n  //           reader.readAsDataURL(file);\r\n  //           return; // Exit if an image is handled\r\n  //         }\r\n  //       }\r\n  //     }\r\n\r\n  //     // Handle text or table data\r\n  //     const pastedText = clipboardData.getData('text/plain');\r\n  //     if (this.isTableData(pastedText)) {\r\n  //       const html = this.convertTextToTable(pastedText);\r\n  //       this.insertHtmlAtCaret(html);\r\n  //     } else {\r\n  //       this.insertHtmlAtCaret(pastedText);\r\n  //     }\r\n  //   }\r\n  // }\r\n\r\n  onPaste(event: ClipboardEvent) {\r\n    event.preventDefault();\r\n    const clipboardData = event.clipboardData;\r\n    if (clipboardData) {\r\n      for (let i = 0; i < clipboardData.items.length; i++) {\r\n        const item = clipboardData.items[i];\r\n\r\n        if (item.type.startsWith(\"image/\")) {\r\n          // Handle image paste\r\n          const file = item.getAsFile();\r\n          if (file) {\r\n            const reader = new FileReader();\r\n            reader.onload = (e: any) => {\r\n              const imgHtml = `<img src=\"${e.target.result}\" alt=\"Pasted Image\" style=\"max-width: 100%;\" />`;\r\n              this.insertHtmlAtCaret(imgHtml);\r\n            };\r\n            reader.readAsDataURL(file);\r\n            return;\r\n          }\r\n        } else if (item.type === \"text/html\") {\r\n          // Handle HTML paste\r\n          // const htmlData = clipboardData.getData(\"text/html\");\r\n          if (this.isTableData(clipboardData.getData('text/html'))) {\r\n            const html = this.convertTextToTable(clipboardData.getData('text/html'));\r\n            this.insertHtmlAtCaret(html);\r\n          } else {\r\n            this.insertHtmlAtCaret(clipboardData.getData('text/html'));\r\n          }\r\n          // this.insertHtmlAtCaret(htmlData);\r\n          return;\r\n        } else if (item.type === \"text/plain\") {\r\n          // Handle plain text paste\r\n          if (this.isTableData(clipboardData.getData('text/plain'))) {\r\n            const html = this.convertTextToTable(clipboardData.getData('text/plain'));\r\n            this.insertHtmlAtCaret(html);\r\n          } else {\r\n            this.insertHtmlAtCaret(clipboardData.getData('text/plain'));\r\n          }\r\n          // const plainText = clipboardData.getData(\"text/plain\");\r\n          // this.insertHtmlAtCaret(plainText);\r\n          return;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  isExcelData(html: string): boolean {\r\n    return html.includes('xmlns:o=\"urn:schemas-microsoft-com:office:office\"') || \r\n          html.includes('xmlns:x=\"urn:schemas-microsoft-com:office:excel\"');\r\n  }\r\n\r\n  convertExcelHtmlToTable(html: string): string {\r\n    const parser = new DOMParser();\r\n    const doc = parser.parseFromString(html, 'text/html');\r\n    const table = doc.querySelector('table');\r\n    return table ? table.outerHTML : ''; // Extract only the table part\r\n  }\r\n\r\n\r\n\r\n\r\n  isTableData(text: string): boolean {\r\n    const rows = text.split('\\n');\r\n    return rows.length > 1 && rows[0].split('\\t').length > 1;\r\n  }\r\n\r\n  // convertTextToTable(text: string): string {\r\n  //   const rows = text.split('\\n').filter(row => row.trim() !== '');\r\n  //   const tableRows = rows.map(row => {\r\n  //     const cells = row.split('\\t').map(cell => `<td class=\"px-1 py-1\" >${cell}</td>`).join('');\r\n  //     return `<tr class=\"table-border-top\" style=\"border-top: ${this.themeModeTableBorderTop()}; width: 100% !important\">${cells}</tr>`;\r\n  //   }).join('');\r\n  //   return `<table>${tableRows}</table>`;\r\n  // }\r\n\r\n  convertTextToTable(text: string): string {\r\n    const rows = text.split('\\n').filter(row => row.trim() !== '');\r\n    const columnCount = rows[0]?.split('\\t').length || 1; // Get the number of columns from the first row\r\n    const columnWidth = 100 / columnCount; // Calculate column width\r\n\r\n    const tableRows = rows.map((row, index) => {\r\n      const cells = row.split('\\t').map(cell => `\r\n        <td class=\"px-1 py-1 text-truncate\" \r\n            style=\"max-width: ${columnWidth}%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;\">\r\n          ${cell}\r\n        </td>`).join('');\r\n\r\n      // Add a border-top for all rows except the first and border-bottom for the last row\r\n      const borderTop = index === 0 ? '' : `border-top: ${this.themeModeTableBorderTop()};`;\r\n      const borderBottom = index === rows.length - 1 ? `border-bottom: ${this.themeModeTableBorderTop()};` : '';\r\n\r\n      return `\r\n        <tr \r\n          style=\"${borderTop} ${borderBottom} width: 100% !important;\">\r\n          ${cells}\r\n        </tr>`;\r\n    }).join('');\r\n\r\n    return `\r\n      <table style=\"table-layout: fixed; width: 100%;\"> \r\n        ${tableRows}\r\n      </table>`;\r\n  }\r\n\r\n\r\n\r\n  insertHtmlAtCaret(html: string) {\r\n    const range = window.getSelection()?.getRangeAt(0);\r\n    if (range) {\r\n      range.deleteContents();\r\n      const tempDiv = document.createElement('div');\r\n      tempDiv.innerHTML = html;\r\n      const frag = document.createDocumentFragment();\r\n      let node;\r\n      while ((node = tempDiv.firstChild)) {\r\n        frag.appendChild(node);\r\n      }\r\n      range.insertNode(frag);\r\n      range.collapse(false);\r\n    }\r\n  }\r\n\r\n  themeModeTableBorderTop() {\r\n    const clrMode = document.body.getAttribute('data-layout-color')\r\n    if (clrMode == 'dark') {\r\n      return '1px solid #D0D0D0; !important'\r\n    } else {\r\n      return '1px solid #414141 !important'\r\n    }\r\n  }\r\n\r\n \r\n  public openFullscreen() {\r\n    var elem: any = document.getElementById(\"textEditor\");\r\n    this.isFullScreen = true;\r\n    if (elem.requestFullscreen) {\r\n      elem.requestFullscreen();\r\n    } else if (elem.mozRequestFullScreen) {\r\n      elem.mozRequestFullScreen();\r\n    } else if (elem.webkitRequestFullscreen) {\r\n      elem.webkitRequestFullscreen();\r\n    } else if (elem.msRequestFullscreen) {\r\n      elem.msRequestFullscreen();\r\n    }\r\n    this.style = {\r\n      'min-height': '90vh',\r\n      'max-height': '90vh',\r\n    }\r\n  }\r\n\r\n  public closeFullscreen() {\r\n    if (document.exitFullscreen) {\r\n      document.exitFullscreen();\r\n      this.isFullScreen = false;\r\n      this.style = {\r\n        'min-height': '400px',\r\n        'max-height': '400px',\r\n      }\r\n    }\r\n  }\r\n  \r\n  clearTextEditor() {\r\n    this.editorTextClear.emit()\r\n  }\r\n\r\n  setupHistory() {\r\n    this.saveState();\r\n     const editor = document.getElementById('editor');\r\n  \r\n    if (editor) {\r\n      editor.addEventListener('input', () => this.onInput());\r\n    }\r\n  }\r\n\r\n  onInput() {\r\n    this.saveState();\r\n  }\r\n\r\n  saveState() {\r\n    const editor = document.getElementById('editor');\r\n  \r\n    if (editor) {\r\n      const editorContent = editor.innerHTML;\r\n      if (this.historyIndex === this.history.length - 1) {\r\n        this.history.push(editorContent);\r\n        this.redoStack = [];\r\n      } else {\r\n        this.history = this.history.slice(0, this.historyIndex + 1);\r\n        this.history.push(editorContent);\r\n        this.redoStack = [];\r\n      }\r\n      this.historyIndex++;\r\n    }\r\n  }\r\n  undo() {\r\n    if (this.historyIndex > 0) {\r\n      this.redoStack.push(this.history[this.historyIndex]);\r\n      this.historyIndex--;\r\n      const editor = document.getElementById('editor');\r\n  \r\n      if (editor) {\r\n        this.sanitizedContent = this.history[this.historyIndex];\r\n      }\r\n    }\r\n  }\r\n\r\n  redo() {\r\n    if (this.redoStack.length > 0) {\r\n      const redoContent = this.redoStack.pop();\r\n      this.history.push(redoContent!);\r\n      this.historyIndex++;\r\n      const editor = document.getElementById('editor');\r\n  \r\n      if (editor) {\r\n        this.sanitizedContent = redoContent!;\r\n      }\r\n    }\r\n  }\r\n\r\n//   formatTextWithDates(text: string): string {\r\n//   // Regular expression to detect YYYY-MM-DD formatted dates\r\n//   const dateRegex = /\\b\\d{4}-\\d{2}-\\d{2}\\b/g;\r\n\r\n//   // Replace found dates with a formatted version\r\n//   return text.replace(dateRegex, (dateStr) => {\r\n//     // Convert the detected date string into a Date object\r\n//     const dateObj = new Date(dateStr);\r\n    \r\n//     // Format the date to 'Month Day, Year' (e.g., October 10, 2024)\r\n//     return dateObj.toLocaleDateString('en-US', {\r\n//       year: 'numeric',\r\n//       month: 'long',\r\n//       day: 'numeric',\r\n//     });\r\n//   });\r\n  // }\r\n  \r\n  formatTextWithDates(text: string): string {\r\n  // Regular expression to detect YYYY-MM-DD formatted dates\r\n  const dateRegex = /\\b\\d{4}-\\d{2}-\\d{2}\\b/g;\r\n\r\n  // Replace found dates with a formatted version\r\n  return text.replace(dateRegex, (dateStr) => {\r\n    // Convert the detected date string into a Date object\r\n    const dateObj = new Date(dateStr);\r\n\r\n    // Extract day, month, and year\r\n    const day = dateObj.getDate().toString().padStart(2, '0'); // Ensure day is two digits\r\n    const month = dateObj.toLocaleString('en-US', { month: 'short' }); // Get abbreviated month name\r\n    const year = dateObj.getFullYear(); // Get full year\r\n\r\n    // Format the date as 'dd/mmm/yyyy'\r\n    return `${day}/${month}/${year}`;\r\n  });\r\n}\r\n\r\n\r\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                    <button \r\n          \r\n          type=\"button\" \r\n          class=\"btn btn-white els-toolbar-button\" \r\n          *ngIf=\"isTableSelected\" \r\n          [style.color]=\"tHeadBgColor\" \r\n          (click)=\"openColorPicker('tHeadbgColorPicker')\" \r\n        > \r\n          <i class=\"mdi mdi-table-edit\"></i> \r\n        </button> \r\n        <input \r\n          type=\"color\" \r\n          id=\"tHeadbgColorPicker\" \r\n          style=\" \r\n            position: absolute; \r\n            top: 100%; \r\n            left: 0; \r\n            z-index: 100; \r\n            opacity: 0; \r\n          \" \r\n          (change)=\"setTheadBgColor($event)\" \r\n        />\r\n            </div>\r\n            <!-- <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Text Formatting\">\r\n                <button type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"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 [attr.contenteditable]=\"contentEditable\" 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)\" (keydown.Tab)=\"handleTabKey($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>"]}
2081
+ //# 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';\r\nimport { ControlValueAccessor, FormControl, NG_VALUE_ACCESSOR } from '@angular/forms';\r\n// import { MatDialog } from '@angular/material/dialog';\r\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\r\nimport { Router, ActivatedRoute } from '@angular/router';\r\nimport { NgxFullscreenDirective } from '@ultimate/ngx-fullscreen';\r\nimport * as XLSX from 'xlsx';\r\n// import { ImageEditorModalComponent } from '../modals/image-editor-modal/image-editor-modal.component';\r\nimport { compress, decompress } from 'lz-string';\r\n\r\n\r\n@Component({\r\n  selector: 'text-editor',\r\n  templateUrl: './el-text-editor.component.html',\r\n  styleUrls: ['./el-text-editor.component.scss'],\r\n    providers: [{\r\n    provide: NG_VALUE_ACCESSOR,\r\n    useExisting: forwardRef(() => ElTextEditorComponent),\r\n    multi: true\r\n  }]\r\n})\r\nexport class ElTextEditorComponent implements ControlValueAccessor, AfterViewInit, OnChanges {\r\n\r\n  @Input() editorText: string = '';\r\n  @Input() editorFrom: any;\r\n  @Input() editorAction: any;\r\n  @Input() UserRole: any;\r\n  @Input() style: any;\r\n  @Input() disableToolbar: any;\r\n  @Input() placeHolder: any;\r\n  @Input() reportId: any;\r\n  @Input() backgroundImage: any;\r\n  @Input() toolbarMode: 'fixed' | 'bubble' | 'none' = 'fixed';\r\n  @Input() contentEditable: boolean = true; // Input for initial value\r\n  @Output() contentEditableChange: EventEmitter<boolean> = new EventEmitter<boolean>(); // Output for changes\r\n  @Output() editorTextChange = new EventEmitter<string>();\r\n  @Output() editorActionResponse = new EventEmitter<any>();\r\n  @Output() editorTextClear = new EventEmitter<any>();\r\n  @Output() imageEdit = new EventEmitter<any>();\r\n  @Output() imageEdit2 = new EventEmitter<any>();\r\n  @Output() placeHolderRemove = new EventEmitter<any>();\r\n  @Output() isOpen = new EventEmitter<any>();\r\n  @Output() newImageAdded = new EventEmitter<any>();\r\n  \r\n  @Input() value: string = '';\r\n\r\n  \r\n  @ViewChild('textEditor') TextEditor!:  ElementRef<Element>;\r\n  @ViewChild('fullscreen') fullscreen!: NgxFullscreenDirective\r\n    \r\n  sanitizedContent!: SafeHtml;\r\n\r\n\r\n  showToolbar = false;\r\n  toolbarTop = 0;\r\n  toolbarLeft = 0;\r\n\r\n  fonts = ['Arial', 'Courier New', 'Georgia', 'Times New Roman', 'Verdana'];\r\n  fontSizes = [10, 12, 14, 16, 18, 20, 24, 28, 32, 36];\r\n  selectedFont = 'Arial';\r\n  selectedFontSize = 14;\r\n  isTableSelected = false;\r\n  tableAdded = false;\r\n  selectedTable: HTMLTableElement | null = null;\r\n  isPlaceholderVisible = true;\r\n  selectedCell: HTMLTableCellElement | null = null;\r\n  \r\n  isBoldActive: boolean = false;\r\n  isItalicActive: boolean = false;\r\n  isUnderlineActive: boolean = false;\r\n  isStrikethroughActive: boolean = false;\r\n  isSubscriptActive: boolean = false;\r\n  isSuperscriptActive: boolean = false;\r\n\r\n  selectedFormatBlock: string = 'normal'\r\n\r\n  selectedImage: HTMLImageElement | null = null;\r\n  imageEditUrl: string = '';\r\n  imagePositionX = 0;\r\n  imagePositionY = 0;\r\n  imageResizeStartX = 0;\r\n  imageResizeStartY = 0;\r\n  imageResizeStartWidth = 0;\r\n  imageResizeStartHeight = 0;\r\n  imageResizeDirection: 'topLeft' | 'topRight' | 'bottomLeft' | 'bottomRight' | null = null;\r\n\r\n  undoStack: string[] = [];\r\n  redoStack: string[] = [];\r\n  history: string[] = [];\r\n  historyIndex = -1;\r\n  // editorText1 = ``;\r\n  selectedTextColor: any;\r\n  onChange: any = () => {};\r\n  onTouched: any = () => {};\r\n  color: any = '#ddd';\r\n  colorFormControl!: FormControl;\r\n  backgroundColor: any;\r\n  selectedItemIndex: number | null = null;\r\n\r\n  parsedTable: { headers: string[], rows: string[][] } | null = null;\r\n\r\n  isFullScreen: boolean = false;\r\n  currentCaretPosition: any;\r\n  userRole: any[] = [];\r\n  showEditButton: boolean = false;\r\n  tHeadBgColor: any;\r\n\r\n  constructor(\r\n    private router: Router,\r\n    private route: ActivatedRoute,\r\n    private renderer: Renderer2,\r\n    private sanitizer: DomSanitizer,\r\n  ) {\r\n    this.getUserRoles()\r\n\r\n    \r\n  }\r\n\r\n  themeMode() {\r\n    const clrMode = document.body.getAttribute('data-layout-color')\r\n    if (clrMode == 'dark') {\r\n      return '2px solid #403F4A !important'\r\n    } else {\r\n      return '2px solid #D0D0D0 !important'\r\n    }\r\n  }\r\n\r\n  themeModeClr() {\r\n    const clrMode = document.body.getAttribute('data-layout-color')\r\n    if (clrMode == 'dark') {\r\n      return '#fff !important'\r\n    } else {\r\n      return '#000 !important'\r\n    }\r\n  }\r\n\r\n  themeModeClrVerticalLine() {\r\n    const clrMode = document.body.getAttribute('data-layout-color')\r\n    if (clrMode == 'dark') {\r\n      return '2px solid #FFFFFF !important'\r\n    } else {\r\n      return '2px solid #D0D0D0 !important'\r\n    }\r\n  }\r\n\r\n  themeModeBgClr() {\r\n    const clrMode = document.body.getAttribute('data-layout-color')\r\n    if (clrMode == 'dark') {\r\n      return '#282828 !important'\r\n    } else {\r\n      return '#F3F3F3 !important'\r\n    }\r\n  }\r\n\r\n  themeModeBorderTop() {\r\n    const clrMode = document.body.getAttribute('data-layout-color')\r\n    if (clrMode == 'dark') {\r\n      return '2px solid #000 !important'\r\n    } else {\r\n      return '2px solid #fff !important'\r\n    }\r\n  }\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['placeHolder']) {\r\n      this.insertAtCaret(this.placeHolder)\r\n\r\n    }\r\n\r\n    if (changes['reportId']) {\r\n      sessionStorage.setItem('reportId', this.reportId)\r\n    } \r\n\r\n    if (changes['UserRole']) { \r\n      this.getUserRoles()\r\n    }\r\n  }\r\n  ngAfterViewInit() {\r\n    this.initEditor();\r\n    this.checkPlaceholder();\r\n    this.setupHistory();\r\n    document.addEventListener('fullscreenchange', this.onFullscreenChange);\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.init_Func(this.editorText)\r\n    document.addEventListener('selectionchange', () => {\r\n      this.checkActiveStates();\r\n      this.checkFormatBlock();\r\n    });\r\n    this.addClickListenerToImages();\r\n    this.addClickListenerToElements();\r\n    // this.route.queryParams.subscribe(params => {\r\n    //   const data = JSON.parse(params['data']);\r\n    //   if (data.editedIMG) {\r\n    //     const imgUrl = sessionStorage.getItem('editImageFromTemp');\r\n    //     if (imgUrl) {\r\n    //       this.replaceImageSrc(imgUrl, data.index.index)\r\n    //     }\r\n    //     sessionStorage.removeItem('editImageFromTemp');\r\n    //   }\r\n    // })\r\n  }\r\n\r\n   ngOnDestroy() {\r\n    // Cleanup the event listener when the component is destroyed\r\n    document.removeEventListener('fullscreenchange', this.onFullscreenChange);\r\n  }\r\n\r\n  IsOpen: boolean = false;\r\n\r\n    toggleFullscreen1() {\r\n      this.IsOpen = !this.IsOpen;\r\n      this.isOpen.emit(this.IsOpen)\r\n      if (this.IsOpen) { \r\n        this.fullscreen.enter(this.TextEditor.nativeElement);\r\n      } else {\r\n        this.fullscreen.exit()\r\n      }\r\n    }\r\n  \r\n  private onFullscreenChange = () => {\r\n    if (!document.fullscreenElement) {\r\n      // When fullscreen mode is exited\r\n      this.IsOpen = false;\r\n      this.isOpen.emit(this.IsOpen);\r\n    }\r\n  };\r\n  \r\n  // enterFullscreenVideo() {\r\n  //   console.log('event:', event);\r\n  //   const fullscreen = event;\r\n  //   this.isOpen = event;\r\n  //   if (fullscreen) {\r\n  //     this.fullscreen.enter(this.TextEditor.nativeElement);\r\n  //   } else {\r\n  //     this.fullscreen.exit()\r\n  //   }\r\n    \r\n  // }\r\n\r\n  writeValue(value: any): void {\r\n    if (value !== undefined) {\r\n      this.editorText = value;\r\n      this.initEditor();\r\n      this.init_Func(this.editorText);\r\n    }\r\n  }\r\n  \r\n//  private addClickListenerToImages() {\r\n//   const editor = document.getElementById('editor');\r\n//   if (editor) {\r\n//     editor.addEventListener('click', (event) => {\r\n//       const target = event.target as HTMLElement;\r\n//       if (target.tagName === 'IMG') {\r\n//         this.selectedImage = target as HTMLImageElement;\r\n//         this.imageEditUrl = this.selectedImage.src;\r\n\r\n//         let container = this.selectedImage.parentElement;\r\n//         if (!container || container.className !== 'image-container') {\r\n//           container = document.createElement('div');\r\n//           container.className = 'image-container';\r\n//           container.style.position = 'relative';\r\n//           container.style.display = 'inline-block';\r\n//           this.selectedImage.parentNode?.insertBefore(container, this.selectedImage);\r\n//           container.appendChild(this.selectedImage);\r\n//         }\r\n//         const existingButton = container.querySelector('.image-edit-button');\r\n//         if (existingButton) {\r\n//           existingButton.remove();\r\n//         }\r\n\r\n//         const button = document.createElement('button');\r\n//         // button.textContent = 'Edit';\r\n//         button.innerText = 'Edit Image';\r\n\r\n//         button.className = 'image-edit-button btn btn-sm';\r\n//         button.style.position = 'absolute';\r\n//         button.style.top = '50%';\r\n//         button.style.left = '50%';\r\n//         button.style.transform = 'translate(-50%, -50%)';\r\n//         button.style.zIndex = '1000';\r\n//         button.style.backgroundColor = '#fff';\r\n//         button.style.border = '2px solid #fff';\r\n//         // button.style.padding = '10px';\r\n//         button.style.color = '#313a46';\r\n//         button.style.cursor = 'pointer';\r\n\r\n//         button.addEventListener('click', (e) => {\r\n//           e.stopPropagation();\r\n//           this.editImage();\r\n//         });\r\n\r\n//         container.appendChild(button);\r\n//       } else {\r\n//         this.selectedImage = null;\r\n//         this.selectedItemIndex = null;\r\n//       }\r\n//     });\r\n//   }\r\n  // }\r\n  getUserRoles() {\r\n    this.userRole = this.UserRole\r\n  }\r\n  // roleCheck() {\r\n  //   for (let i = 0; i < this.userRole.length; ++i) {\r\n  //     const roleName = []\r\n  //       roleName.push(this.userRole[i]?.name);\r\n  //     return this.userRole[i]?.name;\r\n  //   }\r\n  // }\r\n\r\n  roleCheck() {\r\n    let userRoleName: string[] = [];\r\n    for (let i = 0; i <= this.userRole.length; ++i) {\r\n      userRoleName.push(this.userRole[i]?.name);\r\n    }\r\n    return userRoleName;\r\n  }\r\n\r\n\r\n// private addClickListenerToImages() {\r\n//   const editor = document.getElementById('editor');\r\n//   const roles = this.roleCheck(); // Get user roles dynamically\r\n//   const isAdmin = roles.includes('Admin');\r\n//   const isCreator = roles.includes('Creator');\r\n//   const isApprover = roles.includes('Approver');\r\n  \r\n//   if (isCreator || isAdmin) {\r\n//     if (editor) {\r\n//     editor.addEventListener('click', (event) => {\r\n//       const target = event.target as HTMLElement;\r\n//       if (target.tagName === 'IMG') {\r\n//         this.selectedImage = target as HTMLImageElement;\r\n//         this.imageEditUrl = this.selectedImage.src;\r\n//         let container = this.selectedImage.parentElement;\r\n//         if (!container || container.className !== 'image-container') {\r\n//           container = document.createElement('div');\r\n//           container.className = 'image-container';\r\n//           container.style.position = 'relative';\r\n//           container.style.display = 'inline-block';  \r\n//           this.selectedImage.parentNode?.insertBefore(container, this.selectedImage);\r\n//           container.appendChild(this.selectedImage);\r\n//         }\r\n\r\n//         const existingButton = container.querySelector('.image-edit-button');\r\n//         if (existingButton) {\r\n//           existingButton.remove();\r\n//         }\r\n\r\n//         const button = document.createElement('button');\r\n//         button.textContent  = 'Edit Image';\r\n//         button.className = 'image-edit-button btn btn-sm';\r\n//         button.style.position = 'absolute';\r\n//         button.style.top = '50%';\r\n//         button.style.left = '50%';\r\n//         button.style.transform = 'translate(-50%, -50%)';\r\n//         button.style.zIndex = '1000';\r\n//         button.style.backgroundColor = '#fff'; \r\n//         button.style.border = '2px solid #fff'; \r\n//         button.style.color = '#313a46';\r\n//         button.style.cursor = 'pointer';\r\n//         button.style.userSelect = 'none';\r\n\r\n//         button.addEventListener('click', (e) => {\r\n//           e.stopPropagation();\r\n//           this.editImage();\r\n//         });\r\n\r\n//         container.appendChild(button);\r\n\r\n//       } else {\r\n//         this.selectedImage = null;\r\n//         this.selectedItemIndex = null;\r\n//         const buttons = document.querySelectorAll('.image-edit-button');\r\n//         buttons.forEach(button => button.remove());\r\n//       }\r\n//     });\r\n//   }\r\n//   }\r\n  // }\r\n  private addClickListenerToImages() {\r\n  const editor = document.getElementById('editor');\r\n  const roles = this.roleCheck(); // Get user roles dynamically\r\n  const isAdmin = roles.includes('Admin');\r\n  const isCreator = roles.includes('Creator');\r\n\r\n  if (isCreator || isAdmin) {\r\n    if (editor) {\r\n      editor.addEventListener('click', (event) => {\r\n        const target = event.target as HTMLElement;\r\n        if (target.tagName === 'IMG') {\r\n          this.selectedImage = target as HTMLImageElement;\r\n          this.imageEditUrl = this.selectedImage.src;\r\n          const images = editor.getElementsByTagName('img');\r\n           for (let i = 0; i < images.length; i++) {\r\n          if (images[i] === this.selectedImage) {\r\n            this.selectedItemIndex = i;\r\n            break;\r\n          }\r\n        }\r\n          let container = this.selectedImage.parentElement;\r\n          if (!container || container.className !== 'image-container') {\r\n            container = document.createElement('div');\r\n            container.className = 'image-container';\r\n            container.style.position = 'relative';\r\n            container.style.display = 'inline-block';\r\n            this.selectedImage.parentNode?.insertBefore(container, this.selectedImage);\r\n            container.appendChild(this.selectedImage);\r\n          }\r\n\r\n          const existingButton = container.querySelector('.image-edit-button');\r\n          if (existingButton) {\r\n            existingButton.remove();\r\n          }\r\n\r\n          const button = document.createElement('button');\r\n          button.textContent = 'Edit Image';\r\n          button.className = 'image-edit-button btn btn-sm';\r\n          button.style.position = 'absolute';\r\n          button.style.top = '50%';\r\n          button.style.left = '50%';\r\n          button.style.transform = 'translate(-50%, -50%)';\r\n          button.style.zIndex = '1000';\r\n          button.style.backgroundColor = '#fff';\r\n          button.style.border = '2px solid #fff';\r\n          button.style.color = '#313a46';\r\n          button.style.cursor = 'pointer';\r\n          button.style.userSelect = 'none';\r\n\r\n          button.addEventListener('click', (e) => {\r\n            e.stopPropagation();\r\n            this.editImage();\r\n          });\r\n\r\n          container.appendChild(button);\r\n        } else {\r\n          this.removeEditButtons();\r\n        }\r\n      });\r\n\r\n      // Monitor editor content changes to handle image deletion\r\n      const observer = new MutationObserver(() => {\r\n        const buttons = editor.querySelectorAll('.image-edit-button');\r\n        buttons.forEach((button) => {\r\n          const container = button.parentElement;\r\n          if (container && !container.querySelector('img')) {\r\n            button.remove(); // Remove the button if the associated image is gone\r\n            container.remove(); // Clean up the container\r\n          }\r\n        });\r\n      });\r\n\r\n      // Observe changes in the editor\r\n      observer.observe(editor, { childList: true, subtree: true });\r\n    }\r\n  }\r\n}\r\n\r\nprivate removeEditButtons() {\r\n  const buttons = document.querySelectorAll('.image-edit-button');\r\n  buttons.forEach((button) => button.remove());\r\n  this.selectedImage = null;\r\n  this.selectedItemIndex = null;\r\n}\r\n\r\n\r\n  // private addClickListenerToImages() {\r\n  // const editor = document.getElementById('editor');\r\n  // if (editor) {\r\n  //   editor.addEventListener('click', (event) => {\r\n  //     const target = event.target as HTMLElement;\r\n  //     if (target.tagName === 'IMG') {\r\n  //       this.selectedImage = target as HTMLImageElement;\r\n  //       this.imageEditUrl = this.selectedImage.src;\r\n\r\n  //       // Get the index of the selected image\r\n  //       const images = editor.getElementsByTagName('img');\r\n  //       for (let i = 0; i < images.length; i++) {\r\n  //         if (images[i] === this.selectedImage) {\r\n  //           this.selectedItemIndex = i;\r\n  //           break;\r\n  //         }\r\n  //       }\r\n\r\n  //       if (this.toolbarMode === 'bubble') {\r\n  //         this.onTextSelect();\r\n  //       }\r\n  //     } else {\r\n  //       this.selectedImage = null;\r\n  //       this.selectedItemIndex = null;\r\n  //     }\r\n  //   });\r\n  // }\r\n  // }\r\n  \r\n  private addClickListenerToElements() {\r\n  const editor = document.getElementById('editor');\r\n  if (editor) {\r\n    editor.addEventListener('click', (event) => {\r\n      const target = event.target as HTMLElement;\r\n      if (target.tagName === 'IMG') {\r\n        this.selectedImage = target as HTMLImageElement;\r\n        this.imageEditUrl = this.selectedImage.src;\r\n        const images = editor.getElementsByTagName('img');\r\n        for (let i = 0; i < images.length; i++) {\r\n          if (images[i] === this.selectedImage) {\r\n            this.selectedItemIndex = i;\r\n            break;\r\n          }\r\n        }\r\n      } else {\r\n        this.selectedImage = null;\r\n      }\r\n      if (target.tagName === 'TD' || target.tagName === 'TH') {\r\n        this.selectedTable = target.closest('table') as HTMLTableElement;\r\n        const cells = this.selectedTable.getElementsByTagName(target.tagName);\r\n        for (let i = 0; i < cells.length; i++) {\r\n          if (cells[i] === target) {\r\n            this.selectedItemIndex = i;\r\n            break;\r\n          }\r\n        }\r\n      } else {\r\n        this.selectedTable = null;\r\n      }\r\n\r\n      if (target.tagName === 'P' || target.tagName === 'SPAN' || target.tagName === 'DIV') {\r\n        const paragraphs = editor.getElementsByTagName(target.tagName);\r\n        for (let i = 0; i < paragraphs.length; i++) {\r\n          if (paragraphs[i] === target) {\r\n            this.selectedItemIndex = i;\r\n            break;\r\n          }\r\n        }\r\n      }\r\n    });\r\n  }\r\n  }\r\n\r\nreplaceImageSrc(newSrc: string, index: number) {\r\n  const editor = document.getElementById('editor');\r\n  \r\n  if (editor) {\r\n    editor.focus()\r\n    const images = editor.getElementsByTagName('IMG');\r\n    if (index >= 0 ) {\r\n      images[index].setAttribute('src', newSrc);\r\n    } \r\n  }\r\n}\r\n\r\n\r\n\r\n  private initEditor() {\r\n    // Initialize editor content and listeners\r\n    const editor = document.getElementById('editor');\r\n\r\n    if (editor) {\r\n      editor.innerHTML = this.editorText;\r\n      editor.addEventListener('input', () => {\r\n        this.onModelChange(editor.innerHTML);\r\n      });\r\n    }\r\n    this.checkPlaceholder();\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  setDisabledState?(isDisabled: boolean): void {\r\n    // Handle the disabled state if necessary\r\n  }\r\n\r\n  onModelChange(value: any): void {\r\n    if (value) {\r\n      const VALUE = value\r\n      this.editorText = VALUE;\r\n      this.onChange(VALUE);\r\n      this.editorTextChange.emit(VALUE);\r\n    } else {\r\n      this.selectedImage = null;\r\n    }\r\n  }\r\n\r\n  applyImageStyles(content: string): string {\r\n    const div = document.createElement('div');\r\n    div.innerHTML = content;\r\n    const images = div.querySelectorAll('img');\r\n    images.forEach(img => {\r\n      if (img.style.maxWidth >= '700px') {\r\n        img.style.maxWidth = '700px';\r\n        // img.width = 300;\r\n        img.style.height = 'auto';\r\n      } else {\r\n        img.style.maxWidth = '100%';\r\n        img.style.height = 'auto';\r\n      }\r\n    });\r\n    return div.innerHTML;\r\n  }\r\n\r\n  // init_Func(html: any) {\r\n  //   if (html) {\r\n  //     let editor = document.getElementById('editor');\r\n  //     if (editor) { \r\n  //       editor.focus()\r\n  //       editor.innerHTML = html;\r\n  //       this.sanitizedContent = this.sanitizer.bypassSecurityTrustHtml(this.applyImageStyles(html));\r\n  //       editor.innerHTML = this.sanitizedContent as string;\r\n  //       editor.addEventListener('input', () => {\r\n  //         if (editor) {\r\n  //           editor.focus()\r\n  //           this.onModelChange(editor.innerHTML);\r\n  //         }\r\n  //       });\r\n  //     }\r\n  //   } else {\r\n  //     this.selectedImage = null;\r\n  //   }\r\n  // }\r\n  \r\n//   init_Func(html: any) {\r\n//   if (html) {\r\n//     let editor = document.getElementById('editor');\r\n//     if (editor) {\r\n//       // Initialize the editor with sanitized content\r\n      \r\n//       this.setEditorContent(html);\r\n\r\n//       // Set up a MutationObserver to handle content changes\r\n//       this.setupMutationObserver(editor);\r\n\r\n//       // Move the caret to the end after initial content setup\r\n//       this.moveCaretToEnd(editor);\r\n\r\n//       // Track caret position on mouse click\r\n//       editor.addEventListener('click', () => {\r\n//         if (editor) {  // Ensure editor is not null\r\n//           // this.trackCaretPosition(editor);\r\n//         }\r\n//       });\r\n//     }\r\n//   } else {\r\n//     this.selectedImage = null;\r\n//   }\r\n// }\r\n\r\n// private setEditorContent(html: string) {\r\n//   let editor = document.getElementById('editor');\r\n//   if (editor) {\r\n//     // Sanitize and apply styles to the HTML\r\n//     this.sanitizedContent = this.sanitizer.bypassSecurityTrustHtml(this.applyImageStyles(html));\r\n//     editor.innerHTML = this.sanitizedContent as string;\r\n//   }\r\n// }\r\n\r\n// private setupMutationObserver(editor: HTMLElement) {\r\n//   const observer = new MutationObserver(() => {\r\n//     // Update model with the current content\r\n//     this.onModelChange(editor.innerHTML);\r\n//   });\r\n\r\n//   observer.observe(editor, { childList: true, subtree: true, characterData: true });\r\n// }\r\n\r\n// This function tracks the caret position based on the mouse click\r\nprivate trackCaretPosition(editor: HTMLElement) {\r\n  const selection = window.getSelection();\r\n  if (selection && selection.rangeCount > 0) {\r\n    const range = selection.getRangeAt(0);\r\n    const startNode = range.startContainer;\r\n    const startOffset = range.startOffset;\r\n\r\n\r\n    // You can use this information to insert content or perform actions based on the caret position\r\n    // Example: Save the current caret position for future use\r\n    this.currentCaretPosition = { node: startNode, offset: startOffset };\r\n  }\r\n  }\r\n  \r\n  // Method to get caret position and insert new data\r\nprivate insertAtCaret(newData: string): void {\r\n  const selection = window.getSelection();\r\n  \r\n  if (selection && selection.rangeCount > 0) {\r\n    // Get the current range (caret position)\r\n    const range = selection.getRangeAt(0);\r\n\r\n    // Create a document fragment to insert (allows handling HTML strings)\r\n    const fragment = document.createDocumentFragment();\r\n    const tempDiv = document.createElement('div');\r\n    tempDiv.innerHTML = newData;\r\n\r\n    // Append the new data to the fragment (supports HTML insertion)\r\n    while (tempDiv.firstChild) {\r\n      fragment.appendChild(tempDiv.firstChild);\r\n    }\r\n\r\n    // Insert the fragment at the caret position\r\n    range.deleteContents(); // Remove any selected content if applicable\r\n    range.insertNode(fragment);\r\n\r\n    // Move the caret after the inserted content\r\n    const lastChild = fragment.lastChild;\r\n\r\n    if (lastChild) {\r\n      range.setStartAfter(lastChild);\r\n      range.setEndAfter(lastChild);\r\n      selection.removeAllRanges();\r\n      selection.addRange(range);\r\n    }\r\n    let editor = document.getElementById('editor');\r\n    if (editor) {\r\n      this.moveCaretToEnd(editor)\r\n    }\r\n    \r\n    this.placeHolderRemove.emit()\r\n  }\r\n}\r\n\r\n\r\n//   // Move caret to the end of the editor content\r\n//   private moveCaretToEnd(editor: HTMLElement) {\r\n//     const selection = window.getSelection();\r\n//     const range = document.createRange();\r\n    \r\n//     if (editor.lastChild) {\r\n//       range.selectNodeContents(editor);\r\n//       range.collapse(false); // Collapse to the end\r\n//       selection?.removeAllRanges();\r\n//       selection?.addRange(range);\r\n      \r\n//     }\r\n//   }\r\n  \r\n  \r\n\r\n\r\n  init_Func(html: any) {\r\n  if (html) {\r\n    let editor = document.getElementById('editor');\r\n    if (editor) {\r\n      // Initialize the editor with sanitized content\r\n      this.setEditorContent(html);\r\n\r\n      // Set up a MutationObserver to handle content changes\r\n      this.setupMutationObserver(editor);\r\n      \r\n      // Move the caret to the end after initial content setup\r\n      this.moveCaretToEnd(editor);\r\n      //  Track caret position on mouse click\r\n      editor.addEventListener('click', () => {\r\n        if (editor) {  // Ensure editor is not null\r\n          this.trackCaretPosition(editor);\r\n        }\r\n      });\r\n    }\r\n  } else {\r\n    this.selectedImage = null;\r\n  }\r\n}\r\n\r\n\r\nprivate setEditorContent(html: string) {\r\n  let editor = document.getElementById('editor');\r\n  if (editor) {\r\n    // Sanitize and apply styles to the HTML\r\n    this.sanitizedContent = this.sanitizer.bypassSecurityTrustHtml(this.applyImageStyles(html));\r\n    editor.innerHTML = this.sanitizedContent as string;\r\n  }\r\n}\r\n\r\nprivate setupMutationObserver(editor: HTMLElement) {\r\n  const observer = new MutationObserver(() => {\r\n    // Move the caret to the end after content changes\r\n    // this.moveCaretToEnd(editor);\r\n    // Update model with the current content\r\n    this.onModelChange(editor.innerHTML);\r\n  });\r\n\r\n  observer.observe(editor, { childList: true, subtree: true, characterData: true });\r\n}\r\n\r\nprivate moveCaretToEnd(editor: HTMLElement) {\r\n  const selection = window.getSelection();\r\n  const range = document.createRange();\r\n  \r\n  if (editor.lastChild) {\r\n    range.selectNodeContents(editor);\r\n    range.collapse(false); // Collapse to the end\r\n    selection?.removeAllRanges();\r\n    selection?.addRange(range);\r\n  }\r\n}\r\n\r\n//   init_Func(html: any) {\r\n//   if (html) {\r\n//     let editor = document.getElementById('editor');\r\n//     if (editor) {\r\n//       editor.focus();\r\n//       editor.innerHTML = html;\r\n\r\n//       // Sanitize the content and apply styles\r\n//       this.sanitizedContent = this.sanitizer.bypassSecurityTrustHtml(this.applyImageStyles(html));\r\n//       editor.innerHTML = this.sanitizedContent as string;\r\n\r\n//       // Place the caret at the end of the content\r\n//       const range = document.createRange();\r\n//       const selection = window.getSelection();\r\n      \r\n//       if (editor.lastChild) {\r\n//         // Set the range at the end of the editor's content\r\n//         range.selectNodeContents(editor);\r\n//         range.collapse(false); // collapse to the end\r\n//         selection?.removeAllRanges();\r\n//         selection?.addRange(range);\r\n//       }\r\n\r\n//       editor.addEventListener('input', () => {\r\n//         if (editor) {\r\n//           this.onModelChange(editor.innerHTML);\r\n\r\n//           // Ensure the caret remains at the end after new content is added\r\n//           const range = document.createRange();\r\n//           const selection = window.getSelection();\r\n          \r\n//           if (editor.lastChild) {\r\n//             range.selectNodeContents(editor);\r\n//             range.collapse(false); // collapse to the end\r\n//             selection?.removeAllRanges();\r\n//             selection?.addRange(range);\r\n//           }\r\n//         }\r\n//       });\r\n//     }\r\n//   } else {\r\n//     this.selectedImage = null;\r\n//   }\r\n// }\r\n\r\n  format(command: string, value?: any) {\r\n    const editor = document.getElementById('editor');\r\n    if (editor) {\r\n      editor.focus();\r\n      if (command === 'subscript') {\r\n        this.isSubscriptActive = !this.isSubscriptActive;\r\n        document.execCommand('subscript', false, '');\r\n      } else if (command === 'superscript') {\r\n        this.isSuperscriptActive = !this.isSuperscriptActive;\r\n        document.execCommand('superscript', false, '');;\r\n      } else {\r\n        document.execCommand(command, false, value ?? '');\r\n        if (value) {\r\n          const tag = value.toLowerCase().replace(/[<>]/g, '')\r\n          this.selectedFormatBlock = this.formatBlockDecode(tag);\r\n        }\r\n      }\r\n    }\r\n     this.checkActiveStates();\r\n     this.checkFormatBlock();\r\n  }\r\n\r\n  checkActiveStates() {\r\n    this.isBoldActive = document.queryCommandState('bold');\r\n    this.isItalicActive = document.queryCommandState('italic');\r\n    this.isUnderlineActive = document.queryCommandState('underline');\r\n    this.isStrikethroughActive = document.queryCommandState('strikethrough');\r\n    this.isSubscriptActive = document.queryCommandState('subscript');\r\n    this.isSuperscriptActive = document.queryCommandState('superscript');\r\n  }\r\n\r\n  checkFormatBlock() {\r\n    const editor = document.getElementById('editor');\r\n    if (editor) {\r\n      const formatBlock = document.queryCommandValue('formatBlock');\r\n      this.selectedFormatBlock = this.formatBlockDecode(formatBlock);\r\n      // You can further handle the formatBlock value as needed\r\n    }\r\n  }\r\n\r\n  formatBlockDecode(data: string): any {\r\n    switch (data) {\r\n      case 'h1':\r\n        return 'heading 1';\r\n        break;\r\n      case 'h2':\r\n        return 'heading 2';\r\n        break;\r\n      case 'h3':\r\n        return 'heading 3';\r\n        break;\r\n      case 'h4':\r\n        return 'heading 4';\r\n        break;\r\n      case 'h5':\r\n        return 'heading 5';\r\n        break;\r\n      case 'h6':\r\n        return 'heading 6';\r\n        break;\r\n      case 'p':\r\n        return 'normal';\r\n        break;\r\n      default:\r\n        return 'normal';\r\n        break;\r\n    }\r\n  }\r\n\r\n  changeFont(event: any) {\r\n    this.selectedFont = event;\r\n    document.execCommand('fontName', false, this.selectedFont);\r\n  }\r\n\r\n  insertCodeBlock() {\r\n    const code = `\r\n      <pre style=\"font-size: 12px;\r\n                  color: white;\r\n                  background-color: black;\r\n                  overflow-x: auto;\r\n                  margin-bottom: 5px;\r\n                  margin-top: 5px;\r\n                  padding: 5px 10px;\">\r\n        <code style=\"display: block;\r\n                     white-space: pre-wrap;\r\n                     height: auto;\r\n                     font-family: Menlo, Monaco, Consolas, 'Courier New', monospace;\r\n                     font-size: 14px;\" class=\"language-html\">Insert code here...</code>\r\n      </pre>\r\n    `;\r\n    document.execCommand('insertHTML', false, code);\r\n  }\r\n\r\n  // changeFontSize(event: any) {\r\n  //   document.execCommand('fontSize', false, '7');\r\n  //   let editor = document.getElementById('editor');\r\n  //   if (editor) {\r\n  //     let fontElements = editor.getElementsByTagName('font');\r\n  //     for (let i = 0; i < fontElements.length; i++) {\r\n  //       if (fontElements[i].size == \"7\") {\r\n  //         fontElements[i].removeAttribute(\"size\");\r\n  //         fontElements[i].style.fontSize = this.selectedFontSize + 'px';\r\n  //       }\r\n  //     }\r\n  //   }\r\n  // }\r\n  changeFontSize(event: any) {\r\n    const selectedText = window.getSelection();\r\n    \r\n    if (selectedText && selectedText.rangeCount > 0) {\r\n        const range = selectedText.getRangeAt(0);\r\n        const span = document.createElement('span');\r\n        span.style.fontSize = this.selectedFontSize + 'px';\r\n        range.surroundContents(span);\r\n    }\r\n  }\r\n\r\n  addLink() {\r\n    let url = prompt(\"Enter the link here: \", \"http://\");\r\n    if (url) {\r\n      document.execCommand(\"createLink\", false, url);\r\n    }\r\n  }\r\n\r\n  insertsImage() {\r\n    const editor = document.getElementById('editor');\r\n    if (editor) {\r\n      editor.focus();\r\n      let imageInput = document.getElementById('imageInput') as HTMLInputElement;\r\n      if (imageInput) {\r\n        imageInput.click();\r\n      }\r\n    }\r\n  }\r\n\r\n  // handleImageUpload(event: any) {\r\n  //   const file = event.target.files[0];\r\n  //   if (file) {\r\n  //     const reader = new FileReader();\r\n  //     reader.onload = (e: any) => {\r\n  //       const img = new Image();\r\n  //       img.src = e.target.result;\r\n  //       img.onload = () => {\r\n  //         // Create the HTML string with the exact width and height\r\n  //         const imgHTML = `<img src=\"${img.src}\" width=\"${794}\" >`;\r\n  //         // Insert the image into the editor\r\n  //         document.execCommand('insertHTML', false, imgHTML);\r\n  //       };\r\n  //     };\r\n  //     reader.readAsDataURL(file);\r\n  //   }\r\n  // }\r\n\r\n  handleImageUpload(event: any) {\r\n  const file = event.target.files[0];\r\n  const editorElement = document.getElementById('editor'); // Reference to the editor\r\n\r\n  if (file && editorElement) {\r\n    const editorWidth = editorElement.offsetWidth; // Get the editor's width\r\n    const reader = new FileReader();\r\n\r\n    reader.onload = (e: any) => {\r\n      const img = new Image();\r\n      img.src = e.target.result;\r\n\r\n      img.onload = () => {\r\n        const imgWidth = img.width;\r\n\r\n        // If the image width exceeds the editor's width, fit it to the editor\r\n        const imgHTML =\r\n          imgWidth > editorWidth\r\n            ? `<img src=\"${img.src}\" style=\" max-width: ${700}px; height: auto;\">`\r\n            : `<img src=\"${img.src}\" style=\"width: ${imgWidth}px; height: auto;\">`;\r\n        this.newImageAdded.emit()\r\n        // Insert the image into the editor\r\n        document.execCommand('insertHTML', false, imgHTML);\r\n      };\r\n    };\r\n\r\n    reader.readAsDataURL(file);\r\n  }\r\n}\r\n\r\n\r\n\r\n  // addTable() {\r\n  //   const tableWidth = 825; // Table width in pixels\r\n  //   const cols = 3; // Number of columns\r\n  //   const cellMinWidth = tableWidth / cols; // Calculate minimum width for each cell\r\n\r\n  //   let table = `<br /><table style=\"width: ${tableWidth}px;\">`;\r\n  //   for (let i = 0; i < 3; i++) { // Number of rows\r\n  //     table += '<tr >';\r\n  //     for (let j = 0; j < cols; j++) {\r\n  //       table += `<td style=\" word-wrap: break-word; word-break: break-all; white-space: normal; min-width: ${cellMinWidth}px;\">&nbsp;</td>`;\r\n  //     }\r\n  //     table += '</tr>';\r\n  //   }\r\n  //     table += '</table><br/ >';\r\n  //     // document.execCommand('insertHTML', false, table);\r\n  //     const editor = document.getElementById('editor');\r\n  //   if (editor) {\r\n  //     editor.focus();\r\n  //     document.execCommand('insertHTML', false, table);\r\n  //   }\r\n  //   this.tableAdded = true;\r\n  //   this.checkTableSelection();\r\n  // }\r\n\r\n\r\n  handleTabKey(event: any) {\r\n    if (event.key === \"Tab\") {\r\n      event.preventDefault(); // Stop default tabbing behavior\r\n      const selection = window.getSelection();\r\n      if (!selection || selection.rangeCount === 0) return;\r\n\r\n      const range = selection.getRangeAt(0);\r\n      const tabNode = document.createElement(\"span\"); // Create a span element for the tab space\r\n      tabNode.innerHTML = \"&nbsp;&nbsp;&nbsp;&nbsp;\"; // Four non-breaking spaces to mimic tab\r\n      \r\n      range.deleteContents(); // Remove any selected text\r\n      range.insertNode(tabNode); // Insert the tab space as span\r\n      range.setStartAfter(tabNode); // Move cursor after the inserted span\r\n      range.setEndAfter(tabNode);\r\n      selection.removeAllRanges();\r\n      selection.addRange(range);\r\n    }\r\n  }\r\n  \r\n//   addTable() {\r\n//   const tableWidth = 825; // Table width in pixels\r\n//   const cols = 3; // Number of columns\r\n//   const cellMinWidth = tableWidth / cols; // Calculate minimum width for each cell\r\n\r\n//   let table = `<br /><table style=\"width: ${tableWidth}px;\">`;\r\n//   for (let i = 0; i < 3; i++) { // Number of rows\r\n//     table += `<tr style=\"border-bottom: ${this.themeModeClrVerticalLineForTable()}\">`; // Add border-bottom to the row\r\n//     for (let j = 0; j < cols; j++) {\r\n//       table += `<td style=\"word-wrap: break-word; word-break: break-all; white-space: normal; min-width: ${cellMinWidth}px;\">&nbsp;</td>`;\r\n//     }\r\n//     table += '</tr>';\r\n//   }\r\n//   table += '</table><br/>';\r\n\r\n//   const editor = document.getElementById('editor');\r\n//   if (editor) {\r\n//     editor.focus();\r\n//     document.execCommand('insertHTML', false, table);\r\n//   }\r\n\r\n//   this.tableAdded = true;\r\n//   this.checkTableSelection();\r\n// }\r\n// addTable() {\r\n//   const tableWidth = 825;\r\n//   const cols = 3;\r\n//   const cellMinWidth = tableWidth / cols;\r\n\r\n//   let table = `<br /><table id=\"customTable\" style=\"width: ${tableWidth}px; border-collapse: collapse;\">`;\r\n\r\n//   table += `<tbody>`;\r\n//   table += `<tr id=\"tableHeaderRow\" style=\"border-bottom: ${this.themeModeClrVerticalLineForTable()};\" (click)=\"checkTableSelection()\">`;\r\n//   for (let j = 0; j < cols; j++) {\r\n//     table += `<td class=\"header-cell\" \r\n//               style=\"border-top: 2px solid black; \r\n//                      font-weight: bold; \r\n//                      text-align: start; \r\n//                      word-wrap: break-word; \r\n//                      word-break: break-all; \r\n//                      white-space: normal; \r\n//                      min-width: ${cellMinWidth}px; \r\n//                      background-color: inherit !important; \r\n//                     //  pointer-events: none !important;\r\n//                      display: table-cell !important;\r\n//                      position: static !important;\r\n// height:28px;\"></td>`;\r\n//   }\r\n//   table += `</tr>`;\r\n\r\n//   for (let i = 0; i < 3; i++) {\r\n//     table += `<tr style=\"border-bottom: ${this.themeModeClrVerticalLineForTable()}\">`;\r\n//     for (let j = 0; j < cols; j++) {\r\n//       table += `<td style=\"word-wrap: break-word; \r\n//                         word-break: break-all; \r\n//                         white-space: normal; \r\n//                         min-width: ${cellMinWidth}px;\r\n//                         display: table-cell !important;\r\n//                         position: static !important;\">&nbsp;</td>`;\r\n//     }\r\n//     table += \"</tr>\";\r\n//   }\r\n//   table += `</tbody></table><br/>`;\r\n\r\n//   const editor = document.getElementById(\"editor\");\r\n//   if (editor) {\r\n//     editor.focus();\r\n//     document.execCommand(\"insertHTML\", false, table);\r\n//   }\r\n\r\n//   this.tableAdded = true;\r\n//   this.checkTableSelection();\r\n\r\n//   // Add styles to prevent table structure breaking\r\n//   const style = document.createElement(\"style\");\r\n//   style.innerHTML = `\r\n//   #customTable {\r\n//     table-layout: fixed !important;\r\n//     border-collapse: collapse !important;\r\n//   }\r\n//   #customTable tr {\r\n//     display: table-row !important;\r\n//   }\r\n//   #customTable td {\r\n//     display: table-cell !important;\r\n//     position: static !important;\r\n//   }\r\n//   #customTable .header-cell {\r\n//     position: static !important;\r\n//   }\r\n//   #customTable .header-cell > span {\r\n//     display: inline !important;\r\n//     position: static !important;\r\n//   }\r\n//   #customTable .header-cell:hover {\r\n//     cursor: default !important;\r\n//   }\r\n// `;\r\n//   document.head.appendChild(style);\r\n// }\r\n\r\naddTable() {\r\n  const tableWidth = 825;\r\n  const cols = 3;\r\n  const cellMinWidth = tableWidth / cols;\r\n\r\n  let table = `<br /><table id=\"customTable\" style=\"width: ${tableWidth}px; border-collapse: collapse;\">`;\r\n  table += `<tbody>`;\r\n\r\n  // Table Header Row\r\n  table += `<tr id=\"tableHeaderRow\" style=\"border-bottom: ${this.themeModeClrVerticalLineForTable()};\" onclick=\"checkTableSelection()\">`;\r\n\r\n  for (let j = 0; j < cols; j++) {\r\n    table += `<td class=\"header-cell\" \r\n              style=\"border-top: 2px solid black; \r\n                     font-weight: bold; \r\n                     text-align: start; \r\n                     word-wrap: break-word; \r\n                     word-break: break-all; \r\n                     white-space: normal; \r\n                     min-width: ${cellMinWidth}px; \r\n                     background-color: inherit !important; \r\n                     display: table-cell !important;\r\n                     position: static !important;\r\n                     height:28px;\"></td>`;\r\n  }\r\n\r\n  // Properly closing the header row\r\n  table += `</tr>`;\r\n\r\n  // Data Rows\r\n  for (let i = 0; i < 3; i++) {\r\n    table += `<tr style=\"border-bottom: ${this.themeModeClrVerticalLineForTable()}\">`;\r\n    for (let j = 0; j < cols; j++) {\r\n      table += `<td style=\"word-wrap: break-word; \r\n                        word-break: break-all; \r\n                        white-space: normal; \r\n                        min-width: ${cellMinWidth}px;\r\n                        display: table-cell !important;\r\n                        position: static !important;\">&nbsp;</td>`;\r\n    }\r\n    table += `</tr>`;\r\n  }\r\n\r\n  table += `</tbody></table><br/>`;\r\n\r\n  // Inserting into the editor\r\n  const editor = document.getElementById(\"editor\");\r\n  if (editor) {\r\n    editor.focus();\r\n    document.execCommand(\"insertHTML\", false, table);\r\n  }\r\n\r\n  this.tableAdded = true;\r\n  this.checkTableSelection();\r\n\r\n  // Add styles to prevent table structure breaking\r\n  const style = document.createElement(\"style\");\r\n  style.innerHTML = `\r\n  #customTable {\r\n    table-layout: fixed !important;\r\n    border-collapse: collapse !important;\r\n  }\r\n  #customTable tr {\r\n    display: table-row !important;\r\n  }\r\n  #customTable td {\r\n    display: table-cell !important;\r\n    position: static !important;\r\n  }\r\n  #customTable .header-cell {\r\n    position: static !important;\r\n  }\r\n  #customTable .header-cell > span {\r\n    display: inline !important;\r\n    position: static !important;\r\n  }\r\n  #customTable .header-cell:hover {\r\n    cursor: default !important;\r\n  }\r\n`;\r\n  document.head.appendChild(style);\r\n}\r\n\r\n\r\n// Function to change the first row (thead) background color\r\nsetTheadBgColor(event: any) {\r\n  const selectedColor = event.target.value;\r\n\r\n  if (this.selectedTable) {\r\n    const headerRow = this.selectedTable.querySelector(\"tr\") as HTMLElement;\r\n\r\n    if (headerRow) {\r\n      const headerCells = headerRow.querySelectorAll(\".header-cell\");\r\n      headerCells.forEach((cell: Element) => {\r\n        (cell as HTMLElement).style.backgroundColor = selectedColor;\r\n      });\r\n    }\r\n  }\r\n}\r\n\r\n\r\n\r\n  checkTableSelection(event?: MouseEvent) {\r\n    let target = event?.target as HTMLElement;\r\n    if (target && (target.tagName === 'TD' || target.tagName === 'TH')) {\r\n      this.isTableSelected = true;\r\n      this.selectedTable = target.closest('table') as HTMLTableElement;\r\n    } else {\r\n      this.isTableSelected = false;\r\n      this.selectedTable = null;\r\n    }\r\n    \r\n    // this.checkPlaceholder();\r\n  }\r\n\r\n  checkPlaceholder() {\r\n    // let editor = document.getElementById('editor');\r\n    // if (editor) {\r\n    //   this.isPlaceholderVisible = editor.innerHTML === '' || editor.innerHTML === '<br>';\r\n    //   if (this.isPlaceholderVisible) {\r\n    //     // editor.innerHTML = '<span class=\"placeholder\" style=\"background: transparent; color: #000000\">Insert text here ...</span>';\r\n    //   } else {\r\n    //     let placeholder = editor.querySelector('.placeholder');\r\n    //     if (placeholder) {\r\n    //       editor.removeChild(placeholder);\r\n    //     }\r\n    //   }\r\n    // }\r\n  }\r\n\r\n  onFocus() {\r\n    // let editor = document.getElementById('editor');\r\n    // if (editor && this.isPlaceholderVisible) {\r\n    //   editor.innerHTML = '';\r\n    //   this.isPlaceholderVisible = false;\r\n    // }\r\n  }\r\n\r\n  // colorChange(newColor: string) {\r\n  //   this.color = newColor;\r\n  // }\r\n\r\n  onBlur() {\r\n    this.checkPlaceholder();\r\n  }\r\n\r\n  // addRow() {\r\n  //   if (this.selectedTable) {\r\n  //     let row = this.selectedTable.insertRow();\r\n  //     for (let i = 0; i < this.selectedTable.rows[0].cells.length; i++) {\r\n  //       let cell = row.insertCell(i);\r\n  //       cell.innerHTML = '&nbsp;';\r\n  //       cell.style.border = '1px solid black';\r\n  //     }\r\n  //   }\r\n  // }\r\n\r\n  addRow() {\r\n  if (this.selectedTable) {\r\n    let row = this.selectedTable.insertRow();\r\n\r\n    // Loop through the columns of the first row to determine the number of cells\r\n    for (let i = 0; i < this.selectedTable.rows[0].cells.length; i++) {\r\n      let cell = row.insertCell(i);\r\n      cell.innerHTML = '&nbsp;';\r\n\r\n      // Apply bottom border explicitly\r\n      cell.style.borderBottom = `2px solid ${this.themeModeClrVerticalLineColorForTable()}`; // You can replace 'black' with your theme color\r\n    }\r\n  }\r\n}\r\n\r\n//   addRow() {\r\n//   if (this.selectedTable) {\r\n//     let row = this.selectedTable.insertRow();\r\n//     row.style.borderBottom = this.themeModeClrVerticalLineForTable(); // Add bottom border to the row\r\n//     for (let i = 0; i < this.selectedTable.rows[0].cells.length; i++) {\r\n//       let cell = row.insertCell(i);\r\n//       cell.innerHTML = '&nbsp;';\r\n//     }\r\n//   }\r\n// }\r\n\r\n\r\n  // deleteRow() {\r\n  //   if (this.selectedTable) {\r\n  //     this.selectedTable.deleteRow(-1);\r\n  //   }\r\n  // }\r\n\r\n//   deleteRow() {\r\n//   if (this.selectedTable) {\r\n//     let rowIndex = this.selectedTable.rows.length - 1; \r\n//     if (window.getSelection) {\r\n//       let selection = window.getSelection();\r\n//       if (selection) {\r\n//         let row = selection.anchorNode?.parentElement?.closest('tr');\r\n//         if (row) {\r\n//           rowIndex = row.rowIndex;\r\n//         }\r\n//       }\r\n//     }\r\n//     this.selectedTable.deleteRow(rowIndex);\r\n//   }\r\n// }\r\n\r\n  deleteRow() {\r\n  const selection = window.getSelection();\r\n    if (selection) {\r\n    if (!selection.rangeCount) return;\r\n\r\n    const range = selection.getRangeAt(0);\r\n    const selectedNode = range.startContainer;\r\n    const row = selectedNode.parentElement?.closest('tr');\r\n\r\n    if (row) {\r\n      const table = row.closest('table');\r\n      if (table) {\r\n        table.deleteRow(row.rowIndex);\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n\r\n  // addColumn() {\r\n  //   if (this.selectedTable) {\r\n  //     for (let i = 0; i < this.selectedTable.rows.length; i++) {\r\n  //       let cell = this.selectedTable.rows[i].insertCell(-1);\r\n  //       cell.innerHTML = '&nbsp;';\r\n  //       cell.style.border = '1px solid black';\r\n  //     }\r\n  //   }\r\n  // }\r\n\r\n//   addColumn() {\r\n//   if (this.selectedTable) {\r\n//     const columnCount = this.selectedTable.rows[0].cells.length + 1; // New column count\r\n//     const tableWidth = this.selectedTable.offsetWidth;\r\n//     const minWidth = tableWidth / columnCount;\r\n\r\n//     for (let i = 0; i < this.selectedTable.rows.length; i++) {\r\n//       let cell = this.selectedTable.rows[i].insertCell(-1);\r\n//       cell.innerHTML = '&nbsp;';\r\n//       cell.style.border = '1px solid black';\r\n//       cell.style.minWidth = `${minWidth}px`;\r\n//       cell.style.wordWrap = 'break-word';\r\n//       cell.style.wordBreak = 'break-all';\r\n//       cell.style.whiteSpace = 'normal';\r\n//     }\r\n\r\n//     // Update existing cells' minWidth\r\n//     for (let i = 0; i < this.selectedTable.rows.length; i++) {\r\n//       for (let j = 0; j < this.selectedTable.rows[i].cells.length; j++) {\r\n//         this.selectedTable.rows[i].cells[j].style.minWidth = `${minWidth}px`;\r\n//       }\r\n//     }\r\n//   }\r\n  // }\r\n  \r\n  // addColumn() {\r\n  // if (this.selectedTable) {\r\n  //   const columnCount = this.selectedTable.rows[0].cells.length + 1; // New column count\r\n  //   const tableWidth = this.selectedTable.offsetWidth;\r\n  //   const minWidth = tableWidth / columnCount;\r\n\r\n  //   for (let i = 0; i < this.selectedTable.rows.length; i++) {\r\n  //     let cell = this.selectedTable.rows[i].insertCell(-1);\r\n  //     cell.innerHTML = '&nbsp;';\r\n  //     cell.style.wordWrap = 'break-word';\r\n  //     cell.style.wordBreak = 'break-all';\r\n  //     cell.style.whiteSpace = 'normal';\r\n  //     cell.style.minWidth = `${minWidth}px`;\r\n  //     cell.style.borderBottom = `2px solid ${this.themeModeClrVerticalLineColorForTable()}`\r\n  //   }\r\n\r\n  //   // Update existing rows' bottom border\r\n  //   for (let i = 0; i < this.selectedTable.rows.length; i++) {\r\n  //     this.selectedTable.rows[i].style.borderBottom = this.themeModeClrVerticalLineForTable();\r\n  //   }\r\n  // }\r\n  // }\r\n\r\n  addColumn() {\r\n    if (this.selectedTable) {\r\n      const columnCount = this.selectedTable.rows[0].cells.length + 1; // New column count\r\n      const tableWidth = this.selectedTable.offsetWidth;\r\n      const minWidth = tableWidth / columnCount;\r\n\r\n      // Get the current header background color if any\r\n      const firstHeaderCell = this.selectedTable.rows[0]\r\n        .cells[0] as HTMLElement;\r\n      const headerBgColor = firstHeaderCell\r\n        ? firstHeaderCell.style.backgroundColor\r\n        : \"\";\r\n\r\n      for (let i = 0; i < this.selectedTable.rows.length; i++) {\r\n        let cell = this.selectedTable.rows[i].insertCell(-1);\r\n        cell.innerHTML = \"&nbsp;\";\r\n        cell.style.wordWrap = \"break-word\";\r\n        cell.style.wordBreak = \"break-all\";\r\n        cell.style.whiteSpace = \"normal\";\r\n        cell.style.minWidth = `${minWidth}px`;\r\n        cell.style.borderBottom = \"1px solid #d3d3d3\";\r\n\r\n        // cell.style.borderBottom = `2px solid ${this.themeModeClrVerticalLineColorForTable()}`;\r\n\r\n        // If it's the first row, make it a header cell\r\n        if (i === 0) {\r\n          cell.classList.add(\"header-cell\");\r\n          cell.style.fontWeight = \"bold\";\r\n          cell.style.textAlign = \"start\";\r\n          cell.style.pointerEvents = \"none\";\r\n          cell.style.display = \"table-cell\";\r\n          cell.style.position = \"static\";\r\n          cell.style.borderTop = \"2px solid black\";\r\n          // cell.innerText = `Header ${columnCount}`;\r\n\r\n          // Apply the same background color as existing headers\r\n          if (headerBgColor) {\r\n            cell.style.backgroundColor = headerBgColor;\r\n          }\r\n        }\r\n      }\r\n\r\n      // Update existing rows' bottom border\r\n      // for (let i = 0; i < this.selectedTable.rows.length; i++) {\r\n      //   this.selectedTable.rows[i].style.borderBottom =\r\n      //     this.themeModeClrVerticalLineForTable();\r\n      // }\r\n      for (let i = 0; i < this.selectedTable.rows.length; i++) {\r\n        for (let j = 0; j < this.selectedTable.rows[i].cells.length; j++) {\r\n          this.selectedTable.rows[i].cells[j].style.borderBottom = \"1px solid #d3d3d3\";\r\n        }\r\n      }\r\n    }\r\n  }\r\n  \r\n\r\n\r\n\r\n\r\n  deleteColumn() {\r\n  if (this.selectedTable) {\r\n    if (window.getSelection) {\r\n      let selection = window.getSelection();\r\n      if (selection) {\r\n        let cell = selection.anchorNode?.parentElement?.closest('td, th') as HTMLTableCellElement;\r\n        if (cell) {\r\n          let cellIndex = cell.cellIndex;\r\n          for (let i = 0; i < this.selectedTable.rows.length; i++) {\r\n            this.selectedTable.rows[i].deleteCell(cellIndex);\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n\r\n  themeModeClrVerticalLineForTable() {\r\n    const clrMode = document.body.getAttribute('data-layout-color')\r\n    if (clrMode == 'dark') {\r\n      return '2px solid #414141 !important'\r\n    } else {\r\n      return '2px solid #5F5F5F !important'\r\n    }\r\n  }\r\n\r\n  themeModeClrVerticalLineColorForTable() {\r\n    const clrMode = document.body.getAttribute('data-layout-color')\r\n    if (clrMode == 'dark') {\r\n      return '#414141'\r\n    } else {\r\n      return '#5F5F5F'\r\n    }\r\n  }\r\n\r\n  adjustTableWidth(event: any) {\r\n    if (this.selectedTable) {\r\n      this.selectedTable.style.width = event.target.value + 'px';\r\n    }\r\n  }\r\n\r\n  adjustCellWidth(event: any) {\r\n    if (this.selectedTable) {\r\n      for (let i = 0; i < this.selectedTable.rows.length; i++) {\r\n        for (let j = 0; j < this.selectedTable.rows[i].cells.length; j++) {\r\n          this.selectedTable.rows[i].cells[j].style.width = event.target.value + 'px';\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  adjustCellHeight(event: any) {\r\n    if (this.selectedTable) {\r\n      for (let i = 0; i < this.selectedTable.rows.length; i++) {\r\n        for (let j = 0; j < this.selectedTable.rows[i].cells.length; j++) {\r\n          this.selectedTable.rows[i].cells[j].style.height = event.target.value + 'px';\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  private setCaretToEnd(element: HTMLElement) {\r\n    const range = document.createRange();\r\n    const sel = window.getSelection();\r\n      if (sel) {\r\n      range.selectNodeContents(element);\r\n    range.collapse(false);\r\n    sel.removeAllRanges();\r\n    sel.addRange(range);\r\n    }\r\n  }\r\n\r\n  // openColorPicker(inputId: string) {\r\n  //   const inputElement = document.getElementById(inputId);\r\n  //   if (inputElement) {\r\n  //     inputElement.click();\r\n  //   }\r\n  // }\r\n\r\n  // setTextColor(event: any) {\r\n  //   const editor = document.getElementById('editor');\r\n  //   if (editor) {\r\n  //     editor.focus();\r\n  //     const color = event.target.value;\r\n  //     this.selectedTextColor = color;\r\n  //     document.execCommand('foreColor', false, color);\r\n  //   }\r\n  // }\r\n\r\n  // setBackgroundColor(event: any) {\r\n  //   const editor = document.getElementById('editor');\r\n  //   if (editor) {\r\n  //     editor.focus();\r\n  //     const color = event.target.value;\r\n  //     this.backgroundColor = color;\r\n  //     document.execCommand('hiliteColor', false, color);\r\n  //   }\r\n  // }\r\n\r\n  private savedSelection: Range | null = null;\r\n\r\nopenColorPicker(inputId: string) {\r\n  const inputElement = document.getElementById(inputId) as HTMLInputElement;\r\n  if (inputElement) {\r\n    // Save the current selection\r\n    const selection = window.getSelection();\r\n    if (selection && selection.rangeCount > 0) {\r\n      this.savedSelection = selection.getRangeAt(0);\r\n    }\r\n    inputElement.click();\r\n  }\r\n}\r\n\r\n// setTextColor(event: any) {\r\n//   if (this.savedSelection) {\r\n//     const color = event.target.value;\r\n//     this.selectedTextColor = color;\r\n\r\n//     // Restore the saved selection\r\n//     const selection = window.getSelection();\r\n//     if (selection) {\r\n//       selection.removeAllRanges();\r\n//       selection.addRange(this.savedSelection);\r\n\r\n//       // Apply the color using a span\r\n//       const range = this.savedSelection;\r\n//       const span = document.createElement('span');\r\n//       span.style.color = color;\r\n//       span.textContent = range.toString();\r\n\r\n//       // Replace the selected text with the styled span\r\n//       range.deleteContents();\r\n//       range.insertNode(span);\r\n\r\n//       // Clear the saved selection\r\n//       this.savedSelection = null;\r\n//     }\r\n//   }\r\n  // }\r\n//   setTextColor(event: any) {\r\n//   if (this.savedSelection) {\r\n//     const color = event.target.value;\r\n//     this.selectedTextColor = color;\r\n\r\n//     // Restore the saved selection\r\n//     const selection = window.getSelection();\r\n//     if (selection && selection.rangeCount > 0) {\r\n//       const range = this.savedSelection;\r\n//       selection.removeAllRanges();\r\n//       selection.addRange(range);\r\n\r\n//       // Get selected elements\r\n//       const selectedContent = range.cloneContents();\r\n//       const elements = Array.from(selectedContent.querySelectorAll(\"*\")) as HTMLElement[]; // ✅ Explicitly cast to HTMLElement[]\r\n\r\n//       // Apply color to each element without modifying structure\r\n//       elements.forEach((el) => {\r\n//         el.style.color = color;\r\n//       });\r\n\r\n//       // Apply color to the top-level text nodes (without wrapping them)\r\n//       Array.from(selectedContent.childNodes).forEach((node) => {\r\n//         if (node.nodeType === Node.TEXT_NODE && node.textContent?.trim() !== \"\") {\r\n//           const parent = range.commonAncestorContainer.parentElement;\r\n//           if (parent) {\r\n//             parent.style.color = color;\r\n//           }\r\n//         }\r\n//       });\r\n\r\n//       // Replace selected content\r\n//       range.deleteContents();\r\n//       range.insertNode(selectedContent);\r\n\r\n//       // Clear saved selection\r\n//       this.savedSelection = null;\r\n//     }\r\n//   }\r\n// }\r\n\r\n// setTextColor(event: any) {\r\n//   console.log(\"Clicked setTextColor\");\r\n//   if (!this.savedSelection) {\r\n//     console.warn(\"No saved selection available!\");\r\n//     return;\r\n//   }\r\n\r\n//   const color = event.target.value;\r\n//   this.selectedTextColor = color;\r\n//   const selection = window.getSelection();\r\n\r\n//   if (!selection || selection.rangeCount === 0) {\r\n//     console.error(\"No valid selection found!\");\r\n//     return;\r\n//   }\r\n\r\n//   selection.removeAllRanges();\r\n//   selection.addRange(this.savedSelection);\r\n//   const range = this.savedSelection;\r\n\r\n//   const getTableCell = (node: Node | null): HTMLElement | null => {\r\n//     let currentNode = node;\r\n//     if (currentNode && currentNode.nodeType === Node.TEXT_NODE) {\r\n//       currentNode = currentNode.parentNode;\r\n//     }\r\n\r\n//     while (currentNode && currentNode instanceof HTMLElement) {\r\n//       if (currentNode.tagName === \"TD\" || currentNode.tagName === \"TH\") {\r\n//         return currentNode;\r\n//       }\r\n//       currentNode = currentNode.parentElement;\r\n//     }\r\n//     return null;\r\n//   };\r\n\r\n//   const tableCell =\r\n//     getTableCell(range.commonAncestorContainer) ||\r\n//     getTableCell(range.startContainer) ||\r\n//     getTableCell(range.endContainer);\r\n\r\n//   if (tableCell) {\r\n//     console.log(`Processing ${tableCell.tagName} element`);\r\n//     const selectedText = selection.toString();\r\n\r\n//     if (selectedText) {\r\n//       console.log(`Selected text in ${tableCell.tagName}:`, selectedText);\r\n//       const textNodes: Text[] = [];\r\n//       const walker = document.createTreeWalker(\r\n//         tableCell,\r\n//         NodeFilter.SHOW_TEXT,\r\n//         null\r\n//       );\r\n//       let node: Text | null;\r\n\r\n//       while ((node = walker.nextNode() as Text | null)) {\r\n//         textNodes.push(node);\r\n//       }\r\n\r\n//       for (const textNode of textNodes) {\r\n//         const text = textNode.textContent || \"\";\r\n//         const index = text.indexOf(selectedText);\r\n\r\n//         if (index !== -1) {\r\n//           console.log(\r\n//             `Found selected text in ${tableCell.tagName} text node`\r\n//           );\r\n\r\n//           const span = document.createElement(\"span\");\r\n//           span.style.color = color;\r\n//           span.textContent = selectedText;\r\n\r\n//           const beforeText = text.slice(0, index);\r\n//           const afterText = text.slice(index + selectedText.length);\r\n\r\n//           const fragment = document.createDocumentFragment();\r\n//           if (beforeText)\r\n//             fragment.appendChild(document.createTextNode(beforeText));\r\n//           fragment.appendChild(span);\r\n//           if (afterText)\r\n//             fragment.appendChild(document.createTextNode(afterText));\r\n\r\n//           textNode.replaceWith(fragment);\r\n//           break; // Apply only once per selection\r\n//         }\r\n//       }\r\n//     }\r\n//   } else {\r\n//     console.log(\"No TH or TD element found in selection\");\r\n//     return;\r\n//   }\r\n\r\n//   this.savedSelection = null;\r\n// }\r\n\r\nsetTextColor(event: any) {\r\n  console.log(\"clicked\");\r\n\r\n  if (!this.savedSelection) {\r\n      console.warn(\"No saved selection available!\");\r\n      return;\r\n  }\r\n\r\n  const color = event.target.value;\r\n  console.log(\"color\", color);\r\n\r\n  this.selectedTextColor = color;\r\n  const selection = window.getSelection();\r\n\r\n  if (!selection || selection.rangeCount === 0) {\r\n      console.error(\"No valid selection found!\");\r\n      return;\r\n  }\r\n\r\n  selection.removeAllRanges();\r\n  selection.addRange(this.savedSelection);\r\n  const range = this.savedSelection;\r\n\r\n  const getParentElement = (node: Node | null): HTMLElement | null => {\r\n      let currentNode = node;\r\n      if (currentNode && currentNode.nodeType === Node.TEXT_NODE) {\r\n          currentNode = currentNode.parentNode;\r\n      }\r\n\r\n      while (currentNode && currentNode instanceof HTMLElement) {\r\n          return currentNode;\r\n      }\r\n      return null;\r\n  };\r\n\r\n  const parentElement =\r\n      getParentElement(range.commonAncestorContainer) ||\r\n      getParentElement(range.startContainer) ||\r\n      getParentElement(range.endContainer);\r\n\r\n  if (!parentElement) {\r\n      console.error(\"No valid parent element found!\");\r\n      return;\r\n  }\r\n\r\n  // **Handle Table Cell Case**\r\n  if (parentElement.tagName === \"TD\") {\r\n      parentElement.style.color = color; // Apply color directly to cell\r\n      return;\r\n  }\r\n\r\n  // **Handle Normal Text Case**\r\n  const selectedText = selection.toString();\r\n\r\n  if (selectedText) {\r\n      const textNodes: Text[] = [];\r\n      const walker = document.createTreeWalker(\r\n          parentElement,\r\n          NodeFilter.SHOW_TEXT,\r\n          null\r\n      );\r\n      let node: Text | null;\r\n\r\n      while ((node = walker.nextNode() as Text | null)) {\r\n          textNodes.push(node);\r\n      }\r\n\r\n      for (const textNode of textNodes) {\r\n          const text = textNode.textContent || \"\";\r\n          const index = text.indexOf(selectedText);\r\n\r\n          if (index !== -1) {\r\n              const span = document.createElement(\"span\");\r\n              span.style.color = color;\r\n              span.textContent = selectedText;\r\n\r\n              const beforeText = text.slice(0, index);\r\n              const afterText = text.slice(index + selectedText.length);\r\n\r\n              const fragment = document.createDocumentFragment();\r\n\r\n              if (beforeText)\r\n                  fragment.appendChild(document.createTextNode(beforeText));\r\n              fragment.appendChild(span);\r\n              if (afterText)\r\n                  fragment.appendChild(document.createTextNode(afterText));\r\n\r\n              textNode.replaceWith(fragment);\r\n              break; // Apply only once per selection\r\n          }\r\n      }\r\n  }\r\n\r\n  this.savedSelection = null;\r\n}\r\n\r\n  setBackgroundColor(event: any) {\r\n  if (this.savedSelection) {\r\n    const color = event.target.value;\r\n    this.backgroundColor = color;\r\n\r\n    // Restore the saved selection\r\n    const selection = window.getSelection();\r\n    if (selection) {\r\n      selection.removeAllRanges();\r\n      selection.addRange(this.savedSelection);\r\n\r\n      // Apply the background color using a span\r\n      const range = this.savedSelection;\r\n      const span = document.createElement('span');\r\n      span.style.backgroundColor = color;\r\n      span.textContent = range.toString();\r\n\r\n      // Replace the selected text with the styled span\r\n      range.deleteContents();\r\n      range.insertNode(span);\r\n\r\n      // Clear the saved selection\r\n      this.savedSelection = null;\r\n    }\r\n  }\r\n  }\r\n  \r\n  // colorChanged(event: any) {\r\n  //   this.color = event.color.hex; \r\n  // }\r\n\r\n  public logEvent(event: any, trigger: any) {\r\n    const color = event;\r\n    this.setTextColor(color)\r\n    this.selectedTextColor = event\r\n    document.execCommand('foreColor', false, event);\r\n    // this.logs.unshift([this.logs.length + 1, trigger, event]);\r\n  }\r\n  \r\n\r\n  editImage() {\r\n    let data \r\n    switch (this.editorFrom.name) {\r\n      case 'section-content':\r\n        data = { editIMG: true, from: 'htmlEditor', index: this.selectedItemIndex, id: this.editorFrom.id };\r\n        const compressedData: string = compress(JSON.stringify(this.imageEditUrl));\r\n        sessionStorage.setItem('editImageFromTemp', compressedData);\r\n        const compressedData2 = compress(JSON.stringify(this.sanitizedContent));\r\n        sessionStorage.setItem('textEditor', compressedData2);\r\n        // alert('go to editor!')\r\n        this.navigateToIMGEditor(data);\r\n        this.imageEdit.emit()\r\n        break;\r\n      case 'create-document':\r\n        this.imageEdit.emit()\r\n        data = { editIMG: true, from: 'createDocument', index: this.selectedItemIndex, id: this.editorFrom.id, section: this.editorFrom.section, reportSectionId: this.editorFrom.reportSectionId };\r\n        // this.openDialog(data)\r\n        const compressedData3 = compress(JSON.stringify(this.imageEditUrl));\r\n        const compressedData4 = compress(this.editorText);\r\n\r\n        sessionStorage.setItem('editImageFromTemp2', compressedData3);\r\n        sessionStorage.setItem('textEditor2', compressedData4);\r\n        this.navigateToIMGEditor(data);\r\n        break;\r\n      default:\r\n        null\r\n        // sessionStorage.removeItem('editImageFromTemp');\r\n        // sessionStorage.removeItem('editImageFromTemp2');\r\n        // sessionStorage.removeItem('templateEditor');\r\n        // sessionStorage.removeItem('textEditor');\r\n        break;\r\n    }\r\n    // if (this.editorFrom === 'section-content') {\r\n    //   const data = {editIMG: true, from: 'htmlEditor', index: this.selectedItemIndex}\r\n    //   this.navigateToIMGEditor(data)\r\n    //   sessionStorage.setItem('editImageFromTemp', JSON.stringify(this.imageEditUrl))\r\n    //   sessionStorage.setItem('textEditor', this.editorText)\r\n    // } \r\n    \r\n  }\r\n\r\n  openDialog( item: any): void {\r\n    // let data: any;\r\n    //   data = item\r\n    // const dialogRef = this.dialog.open(ImageEditorModalComponent,{\r\n    //   minWidth: '100%', minHeight: '100vh', panelClass: 'theme-2B2936' ,disableClose: true, data: data\r\n    // });\r\n    // dialogRef.afterClosed().subscribe(result => {\r\n    //   console.log('result ===> img = ', result)\r\n    //   const imgUrl = sessionStorage.getItem('editImageFromTemp2');\r\n    //     if (imgUrl) {\r\n    //       this.replaceImageSrc(imgUrl,  result.index.index);\r\n    //       sessionStorage.removeItem('editImageFromTemp2');\r\n    //     }\r\n    // });\r\n  }\r\n\r\n  replaceImageSRC(newSrc: string, index: number) {\r\n    const parser = new DOMParser();\r\n    const doc = parser.parseFromString(this.editorText, 'text/html');\r\n    const imgTags = doc.getElementsByTagName('img');\r\n\r\n  if (imgTags && imgTags.length > 0) {\r\n    if (index >= 0 && index < imgTags.length) {\r\n      // Update the src attribute of the img at the specified index\r\n      \r\n      imgTags[index].setAttribute('src', newSrc);\r\n      this.editorText = doc.body.innerHTML;\r\n    \r\n    } \r\n  } \r\n  }\r\n\r\n  navigateToIMGEditor(data: any) {\r\n    this.router.navigate(['/admin/image-editor'], { queryParams: {data : JSON.stringify(data)} })\r\n  }\r\n\r\n  //  onTextSelect(event: MouseEvent): void {\r\n  //   if (this.toolbarMode === 'bubble') {\r\n  //     const selection = window.getSelection();\r\n  //     if (selection && selection.rangeCount > 0) {\r\n  //       const range = selection.getRangeAt(0);\r\n  //       if (!range.collapsed) {\r\n  //         const rect = range.getBoundingClientRect();\r\n  //         this.toolbarTop = rect.bottom + window.scrollY + 10;\r\n  //         this.toolbarLeft = rect.left + window.scrollX + (rect.width / 2) - 50;\r\n  //         this.showToolbar = true;\r\n  //       } else {\r\n  //         this.showToolbar = false;\r\n  //       }\r\n  //     }\r\n  //   }\r\n  // }\r\n\r\n onTextSelect(event?: MouseEvent): void {\r\n  if (this.toolbarMode === 'bubble') {\r\n    const selection = window.getSelection();\r\n    if (selection && selection.rangeCount > 0) {\r\n      const range = selection.getRangeAt(0);\r\n      if (!range.collapsed) {\r\n        const rect = range.getBoundingClientRect();\r\n        const scrollY =  document.documentElement.scrollTop;\r\n        const scrollX =  document.documentElement.scrollLeft;\r\n        this.toolbarTop = rect.top + scrollY - 75;\r\n        this.toolbarLeft = rect.left + scrollX + (rect.width / 2) - 325;\r\n        this.showToolbar = true;\r\n      } else {\r\n        this.showToolbar = false;\r\n      }\r\n    } else {\r\n      this.showToolbar = false;\r\n    }\r\n  }\r\n}\r\n\r\n\r\n// onPaste(event: ClipboardEvent) {\r\n//     event.preventDefault();\r\n//     const clipboardData = event.clipboardData;\r\n//     if (clipboardData) {\r\n//       const pastedText = clipboardData.getData('text/plain');\r\n//       if (this.isTableData(pastedText)) {\r\n//         const html = this.convertTextToTable(pastedText);\r\n//         this.insertHtmlAtCaret(html);\r\n//       } else {\r\n//         this.insertHtmlAtCaret(pastedText);\r\n//       }\r\n//     }\r\n//   }\r\n\r\n  // onPaste(event: ClipboardEvent) {\r\n  //   event.preventDefault();\r\n  //   const clipboardData = event.clipboardData;\r\n  //   if (clipboardData) {\r\n  //     // Handle image data\r\n  //     const items = clipboardData.items;\r\n  //     for (let i = 0; i < items.length; i++) {\r\n  //       if (items[i].type.startsWith('image/')) {\r\n  //         const file = items[i].getAsFile();\r\n  //         if (file) {\r\n  //           const reader = new FileReader();\r\n  //           reader.onload = (e: any) => {\r\n  //             const imgHtml = `<img src=\"${e.target.result}\" alt=\"Pasted Image\" style=\"max-width: 100%;\"/>`;\r\n  //             this.insertHtmlAtCaret(imgHtml);\r\n  //           };\r\n  //           reader.readAsDataURL(file);\r\n  //           return; // Exit if an image is handled\r\n  //         }\r\n  //       }\r\n  //     }\r\n\r\n  //     // Handle text or table data\r\n  //     const pastedText = clipboardData.getData('text/plain');\r\n  //     if (this.isTableData(pastedText)) {\r\n  //       const html = this.convertTextToTable(pastedText);\r\n  //       this.insertHtmlAtCaret(html);\r\n  //     } else {\r\n  //       this.insertHtmlAtCaret(pastedText);\r\n  //     }\r\n  //   }\r\n  // }\r\n\r\n  onPaste(event: ClipboardEvent) {\r\n    event.preventDefault();\r\n    const clipboardData = event.clipboardData;\r\n    if (clipboardData) {\r\n      for (let i = 0; i < clipboardData.items.length; i++) {\r\n        const item = clipboardData.items[i];\r\n\r\n        if (item.type.startsWith(\"image/\")) {\r\n          // Handle image paste\r\n          const file = item.getAsFile();\r\n          if (file) {\r\n            const reader = new FileReader();\r\n            reader.onload = (e: any) => {\r\n              const imgHtml = `<img src=\"${e.target.result}\" alt=\"Pasted Image\" style=\"max-width: 100%;\" />`;\r\n              this.insertHtmlAtCaret(imgHtml);\r\n            };\r\n            reader.readAsDataURL(file);\r\n            return;\r\n          }\r\n        } else if (item.type === \"text/html\") {\r\n          // Handle HTML paste\r\n          // const htmlData = clipboardData.getData(\"text/html\");\r\n          if (this.isTableData(clipboardData.getData('text/html'))) {\r\n            const html = this.convertTextToTable(clipboardData.getData('text/html'));\r\n            this.insertHtmlAtCaret(html);\r\n          } else {\r\n            this.insertHtmlAtCaret(clipboardData.getData('text/html'));\r\n          }\r\n          // this.insertHtmlAtCaret(htmlData);\r\n          return;\r\n        } else if (item.type === \"text/plain\") {\r\n          // Handle plain text paste\r\n          if (this.isTableData(clipboardData.getData('text/plain'))) {\r\n            const html = this.convertTextToTable(clipboardData.getData('text/plain'));\r\n            this.insertHtmlAtCaret(html);\r\n          } else {\r\n            this.insertHtmlAtCaret(clipboardData.getData('text/plain'));\r\n          }\r\n          // const plainText = clipboardData.getData(\"text/plain\");\r\n          // this.insertHtmlAtCaret(plainText);\r\n          return;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  isExcelData(html: string): boolean {\r\n    return html.includes('xmlns:o=\"urn:schemas-microsoft-com:office:office\"') || \r\n          html.includes('xmlns:x=\"urn:schemas-microsoft-com:office:excel\"');\r\n  }\r\n\r\n  convertExcelHtmlToTable(html: string): string {\r\n    const parser = new DOMParser();\r\n    const doc = parser.parseFromString(html, 'text/html');\r\n    const table = doc.querySelector('table');\r\n    return table ? table.outerHTML : ''; // Extract only the table part\r\n  }\r\n\r\n\r\n\r\n\r\n  isTableData(text: string): boolean {\r\n    const rows = text.split('\\n');\r\n    return rows.length > 1 && rows[0].split('\\t').length > 1;\r\n  }\r\n\r\n  // convertTextToTable(text: string): string {\r\n  //   const rows = text.split('\\n').filter(row => row.trim() !== '');\r\n  //   const tableRows = rows.map(row => {\r\n  //     const cells = row.split('\\t').map(cell => `<td class=\"px-1 py-1\" >${cell}</td>`).join('');\r\n  //     return `<tr class=\"table-border-top\" style=\"border-top: ${this.themeModeTableBorderTop()}; width: 100% !important\">${cells}</tr>`;\r\n  //   }).join('');\r\n  //   return `<table>${tableRows}</table>`;\r\n  // }\r\n\r\n  convertTextToTable(text: string): string {\r\n    const rows = text.split('\\n').filter(row => row.trim() !== '');\r\n    const columnCount = rows[0]?.split('\\t').length || 1; // Get the number of columns from the first row\r\n    const columnWidth = 100 / columnCount; // Calculate column width\r\n\r\n    const tableRows = rows.map((row, index) => {\r\n      const cells = row.split('\\t').map(cell => `\r\n        <td class=\"px-1 py-1 text-truncate\" \r\n            style=\"max-width: ${columnWidth}%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;\">\r\n          ${cell}\r\n        </td>`).join('');\r\n\r\n      // Add a border-top for all rows except the first and border-bottom for the last row\r\n      const borderTop = index === 0 ? '' : `border-top: ${this.themeModeTableBorderTop()};`;\r\n      const borderBottom = index === rows.length - 1 ? `border-bottom: ${this.themeModeTableBorderTop()};` : '';\r\n\r\n      return `\r\n        <tr \r\n          style=\"${borderTop} ${borderBottom} width: 100% !important;\">\r\n          ${cells}\r\n        </tr>`;\r\n    }).join('');\r\n\r\n    return `\r\n      <table style=\"table-layout: fixed; width: 100%;\"> \r\n        ${tableRows}\r\n      </table>`;\r\n  }\r\n\r\n\r\n\r\n  insertHtmlAtCaret(html: string) {\r\n    const range = window.getSelection()?.getRangeAt(0);\r\n    if (range) {\r\n      range.deleteContents();\r\n      const tempDiv = document.createElement('div');\r\n      tempDiv.innerHTML = html;\r\n      const frag = document.createDocumentFragment();\r\n      let node;\r\n      while ((node = tempDiv.firstChild)) {\r\n        frag.appendChild(node);\r\n      }\r\n      range.insertNode(frag);\r\n      range.collapse(false);\r\n    }\r\n  }\r\n\r\n  themeModeTableBorderTop() {\r\n    const clrMode = document.body.getAttribute('data-layout-color')\r\n    if (clrMode == 'dark') {\r\n      return '1px solid #D0D0D0; !important'\r\n    } else {\r\n      return '1px solid #414141 !important'\r\n    }\r\n  }\r\n\r\n \r\n  public openFullscreen() {\r\n    var elem: any = document.getElementById(\"textEditor\");\r\n    this.isFullScreen = true;\r\n    if (elem.requestFullscreen) {\r\n      elem.requestFullscreen();\r\n    } else if (elem.mozRequestFullScreen) {\r\n      elem.mozRequestFullScreen();\r\n    } else if (elem.webkitRequestFullscreen) {\r\n      elem.webkitRequestFullscreen();\r\n    } else if (elem.msRequestFullscreen) {\r\n      elem.msRequestFullscreen();\r\n    }\r\n    this.style = {\r\n      'min-height': '90vh',\r\n      'max-height': '90vh',\r\n    }\r\n  }\r\n\r\n  public closeFullscreen() {\r\n    if (document.exitFullscreen) {\r\n      document.exitFullscreen();\r\n      this.isFullScreen = false;\r\n      this.style = {\r\n        'min-height': '400px',\r\n        'max-height': '400px',\r\n      }\r\n    }\r\n  }\r\n  \r\n  clearTextEditor() {\r\n    this.editorTextClear.emit()\r\n  }\r\n\r\n  setupHistory() {\r\n    this.saveState();\r\n     const editor = document.getElementById('editor');\r\n  \r\n    if (editor) {\r\n      editor.addEventListener('input', () => this.onInput());\r\n    }\r\n  }\r\n\r\n  onInput() {\r\n    this.saveState();\r\n  }\r\n\r\n  saveState() {\r\n    const editor = document.getElementById('editor');\r\n  \r\n    if (editor) {\r\n      const editorContent = editor.innerHTML;\r\n      if (this.historyIndex === this.history.length - 1) {\r\n        this.history.push(editorContent);\r\n        this.redoStack = [];\r\n      } else {\r\n        this.history = this.history.slice(0, this.historyIndex + 1);\r\n        this.history.push(editorContent);\r\n        this.redoStack = [];\r\n      }\r\n      this.historyIndex++;\r\n    }\r\n  }\r\n  undo() {\r\n    if (this.historyIndex > 0) {\r\n      this.redoStack.push(this.history[this.historyIndex]);\r\n      this.historyIndex--;\r\n      const editor = document.getElementById('editor');\r\n  \r\n      if (editor) {\r\n        this.sanitizedContent = this.history[this.historyIndex];\r\n      }\r\n    }\r\n  }\r\n\r\n  redo() {\r\n    if (this.redoStack.length > 0) {\r\n      const redoContent = this.redoStack.pop();\r\n      this.history.push(redoContent!);\r\n      this.historyIndex++;\r\n      const editor = document.getElementById('editor');\r\n  \r\n      if (editor) {\r\n        this.sanitizedContent = redoContent!;\r\n      }\r\n    }\r\n  }\r\n\r\n//   formatTextWithDates(text: string): string {\r\n//   // Regular expression to detect YYYY-MM-DD formatted dates\r\n//   const dateRegex = /\\b\\d{4}-\\d{2}-\\d{2}\\b/g;\r\n\r\n//   // Replace found dates with a formatted version\r\n//   return text.replace(dateRegex, (dateStr) => {\r\n//     // Convert the detected date string into a Date object\r\n//     const dateObj = new Date(dateStr);\r\n    \r\n//     // Format the date to 'Month Day, Year' (e.g., October 10, 2024)\r\n//     return dateObj.toLocaleDateString('en-US', {\r\n//       year: 'numeric',\r\n//       month: 'long',\r\n//       day: 'numeric',\r\n//     });\r\n//   });\r\n  // }\r\n  \r\n  formatTextWithDates(text: string): string {\r\n  // Regular expression to detect YYYY-MM-DD formatted dates\r\n  const dateRegex = /\\b\\d{4}-\\d{2}-\\d{2}\\b/g;\r\n\r\n  // Replace found dates with a formatted version\r\n  return text.replace(dateRegex, (dateStr) => {\r\n    // Convert the detected date string into a Date object\r\n    const dateObj = new Date(dateStr);\r\n\r\n    // Extract day, month, and year\r\n    const day = dateObj.getDate().toString().padStart(2, '0'); // Ensure day is two digits\r\n    const month = dateObj.toLocaleString('en-US', { month: 'short' }); // Get abbreviated month name\r\n    const year = dateObj.getFullYear(); // Get full year\r\n\r\n    // Format the date as 'dd/mmm/yyyy'\r\n    return `${day}/${month}/${year}`;\r\n  });\r\n}\r\n\r\n\r\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                    <button \r\n          \r\n          type=\"button\" \r\n          class=\"btn btn-white els-toolbar-button\" \r\n          *ngIf=\"isTableSelected\" \r\n          [style.color]=\"tHeadBgColor\" \r\n          (click)=\"openColorPicker('tHeadbgColorPicker')\" \r\n        > \r\n          <i class=\"mdi mdi-table-edit\"></i> \r\n        </button> \r\n        <input \r\n          type=\"color\" \r\n          id=\"tHeadbgColorPicker\" \r\n          style=\" \r\n            position: absolute; \r\n            top: 100%; \r\n            left: 0; \r\n            z-index: 100; \r\n            opacity: 0; \r\n          \" \r\n          (change)=\"setTheadBgColor($event)\" \r\n        />\r\n            </div>\r\n            <!-- <div class=\"btn-group els-button-group mr-2\" role=\"group\" aria-label=\"Text Formatting\">\r\n                <button type=\"button\" class=\"btn btn-white els-toolbar-button\" (click)=\"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 [attr.contenteditable]=\"contentEditable\" 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)\" (keydown.Tab)=\"handleTabKey($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>"]}