myrta-ui 1.1.78 → 1.1.81
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.
- package/esm2020/lib/components/form/editor/editor.component.mjs +69 -1
- package/fesm2015/myrta-ui.mjs +71 -1
- package/fesm2015/myrta-ui.mjs.map +1 -1
- package/fesm2020/myrta-ui.mjs +68 -0
- package/fesm2020/myrta-ui.mjs.map +1 -1
- package/lib/components/form/editor/editor.component.d.ts +4 -0
- package/package.json +3 -1
|
@@ -54,8 +54,12 @@ export class EditorComponent {
|
|
|
54
54
|
beautifyHTML: true,
|
|
55
55
|
addNewLine: true,
|
|
56
56
|
createAttributes: {},
|
|
57
|
+
disablePlugins: ['paste'],
|
|
57
58
|
events: {
|
|
58
59
|
getIcon: changeIconsFunction,
|
|
60
|
+
paste: (event) => {
|
|
61
|
+
this.handlePaste(event);
|
|
62
|
+
},
|
|
59
63
|
},
|
|
60
64
|
// uploader: {
|
|
61
65
|
// insertImageAsBase64URI: true
|
|
@@ -217,6 +221,70 @@ export class EditorComponent {
|
|
|
217
221
|
this.updateValue(this.editorElementRef.editor.value);
|
|
218
222
|
}
|
|
219
223
|
}
|
|
224
|
+
handlePaste(event) {
|
|
225
|
+
if (!event.clipboardData) {
|
|
226
|
+
return;
|
|
227
|
+
}
|
|
228
|
+
const { clipboardData } = event;
|
|
229
|
+
const htmlData = clipboardData.getData('text/html');
|
|
230
|
+
const hasHtmlImage = htmlData?.includes('<img');
|
|
231
|
+
const hasImage = Array.from(clipboardData.items).some(item => item.type.startsWith('image/'));
|
|
232
|
+
if (!hasImage && !hasHtmlImage) {
|
|
233
|
+
return;
|
|
234
|
+
}
|
|
235
|
+
event.preventDefault();
|
|
236
|
+
event.stopPropagation();
|
|
237
|
+
const { editor } = this.editorElementRef;
|
|
238
|
+
const plainText = clipboardData.getData('text/plain');
|
|
239
|
+
if (htmlData) {
|
|
240
|
+
const tempDiv = document.createElement('div');
|
|
241
|
+
tempDiv.innerHTML = htmlData;
|
|
242
|
+
this.removeImageNodes(tempDiv);
|
|
243
|
+
if (this.hasContent(tempDiv)) {
|
|
244
|
+
this.insertNodes(editor, tempDiv);
|
|
245
|
+
return;
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
if (plainText) {
|
|
249
|
+
editor.s.insertHTML(plainText);
|
|
250
|
+
}
|
|
251
|
+
}
|
|
252
|
+
removeImageNodes(container) {
|
|
253
|
+
container.querySelectorAll('img').forEach(img => img.remove());
|
|
254
|
+
const comments = [];
|
|
255
|
+
const walker = document.createTreeWalker(container, NodeFilter.SHOW_COMMENT, null);
|
|
256
|
+
let node;
|
|
257
|
+
while (node = walker.nextNode()) {
|
|
258
|
+
comments.push(node);
|
|
259
|
+
}
|
|
260
|
+
comments.forEach(comment => comment.parentNode?.removeChild(comment));
|
|
261
|
+
const emptyElements = container.querySelectorAll('p, div, span, br');
|
|
262
|
+
emptyElements.forEach(el => {
|
|
263
|
+
if (el.tagName === 'BR' && !el.nextSibling && !el.previousSibling) {
|
|
264
|
+
el.remove();
|
|
265
|
+
}
|
|
266
|
+
else if (!el.textContent?.trim() && el.children.length === 0) {
|
|
267
|
+
el.remove();
|
|
268
|
+
}
|
|
269
|
+
});
|
|
270
|
+
container.querySelectorAll('p, div').forEach(el => {
|
|
271
|
+
if (el.children.length === 1 && el.innerHTML.trim() === '<br>') {
|
|
272
|
+
el.remove();
|
|
273
|
+
}
|
|
274
|
+
});
|
|
275
|
+
}
|
|
276
|
+
hasContent(container) {
|
|
277
|
+
return !!container.textContent?.trim() || container.children.length > 0;
|
|
278
|
+
}
|
|
279
|
+
insertNodes(editor, container) {
|
|
280
|
+
const nodes = Array.from(container.childNodes).map(node => node.cloneNode(true));
|
|
281
|
+
nodes.forEach(node => {
|
|
282
|
+
if (node.nodeType === Node.ELEMENT_NODE ||
|
|
283
|
+
(node.nodeType === Node.TEXT_NODE && node.textContent?.trim())) {
|
|
284
|
+
editor.s.insertNode(node);
|
|
285
|
+
}
|
|
286
|
+
});
|
|
287
|
+
}
|
|
220
288
|
}
|
|
221
289
|
EditorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: EditorComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
222
290
|
EditorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: EditorComponent, selector: "mrx-editor", inputs: { fields: "fields", toolbar: "toolbar", maxLength: "maxLength", minHeight: "minHeight", customClasses: "customClasses", placeholder: "placeholder", disabled: "disabled", readonly: "readonly", iframe: "iframe", config: "config", defaultInlineStyle: "defaultInlineStyle", defaultActionOnPaste: "defaultActionOnPaste", askBeforePasteHTML: "askBeforePasteHTML", editHTMLDocumentMode: "editHTMLDocumentMode", askBeforePasteFromWord: "askBeforePasteFromWord", defaultMode: "defaultMode", invalid: "invalid", invalidMessage: "invalidMessage", checkInvalid: "checkInvalid" }, outputs: { changed: "changed", modelChange: "modelChange", blurred: "blurred" }, providers: [
|
|
@@ -283,4 +351,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
283
351
|
}], blurred: [{
|
|
284
352
|
type: Output
|
|
285
353
|
}] } });
|
|
286
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor.component.js","sourceRoot":"","sources":["../../../../../../../projects/myrta-ui/src/lib/components/form/editor/editor.component.ts","../../../../../../../projects/myrta-ui/src/lib/components/form/editor/editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  forwardRef,\n  Input,\n  OnChanges,\n  Output,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport { changeIconsFunction } from './modules/change-icon-module';\nimport { defaultToolbar } from './config';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { popupToolbars } from './config/popups-toolbar';\nimport { ToolbarConfig } from './models/toolbar.model';\nimport { v4 as uuidv4 } from 'uuid';\nimport { Field } from '../../../services/mrx-autosave/mrx-autosave.service';\nimport { defaultInlineStyleConstant } from './config/default-inline-style';\nimport { InputEditorModeEnum, InputEditorValueWithId } from './editor.enum';\n\n@Component({\n  selector: 'mrx-editor',\n  templateUrl: './editor.component.html',\n  styleUrls: ['./editor.component.less'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => EditorComponent),\n      multi: true,\n    },\n  ]\n})\nexport class EditorComponent implements ControlValueAccessor, OnChanges {\n  private _isInit = false;\n  public value = '';\n  public valueLength = 0;\n  public isFocused: boolean | null = false;\n\n  public defaultConfig: any = {\n    ...defaultToolbar,\n    popup: popupToolbars,\n    defaultMode: InputEditorModeEnum.MODE_WYSIWYG,\n    language: 'ru',\n    showCharsCounter: false,\n    showWordsCounter: false,\n    limitHTML: true,\n    showXPathInStatusbar: false,\n    link: {\n      noFollowCheckbox: false\n    },\n    minHeight: 110,\n    iframe: false,\n    imageDefaultWidth: 200,\n    editHTMLDocumentMode: false,\n    cleanHTML: {\n      fillEmptyParagraph: true\n    },\n    placeholder: '',\n    toolbarAdaptive: false,\n    toolbarInline: true,\n    toolbarInlineForSelection: false,\n    toolbarInlineDisableFor: [],\n    toolbarInlineDisabledButtons: ['source'],\n    disabled: false,\n    readonly: false,\n    askBeforePasteHTML: false,\n    defaultActionOnPaste: 'insert_only_text',\n    askBeforePasteFromWord: false,\n    hidePoweredByJodit: true,\n    beautifyHTML: true,\n    addNewLine: true,\n    createAttributes: {},\n    events: {\n      getIcon: changeIconsFunction,\n    },\n    // uploader: {\n    //   insertImageAsBase64URI: true\n    // },\n    // limitChars: 10,\n    // limitHTML: 170,\n    // colors: ['#ff0000', '#00ff00', '#0000ff', '#0000ff', '#0000ff', '#0000ff', '/', '#0000ff'],\n  };\n\n  // SAVE STATE\n  public uuid: string = uuidv4();\n  @Input() public fields: Field[] = [];\n\n  @Input() public toolbar!: ToolbarConfig;\n  @Input() public maxLength = 0;\n  @Input() public minHeight = 110;\n  @Input() public customClasses = '';\n  @Input() public placeholder = '';\n  @Input() public disabled = false;\n  @Input() public readonly = false;\n  @Input() public iframe = false;\n\n  @Input() public config: any = this.defaultConfig;\n\n  @Input() public defaultInlineStyle = false;\n  @Input() public defaultActionOnPaste = 'insert_only_text';\n  @Input() public askBeforePasteHTML = false;\n  @Input() public editHTMLDocumentMode = false;\n  @Input() public askBeforePasteFromWord = false;\n  @Input() public defaultMode: InputEditorModeEnum = InputEditorModeEnum.MODE_WYSIWYG;\n\n  // VALIDATE\n  @Input() public invalid = false;\n  @Input() public invalidMessage: string | string[] = '';\n  @Input() public checkInvalid: true | false | null = null;\n\n  @ViewChild('editorElementRef') editorElementRef!: any;\n\n  @Output() public changed: EventEmitter<string> = new EventEmitter<string>();\n  @Output() public modelChange: EventEmitter<InputEditorValueWithId> = new EventEmitter<InputEditorValueWithId>();\n  @Output() public blurred: EventEmitter<InputEditorValueWithId> = new EventEmitter<InputEditorValueWithId>();\n\n  constructor(private changeDetection: ChangeDetectorRef) {\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['toolbar']) {\n      this.defaultConfig = {...this.defaultConfig, ...changes['toolbar'].currentValue};\n    }\n    if (changes['maxLength']) {\n      this.defaultConfig = {...this.defaultConfig, limitChars: changes['maxLength'].currentValue};\n    }\n    if (changes['placeholder']) {\n      this.defaultConfig = {...this.defaultConfig, placeholder: changes['placeholder'].currentValue};\n    }\n    if (changes['disabled']) {\n      this.defaultConfig = {...this.defaultConfig, disabled: changes['disabled'].currentValue};\n    }\n    if (changes['readonly']) {\n      this.defaultConfig = {...this.defaultConfig, readonly: changes['readonly'].currentValue};\n    }\n    if (changes['iframe']) {\n      this.defaultConfig = {...this.defaultConfig, iframe: changes['iframe'].currentValue};\n    }\n    if (changes['defaultInlineStyle']) {\n      this.defaultConfig = {\n        ...this.defaultConfig,\n        createAttributes: {...this.defaultConfig.createAttributes, ...defaultInlineStyleConstant}\n      };\n    }\n    if (changes['editHTMLDocumentMode']) {\n      this.defaultConfig = {\n        ...this.defaultConfig,\n        editHTMLDocumentMode: changes['editHTMLDocumentMode'].currentValue\n      };\n    }\n    if (changes['askBeforePasteHTML']) {\n      this.defaultConfig = {...this.defaultConfig, askBeforePasteHTML: changes['askBeforePasteHTML'].currentValue};\n    }\n    if (changes['askBeforePasteFromWord']) {\n      this.defaultConfig = {\n        ...this.defaultConfig,\n        askBeforePasteFromWord: changes['askBeforePasteFromWord'].currentValue\n      };\n    }\n    if (changes['defaultMode']) {\n      this.defaultConfig = {...this.defaultConfig, defaultMode: changes['defaultMode'].currentValue};\n    }\n    if (changes['defaultActionOnPaste']) {\n      this.defaultConfig = {\n        ...this.defaultConfig,\n        defaultActionOnPaste: changes['defaultActionOnPaste'].currentValue\n      };\n    }\n    if (changes['minHeight']) {\n      this.defaultConfig = {...this.defaultConfig, minHeight: changes['minHeight'].currentValue};\n    }\n    if (changes['config']) {\n      this.defaultConfig = {...this.defaultConfig, ...changes['config'].currentValue};\n    }\n  }\n\n  private get _isInvalidValueLength(): boolean {\n    return this.maxLength < this.valueLength && this.maxLength > 0;\n  }\n\n  public get getInvalid(): boolean {\n    return this._isInvalidValueLength || this.invalid;\n  }\n\n  public get getInvalidMessage(): string | string[] {\n    return this._isInvalidValueLength ? 'Превышено допустимое значение символов' : this.invalidMessage;\n  }\n\n  public get checkValidClasses(): string {\n    return this.checkInvalid === false ? 'mrx-input-checked-success' : this.checkInvalid === true ? 'mrx-input-checked-error' : '';\n  }\n\n  public get getClasses(): string {\n    return `${this.customClasses} ${this.checkValidClasses}`;\n  }\n\n  private get _cleanedValue(): string {\n    return this.editorElementRef.editor.value.replace(/ &nbsp;/g, '&nbsp;').replace(/&nbsp; /g, '&nbsp;');\n  }\n\n  public insertPositionText(text: string) {\n    this.editorElementRef.editor.s.insertHTML(text);\n  }\n\n  public changeFocused(value: boolean): void {\n    this.isFocused = value;\n    this.changeDetection.detectChanges();\n  }\n\n  private onChange = (value: any) => {\n  };\n  private onTouched = () => {\n  };\n\n  public registerOnChange(fn: any) {\n    this.onChange = fn;\n  }\n\n  public registerOnTouched(fn: () => {}): void {\n    this.onTouched = fn;\n  }\n\n  public writeValue(outsideValue: any) {\n    this.value = this._sanitizeValue(outsideValue);\n    if (outsideValue !== null) {\n      setTimeout(() => {\n        this._isInit = true;\n      });\n    }\n  }\n\n  private _sanitizeValue(value: string): string {\n    return value ? value.replace(/<script\\b[^<]*(?:(?!<\\/script>)<[^<]*)*<\\/script>/gi, '') : value;\n  }\n\n  private _calculateChartsCount() {\n    this.valueLength = this._cleanedValue.length;\n  }\n\n  public updateValue(insideValue: string) {\n    if (this.maxLength) {\n      this._calculateChartsCount();\n    }\n\n    if (this.maxLength && this._cleanedValue.length > this.maxLength) {\n      return;\n    }\n\n    if (this._isInit) {\n      this.value = insideValue;\n      this.changed.emit(insideValue);\n      this.modelChange.emit({value: insideValue, id: this.uuid});\n      this.onChange(insideValue);\n      this.onTouched();\n    }\n  }\n\n  public onBlur(value: boolean) {\n    this.changeFocused(value);\n    this.blurred.emit({value: this.value, id: this.uuid});\n\n    if (this.maxLength && this._cleanedValue.length > this.maxLength) {\n      this.editorElementRef.editor.value = this.value;\n      this.updateValue(this.editorElementRef.editor.value);\n    }\n  }\n}\n","<div\n  class=\"mrx-editor\"\n  [class.mrx-input-focused]=\"isFocused\"\n  [class.mrx-input-error]=\"getInvalid\"\n  [class]=\"getClasses\"\n>\n  <jodit-editor\n    #editorElementRef\n    [config]=\"defaultConfig\"\n    [ngModel]=\"value\"\n    (ngModelChange)=\"updateValue($event)\"\n    (onFocus)=\"changeFocused(true)\"\n    (onBlur)=\"onBlur(false)\"\n  ></jodit-editor>\n\n  <mrx-error-message\n    *ngIf=\"getInvalid && getInvalidMessage\"\n    [invalidMessage]=\"getInvalidMessage\"\n  ></mrx-error-message>\n\n  <mrx-save-state type=\"editor\" [id]=\"uuid\" [fields]=\"fields\"></mrx-save-state>\n\n  <mrx-chars-left\n    *ngIf=\"!disabled && maxLength\"\n    [valueLength]=\"valueLength\"\n    [maxlength]=\"maxLength\"\n  ></mrx-chars-left>\n</div>\n"]}
|
|
354
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"editor.component.js","sourceRoot":"","sources":["../../../../../../../projects/myrta-ui/src/lib/components/form/editor/editor.component.ts","../../../../../../../projects/myrta-ui/src/lib/components/form/editor/editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  forwardRef,\n  Input,\n  OnChanges,\n  Output,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport { changeIconsFunction } from './modules/change-icon-module';\nimport { defaultToolbar } from './config';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { popupToolbars } from './config/popups-toolbar';\nimport { ToolbarConfig } from './models/toolbar.model';\nimport { v4 as uuidv4 } from 'uuid';\nimport { Field } from '../../../services/mrx-autosave/mrx-autosave.service';\nimport { defaultInlineStyleConstant } from './config/default-inline-style';\nimport { InputEditorModeEnum, InputEditorValueWithId } from './editor.enum';\n\n@Component({\n  selector: 'mrx-editor',\n  templateUrl: './editor.component.html',\n  styleUrls: ['./editor.component.less'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => EditorComponent),\n      multi: true,\n    },\n  ]\n})\nexport class EditorComponent implements ControlValueAccessor, OnChanges {\n  private _isInit = false;\n  public value = '';\n  public valueLength = 0;\n  public isFocused: boolean | null = false;\n\n  public defaultConfig: any = {\n    ...defaultToolbar,\n    popup: popupToolbars,\n    defaultMode: InputEditorModeEnum.MODE_WYSIWYG,\n    language: 'ru',\n    showCharsCounter: false,\n    showWordsCounter: false,\n    limitHTML: true,\n    showXPathInStatusbar: false,\n    link: {\n      noFollowCheckbox: false\n    },\n    minHeight: 110,\n    iframe: false,\n    imageDefaultWidth: 200,\n    editHTMLDocumentMode: false,\n    cleanHTML: {\n      fillEmptyParagraph: true\n    },\n    placeholder: '',\n    toolbarAdaptive: false,\n    toolbarInline: true,\n    toolbarInlineForSelection: false,\n    toolbarInlineDisableFor: [],\n    toolbarInlineDisabledButtons: ['source'],\n    disabled: false,\n    readonly: false,\n    askBeforePasteHTML: false,\n    defaultActionOnPaste: 'insert_only_text',\n    askBeforePasteFromWord: false,\n    hidePoweredByJodit: true,\n    beautifyHTML: true,\n    addNewLine: true,\n    createAttributes: {},\n    disablePlugins: [ 'paste'],\n    events: {\n      getIcon: changeIconsFunction,\n      paste: (event: ClipboardEvent) => {\n        this.handlePaste(event);\n      },\n    },\n    // uploader: {\n    //   insertImageAsBase64URI: true\n    // },\n    // limitChars: 10,\n    // limitHTML: 170,\n    // colors: ['#ff0000', '#00ff00', '#0000ff', '#0000ff', '#0000ff', '#0000ff', '/', '#0000ff'],\n  };\n\n  // SAVE STATE\n  public uuid: string = uuidv4();\n  @Input() public fields: Field[] = [];\n\n  @Input() public toolbar!: ToolbarConfig;\n  @Input() public maxLength = 0;\n  @Input() public minHeight = 110;\n  @Input() public customClasses = '';\n  @Input() public placeholder = '';\n  @Input() public disabled = false;\n  @Input() public readonly = false;\n  @Input() public iframe = false;\n\n  @Input() public config: any = this.defaultConfig;\n\n  @Input() public defaultInlineStyle = false;\n  @Input() public defaultActionOnPaste = 'insert_only_text';\n  @Input() public askBeforePasteHTML = false;\n  @Input() public editHTMLDocumentMode = false;\n  @Input() public askBeforePasteFromWord = false;\n  @Input() public defaultMode: InputEditorModeEnum = InputEditorModeEnum.MODE_WYSIWYG;\n\n  // VALIDATE\n  @Input() public invalid = false;\n  @Input() public invalidMessage: string | string[] = '';\n  @Input() public checkInvalid: true | false | null = null;\n\n  @ViewChild('editorElementRef') editorElementRef!: any;\n\n  @Output() public changed: EventEmitter<string> = new EventEmitter<string>();\n  @Output() public modelChange: EventEmitter<InputEditorValueWithId> = new EventEmitter<InputEditorValueWithId>();\n  @Output() public blurred: EventEmitter<InputEditorValueWithId> = new EventEmitter<InputEditorValueWithId>();\n\n  constructor(private changeDetection: ChangeDetectorRef) {\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['toolbar']) {\n      this.defaultConfig = {...this.defaultConfig, ...changes['toolbar'].currentValue};\n    }\n    if (changes['maxLength']) {\n      this.defaultConfig = {...this.defaultConfig, limitChars: changes['maxLength'].currentValue};\n    }\n    if (changes['placeholder']) {\n      this.defaultConfig = {...this.defaultConfig, placeholder: changes['placeholder'].currentValue};\n    }\n    if (changes['disabled']) {\n      this.defaultConfig = {...this.defaultConfig, disabled: changes['disabled'].currentValue};\n    }\n    if (changes['readonly']) {\n      this.defaultConfig = {...this.defaultConfig, readonly: changes['readonly'].currentValue};\n    }\n    if (changes['iframe']) {\n      this.defaultConfig = {...this.defaultConfig, iframe: changes['iframe'].currentValue};\n    }\n    if (changes['defaultInlineStyle']) {\n      this.defaultConfig = {\n        ...this.defaultConfig,\n        createAttributes: {...this.defaultConfig.createAttributes, ...defaultInlineStyleConstant}\n      };\n    }\n    if (changes['editHTMLDocumentMode']) {\n      this.defaultConfig = {\n        ...this.defaultConfig,\n        editHTMLDocumentMode: changes['editHTMLDocumentMode'].currentValue\n      };\n    }\n    if (changes['askBeforePasteHTML']) {\n      this.defaultConfig = {...this.defaultConfig, askBeforePasteHTML: changes['askBeforePasteHTML'].currentValue};\n    }\n    if (changes['askBeforePasteFromWord']) {\n      this.defaultConfig = {\n        ...this.defaultConfig,\n        askBeforePasteFromWord: changes['askBeforePasteFromWord'].currentValue\n      };\n    }\n    if (changes['defaultMode']) {\n      this.defaultConfig = {...this.defaultConfig, defaultMode: changes['defaultMode'].currentValue};\n    }\n    if (changes['defaultActionOnPaste']) {\n      this.defaultConfig = {\n        ...this.defaultConfig,\n        defaultActionOnPaste: changes['defaultActionOnPaste'].currentValue\n      };\n    }\n    if (changes['minHeight']) {\n      this.defaultConfig = {...this.defaultConfig, minHeight: changes['minHeight'].currentValue};\n    }\n    if (changes['config']) {\n      this.defaultConfig = {...this.defaultConfig, ...changes['config'].currentValue};\n    }\n  }\n\n  private get _isInvalidValueLength(): boolean {\n    return this.maxLength < this.valueLength && this.maxLength > 0;\n  }\n\n  public get getInvalid(): boolean {\n    return this._isInvalidValueLength || this.invalid;\n  }\n\n  public get getInvalidMessage(): string | string[] {\n    return this._isInvalidValueLength ? 'Превышено допустимое значение символов' : this.invalidMessage;\n  }\n\n  public get checkValidClasses(): string {\n    return this.checkInvalid === false ? 'mrx-input-checked-success' : this.checkInvalid === true ? 'mrx-input-checked-error' : '';\n  }\n\n  public get getClasses(): string {\n    return `${this.customClasses} ${this.checkValidClasses}`;\n  }\n\n  private get _cleanedValue(): string {\n    return this.editorElementRef.editor.value.replace(/ &nbsp;/g, '&nbsp;').replace(/&nbsp; /g, '&nbsp;');\n  }\n\n  public insertPositionText(text: string) {\n    this.editorElementRef.editor.s.insertHTML(text);\n  }\n\n  public changeFocused(value: boolean): void {\n    this.isFocused = value;\n    this.changeDetection.detectChanges();\n  }\n\n  private onChange = (value: any) => {\n  };\n  private onTouched = () => {\n  };\n\n  public registerOnChange(fn: any) {\n    this.onChange = fn;\n  }\n\n  public registerOnTouched(fn: () => {}): void {\n    this.onTouched = fn;\n  }\n\n  public writeValue(outsideValue: any) {\n    this.value = this._sanitizeValue(outsideValue);\n    if (outsideValue !== null) {\n      setTimeout(() => {\n        this._isInit = true;\n      });\n    }\n  }\n\n  private _sanitizeValue(value: string): string {\n    return value ? value.replace(/<script\\b[^<]*(?:(?!<\\/script>)<[^<]*)*<\\/script>/gi, '') : value;\n  }\n\n  private _calculateChartsCount() {\n    this.valueLength = this._cleanedValue.length;\n  }\n\n  public updateValue(insideValue: string) {\n    if (this.maxLength) {\n      this._calculateChartsCount();\n    }\n\n    if (this.maxLength && this._cleanedValue.length > this.maxLength) {\n      return;\n    }\n\n    if (this._isInit) {\n      this.value = insideValue;\n      this.changed.emit(insideValue);\n      this.modelChange.emit({value: insideValue, id: this.uuid});\n      this.onChange(insideValue);\n      this.onTouched();\n    }\n  }\n\n  public onBlur(value: boolean) {\n    this.changeFocused(value);\n    this.blurred.emit({value: this.value, id: this.uuid});\n\n    if (this.maxLength && this._cleanedValue.length > this.maxLength) {\n      this.editorElementRef.editor.value = this.value;\n      this.updateValue(this.editorElementRef.editor.value);\n    }\n  }\n  public handlePaste(event: ClipboardEvent): void {\n    if (!event.clipboardData) {\n      return;\n    }\n\n    const {clipboardData} = event;\n    const htmlData = clipboardData.getData('text/html');\n    const hasHtmlImage = htmlData?.includes('<img');\n    const hasImage = Array.from(clipboardData.items).some(item => item.type.startsWith('image/'));\n\n    if (!hasImage && !hasHtmlImage) {\n      return;\n    }\n\n    event.preventDefault();\n    event.stopPropagation();\n\n    const { editor } = this.editorElementRef;\n    const plainText = clipboardData.getData('text/plain');\n\n    if (htmlData) {\n      const tempDiv = document.createElement('div');\n      tempDiv.innerHTML = htmlData;\n      this.removeImageNodes(tempDiv);\n\n      if (this.hasContent(tempDiv)) {\n        this.insertNodes(editor, tempDiv);\n        return;\n      }\n    }\n\n    if (plainText) {\n      editor.s.insertHTML(plainText);\n    }\n  }\n\n  private removeImageNodes(container: HTMLElement): void {\n    container.querySelectorAll('img').forEach(img => img.remove());\n\n    const comments = [];\n    const walker = document.createTreeWalker(\n        container,\n        NodeFilter.SHOW_COMMENT,\n        null\n    );\n\n    let node;\n    while (node = walker.nextNode()) {\n      comments.push(node);\n    }\n    comments.forEach(comment => comment.parentNode?.removeChild(comment));\n\n    const emptyElements = container.querySelectorAll('p, div, span, br');\n    emptyElements.forEach(el => {\n      if (el.tagName === 'BR' && !el.nextSibling && !el.previousSibling) {\n        el.remove();\n      }\n      else if (!el.textContent?.trim() && el.children.length === 0) {\n        el.remove();\n      }\n    });\n\n    container.querySelectorAll('p, div').forEach(el => {\n      if (el.children.length === 1 && el.innerHTML.trim() === '<br>') {\n        el.remove();\n      }\n    });\n  }\n\n  private hasContent(container: HTMLElement): boolean {\n    return !!container.textContent?.trim() || container.children.length > 0;\n  }\n\n  private insertNodes(editor: any, container: HTMLElement): void {\n    const nodes = Array.from(container.childNodes).map(node => node.cloneNode(true));\n\n    nodes.forEach(node => {\n      if (node.nodeType === Node.ELEMENT_NODE ||\n          (node.nodeType === Node.TEXT_NODE && node.textContent?.trim())) {\n        editor.s.insertNode(node);\n      }\n    });\n  }\n}\n","<div\n  class=\"mrx-editor\"\n  [class.mrx-input-focused]=\"isFocused\"\n  [class.mrx-input-error]=\"getInvalid\"\n  [class]=\"getClasses\"\n>\n  <jodit-editor\n    #editorElementRef\n    [config]=\"defaultConfig\"\n    [ngModel]=\"value\"\n    (ngModelChange)=\"updateValue($event)\"\n    (onFocus)=\"changeFocused(true)\"\n    (onBlur)=\"onBlur(false)\"\n  ></jodit-editor>\n\n  <mrx-error-message\n    *ngIf=\"getInvalid && getInvalidMessage\"\n    [invalidMessage]=\"getInvalidMessage\"\n  ></mrx-error-message>\n\n  <mrx-save-state type=\"editor\" [id]=\"uuid\" [fields]=\"fields\"></mrx-save-state>\n\n  <mrx-chars-left\n    *ngIf=\"!disabled && maxLength\"\n    [valueLength]=\"valueLength\"\n    [maxlength]=\"maxLength\"\n  ></mrx-chars-left>\n</div>\n"]}
|
package/fesm2015/myrta-ui.mjs
CHANGED
|
@@ -10557,8 +10557,11 @@ class EditorComponent {
|
|
|
10557
10557
|
noFollowCheckbox: false
|
|
10558
10558
|
}, minHeight: 110, iframe: false, imageDefaultWidth: 200, editHTMLDocumentMode: false, cleanHTML: {
|
|
10559
10559
|
fillEmptyParagraph: true
|
|
10560
|
-
}, placeholder: '', toolbarAdaptive: false, toolbarInline: true, toolbarInlineForSelection: false, toolbarInlineDisableFor: [], toolbarInlineDisabledButtons: ['source'], disabled: false, readonly: false, askBeforePasteHTML: false, defaultActionOnPaste: 'insert_only_text', askBeforePasteFromWord: false, hidePoweredByJodit: true, beautifyHTML: true, addNewLine: true, createAttributes: {}, events: {
|
|
10560
|
+
}, placeholder: '', toolbarAdaptive: false, toolbarInline: true, toolbarInlineForSelection: false, toolbarInlineDisableFor: [], toolbarInlineDisabledButtons: ['source'], disabled: false, readonly: false, askBeforePasteHTML: false, defaultActionOnPaste: 'insert_only_text', askBeforePasteFromWord: false, hidePoweredByJodit: true, beautifyHTML: true, addNewLine: true, createAttributes: {}, disablePlugins: ['paste'], events: {
|
|
10561
10561
|
getIcon: changeIconsFunction,
|
|
10562
|
+
paste: (event) => {
|
|
10563
|
+
this.handlePaste(event);
|
|
10564
|
+
},
|
|
10562
10565
|
} });
|
|
10563
10566
|
// SAVE STATE
|
|
10564
10567
|
this.uuid = v4();
|
|
@@ -10701,6 +10704,73 @@ class EditorComponent {
|
|
|
10701
10704
|
this.updateValue(this.editorElementRef.editor.value);
|
|
10702
10705
|
}
|
|
10703
10706
|
}
|
|
10707
|
+
handlePaste(event) {
|
|
10708
|
+
if (!event.clipboardData) {
|
|
10709
|
+
return;
|
|
10710
|
+
}
|
|
10711
|
+
const { clipboardData } = event;
|
|
10712
|
+
const htmlData = clipboardData.getData('text/html');
|
|
10713
|
+
const hasHtmlImage = htmlData === null || htmlData === void 0 ? void 0 : htmlData.includes('<img');
|
|
10714
|
+
const hasImage = Array.from(clipboardData.items).some(item => item.type.startsWith('image/'));
|
|
10715
|
+
if (!hasImage && !hasHtmlImage) {
|
|
10716
|
+
return;
|
|
10717
|
+
}
|
|
10718
|
+
event.preventDefault();
|
|
10719
|
+
event.stopPropagation();
|
|
10720
|
+
const { editor } = this.editorElementRef;
|
|
10721
|
+
const plainText = clipboardData.getData('text/plain');
|
|
10722
|
+
if (htmlData) {
|
|
10723
|
+
const tempDiv = document.createElement('div');
|
|
10724
|
+
tempDiv.innerHTML = htmlData;
|
|
10725
|
+
this.removeImageNodes(tempDiv);
|
|
10726
|
+
if (this.hasContent(tempDiv)) {
|
|
10727
|
+
this.insertNodes(editor, tempDiv);
|
|
10728
|
+
return;
|
|
10729
|
+
}
|
|
10730
|
+
}
|
|
10731
|
+
if (plainText) {
|
|
10732
|
+
editor.s.insertHTML(plainText);
|
|
10733
|
+
}
|
|
10734
|
+
}
|
|
10735
|
+
removeImageNodes(container) {
|
|
10736
|
+
container.querySelectorAll('img').forEach(img => img.remove());
|
|
10737
|
+
const comments = [];
|
|
10738
|
+
const walker = document.createTreeWalker(container, NodeFilter.SHOW_COMMENT, null);
|
|
10739
|
+
let node;
|
|
10740
|
+
while (node = walker.nextNode()) {
|
|
10741
|
+
comments.push(node);
|
|
10742
|
+
}
|
|
10743
|
+
comments.forEach(comment => { var _a; return (_a = comment.parentNode) === null || _a === void 0 ? void 0 : _a.removeChild(comment); });
|
|
10744
|
+
const emptyElements = container.querySelectorAll('p, div, span, br');
|
|
10745
|
+
emptyElements.forEach(el => {
|
|
10746
|
+
var _a;
|
|
10747
|
+
if (el.tagName === 'BR' && !el.nextSibling && !el.previousSibling) {
|
|
10748
|
+
el.remove();
|
|
10749
|
+
}
|
|
10750
|
+
else if (!((_a = el.textContent) === null || _a === void 0 ? void 0 : _a.trim()) && el.children.length === 0) {
|
|
10751
|
+
el.remove();
|
|
10752
|
+
}
|
|
10753
|
+
});
|
|
10754
|
+
container.querySelectorAll('p, div').forEach(el => {
|
|
10755
|
+
if (el.children.length === 1 && el.innerHTML.trim() === '<br>') {
|
|
10756
|
+
el.remove();
|
|
10757
|
+
}
|
|
10758
|
+
});
|
|
10759
|
+
}
|
|
10760
|
+
hasContent(container) {
|
|
10761
|
+
var _a;
|
|
10762
|
+
return !!((_a = container.textContent) === null || _a === void 0 ? void 0 : _a.trim()) || container.children.length > 0;
|
|
10763
|
+
}
|
|
10764
|
+
insertNodes(editor, container) {
|
|
10765
|
+
const nodes = Array.from(container.childNodes).map(node => node.cloneNode(true));
|
|
10766
|
+
nodes.forEach(node => {
|
|
10767
|
+
var _a;
|
|
10768
|
+
if (node.nodeType === Node.ELEMENT_NODE ||
|
|
10769
|
+
(node.nodeType === Node.TEXT_NODE && ((_a = node.textContent) === null || _a === void 0 ? void 0 : _a.trim()))) {
|
|
10770
|
+
editor.s.insertNode(node);
|
|
10771
|
+
}
|
|
10772
|
+
});
|
|
10773
|
+
}
|
|
10704
10774
|
}
|
|
10705
10775
|
EditorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: EditorComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
10706
10776
|
EditorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: EditorComponent, selector: "mrx-editor", inputs: { fields: "fields", toolbar: "toolbar", maxLength: "maxLength", minHeight: "minHeight", customClasses: "customClasses", placeholder: "placeholder", disabled: "disabled", readonly: "readonly", iframe: "iframe", config: "config", defaultInlineStyle: "defaultInlineStyle", defaultActionOnPaste: "defaultActionOnPaste", askBeforePasteHTML: "askBeforePasteHTML", editHTMLDocumentMode: "editHTMLDocumentMode", askBeforePasteFromWord: "askBeforePasteFromWord", defaultMode: "defaultMode", invalid: "invalid", invalidMessage: "invalidMessage", checkInvalid: "checkInvalid" }, outputs: { changed: "changed", modelChange: "modelChange", blurred: "blurred" }, providers: [
|