@syncfusion/ej2-richtexteditor 20.4.43 → 20.4.48

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.
Files changed (69) hide show
  1. package/CHANGELOG.md +30 -0
  2. package/dist/ej2-richtexteditor.min.js +2 -2
  3. package/dist/ej2-richtexteditor.umd.min.js +2 -2
  4. package/dist/ej2-richtexteditor.umd.min.js.map +1 -1
  5. package/dist/es6/ej2-richtexteditor.es2015.js +89 -30
  6. package/dist/es6/ej2-richtexteditor.es2015.js.map +1 -1
  7. package/dist/es6/ej2-richtexteditor.es5.js +89 -30
  8. package/dist/es6/ej2-richtexteditor.es5.js.map +1 -1
  9. package/dist/global/ej2-richtexteditor.min.js +2 -2
  10. package/dist/global/ej2-richtexteditor.min.js.map +1 -1
  11. package/dist/global/index.d.ts +1 -1
  12. package/package.json +12 -12
  13. package/src/editor-manager/plugin/inserthtml.js +1 -1
  14. package/src/editor-manager/plugin/lists.js +6 -1
  15. package/src/editor-manager/plugin/selection-commands.js +57 -17
  16. package/src/rich-text-editor/base/rich-text-editor-model.d.ts +1 -1
  17. package/src/rich-text-editor/base/rich-text-editor.d.ts +1 -1
  18. package/src/rich-text-editor/base/rich-text-editor.js +4 -4
  19. package/src/rich-text-editor/models/items.js +1 -1
  20. package/src/rich-text-editor/renderer/audio-module.js +4 -1
  21. package/src/rich-text-editor/renderer/image-module.js +4 -1
  22. package/src/rich-text-editor/renderer/table-module.js +5 -2
  23. package/src/rich-text-editor/renderer/toolbar-renderer.js +3 -1
  24. package/src/rich-text-editor/renderer/video-module.js +4 -1
  25. package/styles/bootstrap-dark.css +18 -18
  26. package/styles/bootstrap.css +18 -18
  27. package/styles/bootstrap4.css +18 -18
  28. package/styles/bootstrap5-dark.css +18 -18
  29. package/styles/bootstrap5.css +18 -18
  30. package/styles/fabric-dark.css +18 -18
  31. package/styles/fabric.css +18 -18
  32. package/styles/fluent-dark.css +18 -18
  33. package/styles/fluent.css +18 -18
  34. package/styles/highcontrast-light.css +18 -18
  35. package/styles/highcontrast.css +18 -18
  36. package/styles/material-dark.css +18 -18
  37. package/styles/material.css +18 -18
  38. package/styles/rich-text-editor/_layout.scss +3 -3
  39. package/styles/rich-text-editor/bootstrap-dark.css +18 -18
  40. package/styles/rich-text-editor/bootstrap.css +18 -18
  41. package/styles/rich-text-editor/bootstrap4.css +18 -18
  42. package/styles/rich-text-editor/bootstrap5-dark.css +18 -18
  43. package/styles/rich-text-editor/bootstrap5.css +18 -18
  44. package/styles/rich-text-editor/fabric-dark.css +18 -18
  45. package/styles/rich-text-editor/fabric.css +18 -18
  46. package/styles/rich-text-editor/fluent-dark.css +18 -18
  47. package/styles/rich-text-editor/fluent.css +18 -18
  48. package/styles/rich-text-editor/highcontrast-light.css +18 -18
  49. package/styles/rich-text-editor/highcontrast.css +18 -18
  50. package/styles/rich-text-editor/icons/_bootstrap-dark.scss +1 -1
  51. package/styles/rich-text-editor/icons/_bootstrap.scss +1 -1
  52. package/styles/rich-text-editor/icons/_bootstrap4.scss +1 -1
  53. package/styles/rich-text-editor/icons/_bootstrap5.scss +1 -1
  54. package/styles/rich-text-editor/icons/_fabric-dark.scss +1 -1
  55. package/styles/rich-text-editor/icons/_fabric.scss +1 -1
  56. package/styles/rich-text-editor/icons/_fluent.scss +1 -1
  57. package/styles/rich-text-editor/icons/_fusionnew.scss +1 -1
  58. package/styles/rich-text-editor/icons/_highcontrast-light.scss +1 -1
  59. package/styles/rich-text-editor/icons/_highcontrast.scss +1 -1
  60. package/styles/rich-text-editor/icons/_material-dark.scss +1 -1
  61. package/styles/rich-text-editor/icons/_material.scss +1 -1
  62. package/styles/rich-text-editor/icons/_material3.scss +1 -1
  63. package/styles/rich-text-editor/icons/_tailwind.scss +1 -1
  64. package/styles/rich-text-editor/material-dark.css +18 -18
  65. package/styles/rich-text-editor/material.css +18 -18
  66. package/styles/rich-text-editor/tailwind-dark.css +18 -18
  67. package/styles/rich-text-editor/tailwind.css +18 -18
  68. package/styles/tailwind-dark.css +18 -18
  69. package/styles/tailwind.css +18 -18
@@ -1450,7 +1450,7 @@ var tools = {
1450
1450
  },
1451
1451
  'fontcolor': {
1452
1452
  'id': 'FontColor',
1453
- 'icon': 'e-font-color',
1453
+ 'icon': 'e-rte-font-color',
1454
1454
  'tooltip': 'Font Color',
1455
1455
  'command': 'Font',
1456
1456
  'subCommand': 'FontColor',
@@ -3327,6 +3327,8 @@ var ToolbarRenderer = /** @__PURE__ @class */ (function () {
3327
3327
  target: colorPicker.element.parentElement, cssClass: css,
3328
3328
  enablePersistence: this.parent.enablePersistence, enableRtl: this.parent.enableRtl,
3329
3329
  beforeOpen: function (dropDownArgs) {
3330
+ colorPicker.inline = true;
3331
+ colorPicker.dataBind();
3330
3332
  if (proxy.parent.readonly || !proxy.parent.enabled) {
3331
3333
  dropDownArgs.cancel = true;
3332
3334
  return;
@@ -3494,7 +3496,7 @@ var ToolbarRenderer = /** @__PURE__ @class */ (function () {
3494
3496
  var colorPicker = new ColorPicker({
3495
3497
  enablePersistence: this.parent.enablePersistence,
3496
3498
  enableRtl: this.parent.enableRtl,
3497
- inline: true,
3499
+ inline: false,
3498
3500
  value: '#fff',
3499
3501
  created: function () {
3500
3502
  var value = (item === 'backgroundcolor') ? proxy.parent.backgroundColor.default : proxy.parent.fontColor.default;
@@ -11272,7 +11274,7 @@ var Lists = /** @__PURE__ @class */ (function () {
11272
11274
  range.startContainer.parentElement.closest('LI');
11273
11275
  var endNode = range.endContainer.nodeName === 'LI' ? range.endContainer :
11274
11276
  range.endContainer.parentElement.closest('LI');
11275
- // Checks for Image, Audio , Video Element inside List Element
11277
+ // Checks for Image, Audio , Video Element inside List Element
11276
11278
  var hasMediaElem = false;
11277
11279
  if (!isNullOrUndefined(startNode)) {
11278
11280
  var videoElemList = startNode.querySelectorAll('.e-video-clickelem');
@@ -11899,6 +11901,11 @@ var Lists = /** @__PURE__ @class */ (function () {
11899
11901
  }
11900
11902
  node.parentNode.removeChild(node);
11901
11903
  }
11904
+ else if (!isNullOrUndefined(node.getAttribute('level'))) {
11905
+ if (node.tagName === node.previousElementSibling.tagName) {
11906
+ node.previousElementSibling.lastChild.append(node);
11907
+ }
11908
+ }
11902
11909
  }
11903
11910
  };
11904
11911
  Lists.prototype.findUnSelected = function (temp, elements) {
@@ -13100,7 +13107,7 @@ var InsertHtml = /** @__PURE__ @class */ (function () {
13100
13107
  detach(currentNode.nextSibling);
13101
13108
  }
13102
13109
  }
13103
- else if (currentNode.nodeName === '#text' && !isNullOrUndefined(currentNode.parentElement) &&
13110
+ else if ((currentNode.nodeName === '#text' || currentNode.nodeName === "BR") && !isNullOrUndefined(currentNode.parentElement) &&
13104
13111
  (currentNode.parentElement.nodeName === 'LI' || (blockNode === editNode && currentNode.parentElement === blockNode)) &&
13105
13112
  currentNode.parentElement.textContent.trim().length > 0) {
13106
13113
  splitedElm = currentNode;
@@ -15739,14 +15746,17 @@ var SelectionCommands = /** @__PURE__ @class */ (function () {
15739
15746
  isSubSup = formatNode === null ? false : true;
15740
15747
  }
15741
15748
  }
15749
+ else if ((format === 'fontsize' || format === 'fontname' || format === 'fontcolor' || format === 'backgroundcolor') && range.startContainer.parentElement === endNode) {
15750
+ formatNode = null;
15751
+ }
15742
15752
  if (index === 0 && formatNode === null) {
15743
15753
  isFormat = true;
15744
15754
  }
15745
15755
  if (formatNode !== null && (!isFormat || isFontStyle)) {
15746
15756
  nodes[index] = this.removeFormat(nodes, index, formatNode, isCursor, isFormat, isFontStyle, range, nodeCutter, format, value, domSelection, endNode, domNode);
15747
15757
  }
15748
- else {
15749
- nodes[index] = this.insertFormat(docElement, nodes, index, formatNode, isCursor, isFormat, isFontStyle, range, nodeCutter, format, value);
15758
+ else if (range.startContainer.parentElement !== endNode || (range.commonAncestorContainer === endNode || nodes.length === 1)) {
15759
+ nodes[index] = this.insertFormat(docElement, nodes, index, formatNode, isCursor, isFormat, isFontStyle, range, nodeCutter, format, value, domNode, endNode);
15750
15760
  }
15751
15761
  domSelection = this.applySelection(nodes, domSelection, nodeCutter, index, isCollapsed);
15752
15762
  }
@@ -16001,10 +16011,24 @@ var SelectionCommands = /** @__PURE__ @class */ (function () {
16001
16011
  }
16002
16012
  return nodes[index];
16003
16013
  };
16004
- SelectionCommands.insertFormat = function (docElement, nodes, index, formatNode, isCursor, isFormat, isFontStyle, range, nodeCutter, format, value) {
16014
+ SelectionCommands.insertFormat = function (docElement, nodes, index, formatNode, isCursor, isFormat, isFontStyle, range, nodeCutter, format, value, domNode, endNode) {
16015
+ var rootElementNode;
16005
16016
  if (!isCursor) {
16006
16017
  if ((formatNode === null && isFormat) || isFontStyle) {
16007
16018
  if (nodes[index].nodeName !== 'BR') {
16019
+ if (format === 'fontsize' || format === 'fontname' || format === 'fontcolor' || format === 'backgroundcolor') {
16020
+ var rangeNode = nodes[index];
16021
+ while (rangeNode && !domNode.isBlockNode(rangeNode) && rangeNode !== endNode) {
16022
+ if (domNode.isBlockNode(rangeNode.parentElement)) {
16023
+ rootElementNode = rangeNode;
16024
+ }
16025
+ rangeNode = rangeNode.parentElement;
16026
+ }
16027
+ if (rootElementNode && rootElementNode.nodeType !== 3) {
16028
+ nodeCutter.SplitNode(range, rootElementNode, true).cloneNode(true);
16029
+ nodeCutter.SplitNode(range, rootElementNode, false).cloneNode(false);
16030
+ }
16031
+ }
16008
16032
  nodes[index] = nodeCutter.GetSpliceNode(range, nodes[index]);
16009
16033
  nodes[index].textContent = nodeCutter.TrimLineBreak(nodes[index].textContent);
16010
16034
  }
@@ -16014,24 +16038,47 @@ var SelectionCommands = /** @__PURE__ @class */ (function () {
16014
16038
  }
16015
16039
  else if (!(isFontStyle === true && value === '')) {
16016
16040
  var element = this.GetFormatNode(format, value);
16017
- if (format === 'fontsize' || format === 'fontcolor') {
16018
- var liElement = nodes[index].parentElement;
16019
- var parentElement = nodes[index].parentElement;
16020
- while (!isNullOrUndefined(parentElement) && parentElement.tagName.toLowerCase() !== 'li') {
16021
- parentElement = parentElement.parentElement;
16022
- liElement = parentElement;
16041
+ if (format === 'fontsize' || format === 'fontcolor' || format === 'fontname' || format === 'backgroundcolor') {
16042
+ if (format !== 'fontname' && format !== 'backgroundcolor') {
16043
+ var liElement = nodes[index].parentElement;
16044
+ var parentElement = nodes[index].parentElement;
16045
+ while (!isNullOrUndefined(parentElement) && parentElement.tagName.toLowerCase() !== 'li' && parentElement !== endNode) {
16046
+ parentElement = parentElement.parentElement;
16047
+ liElement = parentElement;
16048
+ }
16049
+ if (!isNullOrUndefined(liElement) && liElement.tagName.toLowerCase() === 'li' &&
16050
+ liElement.textContent.trim() === nodes[index].textContent.trim()) {
16051
+ if (format === 'fontsize') {
16052
+ liElement.style.fontSize = value;
16053
+ }
16054
+ else {
16055
+ liElement.style.color = value;
16056
+ liElement.style.textDecoration = 'inherit';
16057
+ }
16058
+ }
16023
16059
  }
16024
- if (!isNullOrUndefined(liElement) && liElement.tagName.toLowerCase() === 'li' &&
16025
- liElement.textContent.trim() === nodes[index].textContent.trim()) {
16026
- if (format === 'fontsize') {
16027
- liElement.style.fontSize = value;
16060
+ if (rootElementNode && rootElementNode.nodeType !== 3) {
16061
+ var save = new NodeSelection();
16062
+ save.save(range, docElement);
16063
+ domNode.setMarker(save);
16064
+ var cloneNode = rootElementNode.cloneNode(true);
16065
+ element.appendChild(cloneNode);
16066
+ domNode.replaceWith(rootElementNode, element.outerHTML);
16067
+ var currentStartNode = endNode.querySelector('.e-editor-select-start');
16068
+ var currrentEndNode = endNode.querySelector('.e-editor-select-end');
16069
+ if (index === 0) {
16070
+ nodes[index] = currentStartNode ? currentStartNode.lastChild : nodes[index];
16028
16071
  }
16029
- else {
16030
- liElement.style.color = value;
16031
- liElement.style.textDecoration = 'inherit';
16072
+ if (range.startContainer.parentElement === endNode) {
16073
+ if (nodes.length > 1) {
16074
+ nodes[nodes.length - 1] = currrentEndNode ? currrentEndNode.lastChild : nodes[index];
16075
+ }
16032
16076
  }
16077
+ domNode.saveMarker(save, null);
16078
+ }
16079
+ else {
16080
+ nodes[index] = this.applyStyles(nodes, index, element);
16033
16081
  }
16034
- nodes[index] = this.applyStyles(nodes, index, element);
16035
16082
  if (format === 'fontsize') {
16036
16083
  var bg = closest(nodes[index].parentElement, 'span[style*=' + 'background-color' + ']');
16037
16084
  if (!isNullOrUndefined(bg)) {
@@ -22058,7 +22105,6 @@ var Image = /** @__PURE__ @class */ (function () {
22058
22105
  if (!isNullOrUndefined(this.parent.formatter.editorManager.nodeSelection) &&
22059
22106
  originalEvent.code !== 'KeyK') {
22060
22107
  range = this.parent.formatter.editorManager.nodeSelection.getRange(this.parent.contentModule.getDocument());
22061
- save = this.parent.formatter.editorManager.nodeSelection.save(range, this.parent.contentModule.getDocument());
22062
22108
  selectNodeEle = this.parent.formatter.editorManager.nodeSelection.getNodeCollection(range);
22063
22109
  selectParentEle = this.parent.formatter.editorManager.nodeSelection.getParentNodeCollection(range);
22064
22110
  if (!originalEvent.ctrlKey && originalEvent.key && (originalEvent.key.length === 1 || originalEvent.action === 'enter') &&
@@ -22077,6 +22123,8 @@ var Image = /** @__PURE__ @class */ (function () {
22077
22123
  }
22078
22124
  if (originalEvent.keyCode === 8 || originalEvent.keyCode === 46) {
22079
22125
  if (selectNodeEle && selectNodeEle[0].nodeName === 'IMG' && selectNodeEle.length < 1) {
22126
+ if (!isNullOrUndefined(this.parent.formatter.editorManager.nodeSelection))
22127
+ save = this.parent.formatter.editorManager.nodeSelection.save(range, this.parent.contentModule.getDocument());
22080
22128
  originalEvent.preventDefault();
22081
22129
  var event_1 = {
22082
22130
  selectNode: selectNodeEle, selection: save, selectParent: selectParentEle,
@@ -22135,6 +22183,8 @@ var Image = /** @__PURE__ @class */ (function () {
22135
22183
  }
22136
22184
  break;
22137
22185
  case 'insert-image':
22186
+ if (!isNullOrUndefined(this.parent.formatter.editorManager.nodeSelection))
22187
+ save = this.parent.formatter.editorManager.nodeSelection.save(range, this.parent.contentModule.getDocument());
22138
22188
  this.openDialog(true, originalEvent, save, selectNodeEle, selectParentEle);
22139
22189
  originalEvent.preventDefault();
22140
22190
  break;
@@ -23922,7 +23972,6 @@ var Audio = /** @__PURE__ @class */ (function () {
23922
23972
  if (!isNullOrUndefined(this.parent.formatter.editorManager.nodeSelection) &&
23923
23973
  originalEvent.code !== 'KeyK') {
23924
23974
  range = this.parent.formatter.editorManager.nodeSelection.getRange(this.parent.contentModule.getDocument());
23925
- save = this.parent.formatter.editorManager.nodeSelection.save(range, this.parent.contentModule.getDocument());
23926
23975
  selectNodeEle = this.parent.formatter.editorManager.nodeSelection.getNodeCollection(range);
23927
23976
  selectParentEle = this.parent.formatter.editorManager.nodeSelection.getParentNodeCollection(range);
23928
23977
  if (!originalEvent.ctrlKey && originalEvent.key && (originalEvent.key.length === 1 || originalEvent.action === 'enter') &&
@@ -23938,6 +23987,8 @@ var Audio = /** @__PURE__ @class */ (function () {
23938
23987
  }
23939
23988
  if (originalEvent.keyCode === 8 || originalEvent.keyCode === 46) {
23940
23989
  if (selectNodeEle && this.isAudioElem(selectNodeEle[0]) && selectNodeEle.length < 1) {
23990
+ if (!isNullOrUndefined(this.parent.formatter.editorManager.nodeSelection))
23991
+ save = this.parent.formatter.editorManager.nodeSelection.save(range, this.parent.contentModule.getDocument());
23941
23992
  originalEvent.preventDefault();
23942
23993
  var event_1 = {
23943
23994
  selectNode: selectNodeEle, selection: save, selectParent: selectParentEle,
@@ -23986,6 +24037,8 @@ var Audio = /** @__PURE__ @class */ (function () {
23986
24037
  }
23987
24038
  break;
23988
24039
  case 'insert-audio':
24040
+ if (!isNullOrUndefined(this.parent.formatter.editorManager.nodeSelection))
24041
+ save = this.parent.formatter.editorManager.nodeSelection.save(range, this.parent.contentModule.getDocument());
23989
24042
  this.openDialog(true, originalEvent, save, selectNodeEle, selectParentEle);
23990
24043
  originalEvent.preventDefault();
23991
24044
  break;
@@ -25228,7 +25281,6 @@ var Video = /** @__PURE__ @class */ (function () {
25228
25281
  if (!isNullOrUndefined(this.parent.formatter.editorManager.nodeSelection) &&
25229
25282
  originalEvent.code !== 'KeyK') {
25230
25283
  range = this.parent.formatter.editorManager.nodeSelection.getRange(this.parent.contentModule.getDocument());
25231
- save = this.parent.formatter.editorManager.nodeSelection.save(range, this.parent.contentModule.getDocument());
25232
25284
  selectNodeEle = this.parent.formatter.editorManager.nodeSelection.getNodeCollection(range);
25233
25285
  selectParentEle = this.parent.formatter.editorManager.nodeSelection.getParentNodeCollection(range);
25234
25286
  if (!originalEvent.ctrlKey && originalEvent.key && (originalEvent.key.length === 1 || originalEvent.action === 'enter') &&
@@ -25248,6 +25300,8 @@ var Video = /** @__PURE__ @class */ (function () {
25248
25300
  }
25249
25301
  if (originalEvent.keyCode === 8 || originalEvent.keyCode === 46) {
25250
25302
  if (selectNodeEle && (selectNodeEle[0].nodeName === 'VIDEO' || this.isEmbedVidElem(selectNodeEle[0])) && selectNodeEle.length < 1) {
25303
+ if (!isNullOrUndefined(this.parent.formatter.editorManager.nodeSelection))
25304
+ save = this.parent.formatter.editorManager.nodeSelection.save(range, this.parent.contentModule.getDocument());
25251
25305
  originalEvent.preventDefault();
25252
25306
  var event_1 = {
25253
25307
  selectNode: selectNodeEle, selection: save, selectParent: selectParentEle,
@@ -25300,6 +25354,8 @@ var Video = /** @__PURE__ @class */ (function () {
25300
25354
  }
25301
25355
  break;
25302
25356
  case 'insert-video':
25357
+ if (!isNullOrUndefined(this.parent.formatter.editorManager.nodeSelection))
25358
+ save = this.parent.formatter.editorManager.nodeSelection.save(range, this.parent.contentModule.getDocument());
25303
25359
  this.openDialog(true, originalEvent, save, selectNodeEle, selectParentEle);
25304
25360
  originalEvent.preventDefault();
25305
25361
  break;
@@ -26489,14 +26545,15 @@ var Table = /** @__PURE__ @class */ (function () {
26489
26545
  }
26490
26546
  if (!isNullOrUndefined(this.parent.formatter.editorManager.nodeSelection) && this.contentModule
26491
26547
  && event.code !== 'KeyK') {
26548
+ var selection = void 0;
26492
26549
  var range = this.parent.formatter.editorManager.nodeSelection.getRange(this.parent.contentModule.getDocument());
26493
- var selection = this.parent.formatter.editorManager.
26494
- nodeSelection.save(range, this.contentModule.getDocument());
26495
26550
  var ele = this.parent.formatter.editorManager.nodeSelection.getParentNodeCollection(range)[0];
26496
26551
  ele = (ele && ele.tagName !== 'TD' && ele.tagName !== 'TH') ? ele.parentElement : ele;
26497
26552
  if ((event.keyCode === 8 || event.keyCode === 46) ||
26498
26553
  (event.ctrlKey && event.keyCode === 88)) {
26499
26554
  if (ele && ele.tagName === 'TBODY') {
26555
+ if (!isNullOrUndefined(this.parent.formatter.editorManager.nodeSelection) && this.contentModule)
26556
+ selection = this.parent.formatter.editorManager.nodeSelection.save(range, this.contentModule.getDocument());
26500
26557
  event.preventDefault();
26501
26558
  proxy.removeTable(selection, event, true);
26502
26559
  }
@@ -26510,6 +26567,8 @@ var Table = /** @__PURE__ @class */ (function () {
26510
26567
  ele = !isNullOrUndefined(closestTd) && this.parent.inputElement.contains(closestTd) ? closestTd : ele;
26511
26568
  }
26512
26569
  if (ele && (ele.tagName === 'TD' || ele.tagName === 'TH')) {
26570
+ if (!isNullOrUndefined(this.parent.formatter.editorManager.nodeSelection) && this.contentModule)
26571
+ selection = this.parent.formatter.editorManager.nodeSelection.save(range, this.contentModule.getDocument());
26513
26572
  switch (event.keyCode) {
26514
26573
  case 9:
26515
26574
  case 37:
@@ -29979,6 +30038,10 @@ var RichTextEditor = /** @__PURE__ @class */ (function (_super) {
29979
30038
  if (this.isDestroyed || !this.isRendered) {
29980
30039
  return;
29981
30040
  }
30041
+ if (!isNullOrUndefined(this.timeInterval)) {
30042
+ clearInterval(this.timeInterval);
30043
+ this.timeInterval = null;
30044
+ }
29982
30045
  if (this.element.offsetParent === null) {
29983
30046
  if (!isNullOrUndefined(this.toolbarModule)) {
29984
30047
  this.toolbarModule.destroy();
@@ -29988,10 +30051,6 @@ var RichTextEditor = /** @__PURE__ @class */ (function (_super) {
29988
30051
  }
29989
30052
  this.notify(destroy, {});
29990
30053
  this.destroyDependentModules();
29991
- if (!isNullOrUndefined(this.timeInterval)) {
29992
- clearInterval(this.timeInterval);
29993
- this.timeInterval = null;
29994
- }
29995
30054
  this.unWireEvents();
29996
30055
  if (this.originalElement.tagName === 'TEXTAREA') {
29997
30056
  this.element.parentElement.insertBefore(this.valueContainer, this.element);