keevo-components 2.0.200 → 2.0.202

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.
@@ -1,4 +1,5 @@
1
1
  import { Component, computed, effect, EventEmitter, inject, input, Input, model, Output, signal, ViewChild, } from '@angular/core';
2
+ import Quill from 'quill';
2
3
  import { DialogService } from 'primeng/dynamicdialog';
3
4
  import { BaseComponentInput } from '../../../api/base-components/base-component-input';
4
5
  import { ComponentProviders } from '../../../api/helpers/component-providers';
@@ -45,6 +46,7 @@ export class KvEditorComponent extends BaseComponentInput {
45
46
  this.editorReadyResolver = resolve;
46
47
  });
47
48
  this.htmlDoEditor = '';
49
+ this.quillDelta = Quill.import('delta');
48
50
  // Signal para espelhamento do conteúdo do editor
49
51
  this.htmlEspelho = signal('');
50
52
  this.previewContent = signal('');
@@ -129,12 +131,21 @@ export class KvEditorComponent extends BaseComponentInput {
129
131
  theme: 'snow',
130
132
  modules: {
131
133
  toolbar: '#kv-editor-toolbar',
134
+ clipboard: {
135
+ matchVisual: false,
136
+ matchers: [
137
+ ['*', (node, delta) => {
138
+ return delta;
139
+ }]
140
+ ]
141
+ }
132
142
  },
133
143
  placeholder: this.label ? this.label : '',
134
144
  readOnly: this.readonly(),
135
145
  debug: this.debug,
136
146
  };
137
147
  this.quill = this.quillService.createQuillInstance('#kv-editor', config);
148
+ this.configurarHtmlClipboard();
138
149
  this.setupQuillEvents();
139
150
  this.editorReadyResolver();
140
151
  this.initLoadComplete.set(true);
@@ -267,6 +278,39 @@ export class KvEditorComponent extends BaseComponentInput {
267
278
  this.setRelatorioPorId(0);
268
279
  this.writeValue('');
269
280
  }
281
+ configurarHtmlClipboard() {
282
+ const editor = this.quill.root;
283
+ editor.addEventListener('paste', (e) => {
284
+ if (e.clipboardData) {
285
+ e.preventDefault();
286
+ e.stopPropagation();
287
+ const html = e.clipboardData.getData('text/html');
288
+ const text = e.clipboardData.getData('text/plain');
289
+ const selection = this.quill.getSelection();
290
+ if (!selection)
291
+ return;
292
+ if (html && html.trim()) {
293
+ const startIndex = selection.index;
294
+ //a partir daqui é para evitar que o copiar seja duplicado
295
+ this.updatingEditor = true;
296
+ this.quill.clipboard.dangerouslyPasteHTML(startIndex, html);
297
+ setTimeout(() => {
298
+ this.updatingEditor = false;
299
+ const newLength = this.quill.getLength();
300
+ this.quill.setSelection(newLength, 0);
301
+ if (this.enablePreviewMode()) {
302
+ this.atualizarPreview();
303
+ }
304
+ }, 10);
305
+ }
306
+ else if (text && text.trim()) {
307
+ this.quill.insertText(selection.index, text, 'user');
308
+ this.quill.setSelection(selection.index + text.length, 0);
309
+ }
310
+ }
311
+ }, true);
312
+ }
313
+ //#region Métodos modo preview
270
314
  atualizarPreview() {
271
315
  if (!this.quill)
272
316
  return;
@@ -351,41 +395,30 @@ export class KvEditorComponent extends BaseComponentInput {
351
395
  let conteudoProcessado = content;
352
396
  const variaveis = this.relatorio().variaveis;
353
397
  variaveis.forEach(variavel => {
398
+ if (!this.isHtmlString(variavel.value)) {
399
+ return;
400
+ }
354
401
  const placeholderId = `{${variavel.id}}`;
355
- //para buscar outros padrões de html pra variável
356
- //obs: padronizar o uso de menções com spans data-mention
402
+ if (conteudoProcessado.includes(placeholderId)) {
403
+ conteudoProcessado = conteudoProcessado.split(placeholderId).join(variavel.value);
404
+ }
357
405
  const patterns = [
358
406
  `<span[^>]*class="[^"]*mention[^"]*"[^>]*>\\s*${this.escapeRegex(variavel.descricao)}\\s*</span>`,
359
407
  `<span[^>]*data-mention[^>]*>\\s*${this.escapeRegex(variavel.descricao)}\\s*</span>`,
360
408
  `>\\s*${this.escapeRegex(variavel.descricao)}\\s*<`,
361
409
  `<[^>]+>\\s*${this.escapeRegex(variavel.descricao)}\\s*</[^>]+>`
362
410
  ];
363
- if (conteudoProcessado.includes(placeholderId)) {
364
- if (this.isHtmlString(variavel.value)) {
365
- conteudoProcessado = conteudoProcessado.split(placeholderId).join(variavel.value);
366
- }
367
- }
368
411
  let substituido = false;
369
412
  for (const pattern of patterns) {
370
413
  const regexMention = new RegExp(pattern, 'gi');
371
414
  if (regexMention.test(conteudoProcessado)) {
372
- if (this.isHtmlString(variavel.value)) {
373
- const replacement = pattern.includes('>') && pattern.includes('<')
374
- ? variavel.value
375
- : `>${variavel.value}<`;
376
- conteudoProcessado = conteudoProcessado.replace(regexMention, pattern.startsWith('>') ? `>${variavel.value}<` : variavel.value);
377
- }
378
- else {
379
- conteudoProcessado = conteudoProcessado.replace(regexMention, pattern.startsWith('>') ? `>${variavel.value}<` : variavel.value);
380
- }
415
+ conteudoProcessado = conteudoProcessado.replace(regexMention, pattern.startsWith('>') ? `>${variavel.value}<` : variavel.value);
381
416
  substituido = true;
382
417
  break;
383
418
  }
384
419
  }
385
420
  if (!substituido && conteudoProcessado.includes(variavel.descricao)) {
386
- if (this.isHtmlString(variavel.value)) {
387
- conteudoProcessado = conteudoProcessado.split(variavel.descricao).join(variavel.value);
388
- }
421
+ conteudoProcessado = conteudoProcessado.split(variavel.descricao).join(variavel.value);
389
422
  }
390
423
  });
391
424
  return conteudoProcessado;
@@ -423,4 +456,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
423
456
  type: ViewChild,
424
457
  args: ['mentionAnchor']
425
458
  }] } });
426
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-editor.component.js","sourceRoot":"","sources":["../../../../../../../projects/keevo-components/src/lib/components/kv-inputs/kv-editor/kv-editor.component.ts","../../../../../../../projects/keevo-components/src/lib/components/kv-inputs/kv-editor/kv-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  computed,\r\n  effect,\r\n  ElementRef,\r\n  EventEmitter,\r\n  inject,\r\n  input,\r\n  Input,\r\n  model,\r\n  OnInit,\r\n  output,\r\n  Output,\r\n  Renderer2,\r\n  signal,\r\n  TemplateRef,\r\n  ViewChild,\r\n  SecurityContext,\r\n} from '@angular/core';\r\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\r\n\r\nimport Quill from 'quill';\r\nimport { OverlayPanel } from 'primeng/overlaypanel';\r\nimport { DialogService } from 'primeng/dynamicdialog';\r\n\r\nimport { BaseComponentInput } from '../../../api/base-components/base-component-input';\r\nimport { ComponentProviders } from '../../../api/helpers/component-providers';\r\nimport { ComponentService } from '../../../api/services/component.service';\r\nimport { KvInstrucoesReportComponent } from './components/kv-instrucoes-report/kv-instrucoes-report.component';\r\n\r\nimport {\r\n  KvEditorRelatorio,\r\n  KvEditorVariavel,\r\n  KvEditorQuillService,\r\n  KvEditorRelatorioService,\r\n  KvEditorMentionService,\r\n  KvEditorPdfService\r\n} from './kv-editor';\r\n\r\n@Component({\r\n  selector: 'kv-editor',\r\n  templateUrl: './kv-editor.component.html',\r\n  styleUrls: ['./kv-editor.component.scss'],\r\n  providers: ComponentProviders(KvEditorComponent),\r\n})\r\nexport class KvEditorComponent extends BaseComponentInput<string> implements OnInit {\r\n\r\n  constructor(\r\n    componentService: ComponentService,\r\n    private sanitizer: DomSanitizer\r\n  ) {\r\n    super(componentService);\r\n\r\n    effect(() => {\r\n      let readonly = this.readonly();\r\n      if (this.quill) {\r\n        this.quill.enable(!readonly);\r\n      }\r\n    });\r\n\r\n    effect(() => {\r\n      if (this.enablePreviewMode()) {\r\n        this.atualizarPreview();\r\n      }\r\n    });\r\n  }\r\n\r\n  // Injeção de serviços\r\n  private quillService = inject(KvEditorQuillService);\r\n  private relatorioService = inject(KvEditorRelatorioService);\r\n  private mentionService = inject(KvEditorMentionService);\r\n  private pdfService = inject(KvEditorPdfService);\r\n  private dialogService = inject(DialogService);\r\n\r\n  // Propriedades de configuração\r\n  /**\r\n   * @deprecated Essa propriedade não será mais utilizada por esse componente nas próximas versões.\r\n   */\r\n  @Input() canvaHeigth: string = '380px';\r\n\r\n  @Input() contentType: 'html' | 'text' = 'html';\r\n  @Input() debug: boolean = false;\r\n\r\n  // Eventos\r\n  @Output() onTextChange: EventEmitter<any> = new EventEmitter();\r\n  @Output() onSelectionChange: EventEmitter<any> = new EventEmitter();\r\n  @Output() outputRaw: EventEmitter<string> = new EventEmitter();\r\n  @Output() outputHtml: EventEmitter<string> = new EventEmitter();\r\n\r\n  // Propriedades internas\r\n  private updatingEditor: boolean = false;\r\n  private lastSelectionRange: any = null;\r\n  private editorReadyResolver!: () => void;\r\n  private editorReadyPromise = new Promise<void>((resolve) => {\r\n    this.editorReadyResolver = resolve;\r\n  });\r\n\r\n  // Instância do Quill\r\n  quill!: Quill;\r\n  htmlDoEditor = '';\r\n\r\n  // Signal para espelhamento do conteúdo do editor\r\n  htmlEspelho = signal<string>('');\r\n  previewContent = signal<SafeHtml>('');\r\n\r\n  // Signals para controle de estado\r\n  initLoadComplete = signal<boolean>(false);\r\n  isLoading = signal<boolean>(true);\r\n  editorToolbarHeight = signal<string>('3rem');\r\n  // tipoVisualizacao = signal<'valor' | 'descricao'>('descricao');\r\n  filteredVariables = signal<KvEditorVariavel[]>([]);\r\n  clearedTemplate = signal<boolean>(false);\r\n\r\n  //Input para habilitar preview\r\n  enablePreviewMode = input<boolean>(false);\r\n\r\n  // Inputs para relatórios\r\n  relatorios = input<KvEditorRelatorio[]>([]);\r\n  idRelatorioInitial = model<any>(0);\r\n  printButton = input<boolean>(true);\r\n  labelEmptyDropdown = input<string>('Selecione um relatório');\r\n  instrucoesTemplate = input<TemplateRef<any> | undefined>(undefined);\r\n  showHeader = input<boolean>(true);\r\n  readonly = input<boolean>(false);\r\n\r\n\r\n  // Computed properties para relatórios\r\n  idRelatorioSelected = computed(() => this.relatorioService.getIdRelatorioSelected());\r\n  relatorio = computed(() => this.relatorioService.getRelatorioSelected());\r\n  isLoadingPdf = computed(() => this.pdfService.getIsLoadingPdf());\r\n\r\n  // ViewChild para overlay panels\r\n  @ViewChild('opVariables') opVariables!: OverlayPanel;\r\n  @ViewChild('mentionAnchor') mentionAnchor!: ElementRef;\r\n\r\n  messages = [{ severity: 'info', detail: 'Message Content' }];\r\n\r\n  // Métodos para gerenciar relatórios\r\n  setRelatorioPorId(id: any): void {\r\n    const relatorio = this.relatorioService.setRelatorioPorId(id);\r\n    if (relatorio) {\r\n      this.setRelatorio(relatorio);\r\n    }\r\n  }\r\n\r\n  setRelatorio(relatorio: KvEditorRelatorio): void {\r\n    this.clearedTemplate.set(false);\r\n    this.relatorioService.setRelatorio(relatorio);\r\n    const modelo = relatorio.modeloRelatorio || '';\r\n    const variaveis = relatorio.variaveis || [];\r\n\r\n    this.htmlDoEditor = this.relatorioService.renderContrato(modelo, variaveis);\r\n    this.updatingEditor = true;\r\n    this.escrevaValor(this.htmlDoEditor);\r\n  }\r\n\r\n  override ngOnInit(): void {\r\n    super.ngOnInit();\r\n\r\n    // Inicializa os relatórios no serviço\r\n    this.relatorioService.setRelatorios(this.relatorios());\r\n\r\n    if (!this.quill) {\r\n      this.handleInit();\r\n    }\r\n\r\n    setTimeout(() => {\r\n      this.isLoading.set(false);\r\n    }, 1000);\r\n\r\n    if (this.idRelatorioInitial()) {\r\n      this.clearedTemplate.set(false);\r\n      this.setRelatorioPorId(this.idRelatorioInitial());\r\n    } else this.clearedTemplate.set(true);\r\n\r\n    setTimeout(() => {\r\n      if (this.enablePreviewMode()) {\r\n        this.atualizarPreview();\r\n      }\r\n    }, 1500);\r\n  }\r\n\r\n  async handleInit(): Promise<void> {\r\n    await this.quillService.loadCss();\r\n    this.initializeQuillEditor();\r\n  }\r\n\r\n  initializeQuillEditor(): void {\r\n    const config = {\r\n      theme: 'snow',\r\n      modules: {\r\n        toolbar: '#kv-editor-toolbar',\r\n      },\r\n      placeholder: this.label ? this.label : '',\r\n      readOnly: this.readonly(),\r\n      debug: this.debug,\r\n    };\r\n\r\n    this.quill = this.quillService.createQuillInstance('#kv-editor', config);\r\n\r\n    this.setupQuillEvents();\r\n    this.editorReadyResolver();\r\n    this.initLoadComplete.set(true);\r\n\r\n    setTimeout(() => {\r\n      const control = this.formControl;\r\n      if (control && control.markAsPristine) {\r\n        control.markAsPristine();\r\n        control.markAsUntouched();\r\n      }\r\n    }, 0);\r\n  }\r\n\r\n  private setupQuillEvents(): void {\r\n    this.quill.on('selection-change', (range, oldRange, source) => {\r\n      if (range) {\r\n        this.lastSelectionRange = range;\r\n      }\r\n      this.onSelectionChange.emit({\r\n        range: range,\r\n        oldRange: oldRange,\r\n        source: source,\r\n      });\r\n    });\r\n\r\n    this.quill.on('text-change', (delta, oldContents, source) => {\r\n      if (source === 'user' && delta.ops) {\r\n        this.configurarHtmlAutoCompleteTag(delta);\r\n      }\r\n\r\n      if (this.relatorios().length > 0) {\r\n        this.handleMention();\r\n      }\r\n\r\n      if (!this.updatingEditor) {\r\n        this.updatingEditor = false;\r\n        this.escrevaValor(this.quill.getSemanticHTML(), this.quill.getText());\r\n\r\n        this.onTextChange.emit({\r\n          delta: delta,\r\n          oldContents: oldContents,\r\n          source: source,\r\n        });\r\n\r\n        this.outputRaw.emit(this.quill.getText());\r\n        this.outputHtml.emit(this.quill.getSemanticHTML());\r\n\r\n        if (this.enablePreviewMode()) {\r\n          this.atualizarPreview();\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  override writeValue(value: any): void {\r\n    this.updatingEditor = true;\r\n    this.escrevaValor(value);\r\n  }\r\n\r\n  async escrevaValor(htmlvalue: any, rawvalue?: any): Promise<void> {\r\n    if (!this.initLoadComplete()) {\r\n      await this.editorReadyPromise;\r\n    }\r\n\r\n    if (this.quill) {\r\n      if (this.updatingEditor) {\r\n        this.quill.clipboard.dangerouslyPasteHTML(htmlvalue);\r\n      }\r\n      this.updatingEditor = false;\r\n      this.value = htmlvalue;\r\n\r\n      if (rawvalue == \"\\n\" || this.value == \"\\n\") {\r\n        this.value = '';\r\n      }\r\n\r\n      if (this.enablePreviewMode()) {\r\n        setTimeout(() => this.atualizarPreview(), 100);\r\n      }\r\n    } else {\r\n      this.updatingEditor = false;\r\n    }\r\n\r\n    this.outputHtml.emit(this.quill.getSemanticHTML());\r\n  }\r\n\r\n  getEditorSize(): void {\r\n    let editorFieldHeight = document.getElementById('kv-editor-toolbar')?.offsetHeight;\r\n    if (editorFieldHeight) {\r\n      this.editorToolbarHeight.set(`${editorFieldHeight}px`);\r\n    }\r\n  }\r\n\r\n  async openRelatorio(): Promise<void> {\r\n    if (this.isLoadingPdf()) return;\r\n\r\n    const htmlContent = this.quill.getSemanticHTML();\r\n    const relatorio = this.relatorio();\r\n    // const tipoVisualizacao = this.tipoVisualizacao();\r\n\r\n    await this.pdfService.openRelatorio(htmlContent, relatorio, 'valor');\r\n  }\r\n\r\n  // Métodos para sistema de menções\r\n  handleMention(): void {\r\n    if (!this.relatorio()) return;\r\n\r\n    const result = this.mentionService.handleMention(this.quill, this.relatorio()!.variaveis);\r\n    this.filteredVariables.set(result.filteredVariables);\r\n\r\n    if (result.shouldShowPanel && result.mentionBounds) {\r\n      this.showVariablesPanel(result.mentionBounds);\r\n    } else {\r\n      this.closeVariablesPanel();\r\n    }\r\n  }\r\n\r\n  private showVariablesPanel(bounds: { top: number; left: number }): void {\r\n    const anchorEl = this.mentionAnchor.nativeElement;\r\n    anchorEl.style.top = `${bounds.top}px`;\r\n    anchorEl.style.left = `${bounds.left}px`;\r\n    this.opVariables.show(null, anchorEl);\r\n  }\r\n\r\n  selectVariableFromPanel(variable: KvEditorVariavel): void {\r\n    this.mentionService.insertVariable(this.quill, variable);\r\n    this.closeVariablesPanel();\r\n  }\r\n\r\n  closeVariablesPanel(): void {\r\n    if (this.opVariables) {\r\n      this.opVariables.hide();\r\n    }\r\n    this.mentionService.closeMention();\r\n  }\r\n\r\n  showInstrucoes(): void {\r\n    this.dialogService.open(KvInstrucoesReportComponent, {\r\n      header: 'Instruções',\r\n      width: '40%',\r\n      height: '30%',\r\n      modal: true,\r\n      closable: true,\r\n      data: {\r\n        template: this.instrucoesTemplate()\r\n      }\r\n    });\r\n  }\r\n\r\n  clearTemplate() {\r\n    // Limpa o template do editor\r\n    this.clearedTemplate.set(true);\r\n    this.setRelatorioPorId(0);\r\n    this.writeValue('');\r\n  }\r\n\r\n  private atualizarPreview(): void {\r\n    if (!this.quill) return;\r\n\r\n    let conteudoHtml = this.quill.root.innerHTML;\r\n\r\n    conteudoHtml = this.decodificarEntidadesHtml(conteudoHtml);\r\n    \r\n    this.htmlEspelho.set(conteudoHtml);\r\n\r\n    const conteudoProcessado = this.processarConteudoPreview(conteudoHtml);\r\n    this.previewContent.set(conteudoProcessado);\r\n  }\r\n\r\n  private decodificarEntidadesHtml(text: string): string {\r\n    const textarea = document.createElement('textarea');\r\n    textarea.innerHTML = text;\r\n    return textarea.value;\r\n  }\r\n\r\n  private configurarHtmlAutoCompleteTag(delta: any): void {\r\n    if (!delta.ops || delta.ops.length === 0) return;\r\n\r\n    const ultimoOp = delta.ops[delta.ops.length - 1];\r\n    if (ultimoOp.insert && typeof ultimoOp.insert === 'string' && ultimoOp.insert === '>') {\r\n      const textoAtual = this.quill.getText();\r\n      const posicaoCursor = this.quill.getSelection()?.index || 0;\r\n\r\n      const textoAntesCursor = textoAtual.substring(0, posicaoCursor);\r\n\r\n      const regexTagAberta = /<(\\w+)(?:\\s+[^>]*)?(?<!\\/)\\>$/;\r\n      const verificarTag = textoAntesCursor.match(regexTagAberta);\r\n\r\n      if (verificarTag) {\r\n        const tagName = verificarTag[1];\r\n\r\n        const tagsInline = ['img', 'br', 'hr', 'input', 'meta', 'link', 'area', 'base', 'col', 'embed', 'source', 'track', 'wbr'];\r\n\r\n        if (!tagsInline.includes(tagName.toLowerCase())) {\r\n          const textoDepoisCursor = textoAtual.substring(posicaoCursor);\r\n          const fecharTagRegex = new RegExp(`^<\\/${tagName}>`, 'i');\r\n\r\n          if (!fecharTagRegex.test(textoDepoisCursor)) {\r\n            this.updatingEditor = true;\r\n            this.quill.insertText(posicaoCursor, `</${tagName}>`, 'user');\r\n\r\n            setTimeout(() => {\r\n              this.quill.setSelection(posicaoCursor, 0);\r\n              this.updatingEditor = false;\r\n            }, 0);\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  private processarConteudoPreview(content: string): SafeHtml {\r\n    if (!content || content === '\\n') {\r\n      return this.sanitizer.bypassSecurityTrustHtml('<p class=\"text-gray-400 text-sm\">O conteúdo aparecerá aqui...</p>');\r\n    }\r\n\r\n    const styleRegex = /<style[^>]*>([\\s\\S]*?)<\\/style>/gi;\r\n    const styles: string[] = [];\r\n    let conteudoProcessado = content;\r\n\r\n    let match;\r\n    while ((match = styleRegex.exec(content)) !== null) {\r\n      styles.push(match[1]);\r\n    }\r\n\r\n    conteudoProcessado = this.processarVariaveisComHtml(conteudoProcessado);\r\n    conteudoProcessado = this.manterQuebrasLinhaHtml(conteudoProcessado);\r\n\r\n    let conteudoFinal = '<div class=\"kv-editor-preview-wrapper\">';\r\n\r\n    if (styles.length > 0) {\r\n      conteudoFinal += '<style>' + styles.join('\\n') + '</style>';\r\n    }\r\n\r\n    conteudoFinal += conteudoProcessado;\r\n    conteudoFinal += '</div>';\r\n\r\n    return this.sanitizer.bypassSecurityTrustHtml(conteudoFinal);\r\n  }\r\n\r\n  private manterQuebrasLinhaHtml(html: string): string {\r\n    return html;\r\n  }\r\n\r\n  private isHtmlString(str: string): boolean {\r\n    if (!str || typeof str !== 'string') return false;\r\n    \r\n    const trimmed = str.trim();\r\n    \r\n    if (!trimmed.startsWith('<') || !trimmed.endsWith('>')) return false;\r\n    \r\n    const htmlTagRegex = /<\\/?[a-z][\\s\\S]*?>/i;\r\n    const hasOpeningTag = /<[a-z][\\s\\S]*?>/i.test(trimmed);\r\n    const hasClosingTag = /<\\/[a-z][\\s\\S]*?>/i.test(trimmed);\r\n    \r\n    return htmlTagRegex.test(trimmed) && (hasOpeningTag || hasClosingTag);\r\n  }\r\n\r\n  private processarVariaveisComHtml(content: string): string {\r\n    if (!this.relatorio() || !this.relatorio()!.variaveis) {\r\n      return content;\r\n    }\r\n\r\n    let conteudoProcessado = content;\r\n    const variaveis = this.relatorio()!.variaveis;\r\n\r\n    variaveis.forEach(variavel => {\r\n      const placeholderId = `{${variavel.id}}`;\r\n      \r\n      //para buscar outros padrões de html pra variável\r\n      //obs: padronizar o uso de menções com spans data-mention\r\n      const patterns = [\r\n        `<span[^>]*class=\"[^\"]*mention[^\"]*\"[^>]*>\\\\s*${this.escapeRegex(variavel.descricao)}\\\\s*</span>`,\r\n        `<span[^>]*data-mention[^>]*>\\\\s*${this.escapeRegex(variavel.descricao)}\\\\s*</span>`,\r\n        `>\\\\s*${this.escapeRegex(variavel.descricao)}\\\\s*<`,\r\n        `<[^>]+>\\\\s*${this.escapeRegex(variavel.descricao)}\\\\s*</[^>]+>`\r\n      ];\r\n      \r\n      if (conteudoProcessado.includes(placeholderId)) {\r\n        if (this.isHtmlString(variavel.value)) {\r\n          conteudoProcessado = conteudoProcessado.split(placeholderId).join(variavel.value);\r\n        }\r\n      }\r\n      \r\n      let substituido = false;\r\n      for (const pattern of patterns) {\r\n        const regexMention = new RegExp(pattern, 'gi');\r\n        if (regexMention.test(conteudoProcessado)) {\r\n          if (this.isHtmlString(variavel.value)) {\r\n            const replacement = pattern.includes('>') && pattern.includes('<') \r\n              ? variavel.value \r\n              : `>${variavel.value}<`;\r\n            conteudoProcessado = conteudoProcessado.replace(regexMention, \r\n              pattern.startsWith('>') ? `>${variavel.value}<` : variavel.value\r\n            );\r\n          } else {\r\n            conteudoProcessado = conteudoProcessado.replace(regexMention, \r\n              pattern.startsWith('>') ? `>${variavel.value}<` : variavel.value\r\n            );\r\n          }\r\n          substituido = true;\r\n          break;\r\n        }\r\n      }\r\n      \r\n      if (!substituido && conteudoProcessado.includes(variavel.descricao)) {\r\n        if (this.isHtmlString(variavel.value)) {\r\n          conteudoProcessado = conteudoProcessado.split(variavel.descricao).join(variavel.value);\r\n        }\r\n      }\r\n    });\r\n\r\n    return conteudoProcessado;\r\n  }\r\n\r\n  private escapeRegex(str: string): string {\r\n    return str.replace(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&');\r\n  }\r\n\r\n  get getPreviewContent(): SafeHtml {\r\n    return this.previewContent();\r\n  }\r\n}\r\n","<div\r\n  class=\"kv-editor-container h-full w-full max-h-full flex flex-column overflow-hidden\"\r\n>\r\n  <div\r\n    #editor\r\n    id=\"kv-editor-toolbar\"\r\n    [ngClass]=\"{ 'error-border-toolbar': hasControlError() }\"\r\n    class=\"{{ showHeader() ? 'flex' : 'hidden' }} flex-column flex-initial\"\r\n  >\r\n    @if(relatorios().length > 0) {\r\n    <div class=\"flex flex-row justify-content-between {{readonly() && 'pointer-events-none opacity-90'}}\">\r\n      <div class=\"flex flex-row gap-2\">\r\n        <div\r\n          class=\"flex flex-row align-items-center gap-2 p-2 border-round-lg border-1 border-gray-200 hover:shadow-1 hover:bg-gray-100 cursor-pointer transition-all transition-duration-300\"\r\n          (click)=\"op.toggle($event)\"\r\n        >\r\n          <span\r\n            class=\"material-symbols-outlined text-lg text-green-600 font-medium\"\r\n          >\r\n            contract\r\n          </span>\r\n          <span class=\"font-semibold text-xs text-gray-600\">{{\r\n            !clearedTemplate()\r\n              ? relatorio()?.label || labelEmptyDropdown()\r\n              : labelEmptyDropdown()\r\n          }}</span>\r\n          <span class=\"material-symbols-outlined text-lg\">\r\n            keyboard_arrow_down\r\n          </span>\r\n        </div>\r\n\r\n        @if(!clearedTemplate()) {\r\n        <div\r\n          class=\"flex flex-row align-items-center gap-2 p-2 border-round-lg border-1 border-gray-200 hover:shadow-1 hover:bg-gray-100 cursor-pointer transition-all transition-duration-300\"\r\n          (click)=\"clearTemplate()\"\r\n        >\r\n          <span\r\n            class=\"material-symbols-outlined text-lg text-orange-600 font-medium\"\r\n            [pTooltip]=\"'Limpar Template'\"\r\n          >\r\n            layers_clear\r\n          </span>\r\n        </div>\r\n        }\r\n\r\n        <div\r\n          class=\"flex flex-row align-items-center gap-2 p-2 border-round-lg border-1 border-gray-200 hover:shadow-1 hover:bg-gray-100 cursor-pointer transition-all transition-duration-300\"\r\n          (click)=\"showInstrucoes()\"\r\n        >\r\n          <span\r\n            class=\"material-symbols-outlined text-lg text-blue-600 font-medium\"\r\n          >\r\n            info\r\n          </span>\r\n          <span class=\"font-semibold text-xs text-gray-600\">Instruções</span>\r\n        </div>\r\n      </div>\r\n\r\n      <!-- @if(printButton()) {\r\n      <div\r\n        class=\"flex flex-row align-items-center gap-2 p-2 border-round-lg border-1 border-gray-200 hover:shadow-1 hover:bg-gray-100 cursor-pointer transition-all transition-duration-300\"\r\n        (click)=\"openRelatorio()\"\r\n      >\r\n        <span class=\"material-symbols-outlined text-lg font-medium\">\r\n          print\r\n        </span>\r\n        <span class=\"font-semibold text-xs text-gray-600\">Imprimir</span>\r\n      </div>\r\n      } -->\r\n    </div>\r\n\r\n    <p-divider class=\"w-full\"></p-divider>\r\n\r\n    }\r\n\r\n    <div\r\n      class=\"flex flex-row align-items-center justify-content-between w-full flex-initial\"\r\n    >\r\n      @if(isLoading()) {\r\n\r\n      <div class=\"flex flex-row align-items-center gap-3 w-full\">\r\n        <p-skeleton\r\n          styleClass=\"w-6rem\"\r\n          [style]=\"{ height: '2rem' }\"\r\n        ></p-skeleton>\r\n\r\n        <p-skeleton\r\n          styleClass=\"w-6rem\"\r\n          [style]=\"{ height: '2rem' }\"\r\n        ></p-skeleton>\r\n\r\n        <p-skeleton\r\n          styleClass=\"w-6rem\"\r\n          [style]=\"{ height: '2rem' }\"\r\n        ></p-skeleton>\r\n\r\n        <p-skeleton\r\n          styleClass=\"w-6rem\"\r\n          [style]=\"{ height: '2rem' }\"\r\n        ></p-skeleton>\r\n\r\n        <p-skeleton\r\n          styleClass=\"w-6rem\"\r\n          [style]=\"{ height: '2rem' }\"\r\n        ></p-skeleton>\r\n      </div>\r\n      }\r\n\r\n      <div\r\n        class=\"flex-row align-items-center flex-wrap gap-2 {{\r\n          isLoading() ? 'hidden' : 'flex'\r\n        }} w-full\"\r\n      >\r\n        <span class=\"ql-formats border-round-md\">\r\n          <select class=\"ql-font\">\r\n            <option value=\"roboto\">Roboto</option>\r\n            <option value=\"arial\">Arial</option>\r\n            <option value=\"times-new-roman\">Times New Roman</option>\r\n            <option value=\"monospace\">Monospace</option>\r\n            <option value=\"inter\">Inter</option>\r\n            <option selected>Sans Serif</option>\r\n            <option value=\"serif\">Serif</option>\r\n          </select>\r\n\r\n          <select class=\"ql-header\">\r\n            <option value=\"1\">Titulo</option>\r\n            <option value=\"2\">Subtitulo</option>\r\n            <option selected>Normal</option>\r\n          </select>\r\n\r\n          <span class=\"ql-format-group\">\r\n            <select title=\"Size\" class=\"ql-size\">\r\n              <option value=\"15px\">15px</option>\r\n              <option value=\"20px\">20px</option>\r\n              <option value=\"30px\">30px</option>\r\n              <option value=\"40px\">40px</option>\r\n              <option value=\"50px\">50px</option>\r\n              <option value=\"70px\">70px</option>\r\n              <option value=\"90px\">90px</option>\r\n            </select>\r\n          </span>\r\n        </span>\r\n\r\n        <p-divider layout=\"vertical\"></p-divider>\r\n\r\n        <span class=\"ql-formats border-round-md\">\r\n          <button class=\"ql-bold\"></button>\r\n          <button class=\"ql-italic\"></button>\r\n          <button class=\"ql-underline\"></button>\r\n          <button class=\"ql-strike\"></button>\r\n        </span>\r\n\r\n        <p-divider layout=\"vertical\"></p-divider>\r\n\r\n        <span class=\"ql-formats border-round-md\">\r\n          <select class=\"ql-color\"></select>\r\n          <select class=\"ql-background\"></select>\r\n        </span>\r\n\r\n        @if(true) {\r\n        <!-- <p-divider layout=\"vertical\"></p-divider>\r\n\r\n      <span class=\"ql-formats border-round-md\">\r\n        <button class=\"ql-header\" value=\"1\"></button>\r\n        <button class=\"ql-header\" value=\"2\"></button>\r\n      </span> -->\r\n\r\n        <p-divider layout=\"vertical\"></p-divider>\r\n\r\n        <span class=\"ql-formats border-round-md\">\r\n          <button class=\"ql-link\"></button>\r\n          <button class=\"ql-image\"></button>\r\n          <button class=\"ql-video\"></button>\r\n        </span>\r\n\r\n        <p-divider layout=\"vertical\"></p-divider>\r\n\r\n        <span class=\"ql-formats border-round-md\">\r\n          <button class=\"ql-list\" value=\"ordered\"></button>\r\n          <button class=\"ql-list\" value=\"bullet\"></button>\r\n          <select class=\"ql-align\"></select>\r\n        </span>\r\n        }\r\n      </div>\r\n    </div>\r\n  </div>\r\n  <div\r\n    style=\"height: 3px; border-top: none; border-bottom: none\"\r\n    [style.borderRight]=\"showHeader() ? '1px solid #e5e7eb' : 'none'\"\r\n    [style.borderLeft]=\"showHeader() ? '1px solid #e5e7eb' : 'none'\"\r\n  >\r\n    @if(isLoadingPdf()) {\r\n    <p-progressBar mode=\"indeterminate\" [style]=\"{ height: '3px' }\" />\r\n    }\r\n  </div>\r\n\r\n  <div class=\"flex flex-row flex-1 gap-0 overflow-auto\">\r\n    <div\r\n      id=\"kv-editor\"\r\n      class=\"overflow-auto flex-1 scrollstyle\"\r\n      [ngClass]=\"{\r\n        'error-border': hasControlError(),\r\n        'pointer-events-none opacity-60': isLoadingPdf()\r\n      }\"\r\n      [style.borderTop]=\"showHeader() ? 'none' : '1px solid #e5e7eb'\"\r\n      [style.borderRight]=\"enablePreviewMode() ? 'none' : '1px solid #e5e7eb'\"\r\n    ></div>\r\n\r\n    @if(enablePreviewMode()) {\r\n    <div class=\"flex flex-column flex-1\">\r\n      <div \r\n        class=\"flex align-items-center gap-2 px-3 py-2\" \r\n        [style.borderRight]=\"'1px solid #e5e7eb'\"\r\n        [style.borderLeft]=\"'1px solid #e5e7eb'\"\r\n      >\r\n        <span class=\"material-symbols-outlined text-blue-600 text-lg\">visibility</span>\r\n        <span class=\"font-semibold text-gray-700 text-sm\">Preview</span>\r\n      </div>\r\n      \r\n      <div\r\n        id=\"kv-editor-preview\"\r\n        class=\"overflow-auto flex-1 scrollstyle\"\r\n        [innerHTML]=\"getPreviewContent\"\r\n        [style.border]=\"'1px solid #e5e7eb'\"\r\n      ></div>\r\n    </div>\r\n    }\r\n  </div>\r\n\r\n</div>\r\n<kv-error [hasError]=\"hasControlError()\">{{ erroMessage() }}</kv-error>\r\n\r\n<!-- <link href=\"https://cdn.jsdelivr.net/npm/quill@2.0.2/dist/quill.snow.css\" rel=\"stylesheet\" /> -->\r\n<link href=\"https://fonts.googleapis.com/css?family=Roboto\" rel=\"stylesheet\" />\r\n<script src=\"https://cdn.jsdelivr.net/npm/quill@2.0.2/dist/quill.js\"></script>\r\n<script src=\"https://cdn.jsdelivr.net/npm/katex@0.16.9/dist/katex.min.js\"></script>\r\n\r\n<link\r\n  rel=\"stylesheet\"\r\n  href=\"https://cdn.jsdelivr.net/npm/quill@2.0.2/dist/quill.bubble.css\"\r\n/>\r\n<link\r\n  rel=\"stylesheet\"\r\n  href=\"https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.9.0/styles/atom-one-dark.min.css\"\r\n/>\r\n<link\r\n  rel=\"stylesheet\"\r\n  href=\"https://cdn.jsdelivr.net/npm/katex@0.16.9/dist/katex.min.css\"\r\n/>\r\n\r\n<p-overlayPanel #op styleClass=\"overflow-hidden\">\r\n  <div\r\n    class=\"grid m-0 gap-2 p-2 max-w-20rem overflow-y-auto scrollstyle\"\r\n    style=\"max-height: 16rem\"\r\n  >\r\n    @for(item of relatorios(); track $index) {\r\n    <div\r\n      class=\"col-12 cursor-pointer hover:bg-gray-100 transition-colors transition-duration-200 border-round-lg shadow-2 flex flex-column gap-2\"\r\n      (click)=\"setRelatorio(item)\"\r\n    >\r\n      <div\r\n        class=\"flex flex-row align-items-center gap-2 justify-content-between\"\r\n      >\r\n        <span class=\"text-sm font-medium w-full\">{{ item.label }}</span>\r\n\r\n        <kv-tags\r\n          class=\"transition-opacity transition-duration-300 {{\r\n            item?.id == idRelatorioSelected() ? 'opacity-100' : 'opacity-0'\r\n          }}\"\r\n          [tags]=\"[{ label: 'Selecionado', severity: 'primary' }]\"\r\n        ></kv-tags>\r\n      </div>\r\n      <span class=\"text-xs text-gray-500\">{{ item.descricao }}</span>\r\n    </div>\r\n    }\r\n  </div>\r\n</p-overlayPanel>\r\n\r\n<div class=\"kv-editor-container flex flex-column overflow-hidden relative\">\r\n  <div\r\n    #mentionAnchor\r\n    style=\"position: fixed; width: 1px; height: 1px; opacity: 0\"\r\n  ></div>\r\n</div>\r\n\r\n<p-overlayPanel\r\n  #opVariables\r\n  [appendTo]=\"'body'\"\r\n  (onHide)=\"closeVariablesPanel()\"\r\n>\r\n  <div\r\n    class=\"flex flex-column gap-1 p-1 overflow-y-auto scroll-virtual border-round-lg\"\r\n    style=\"max-height: 250px; min-width: 250px; background-color: #333333\"\r\n  >\r\n    @for(variable of filteredVariables(); track variable.id) {\r\n    <div\r\n      class=\"p-2 cursor-pointer transition-colors transition-duration-200 border-round-lg text-sm text-white option-dropdown\"\r\n      (click)=\"selectVariableFromPanel(variable)\"\r\n    >\r\n      {{ variable.descricao }} (\r\n      <span class=\"text-gray-400\">{{ variable.value }}</span> )\r\n    </div>\r\n    } @empty {\r\n    <div class=\"p-2 text-sm text-gray-500\">Nenhuma variável encontrada.</div>\r\n    }\r\n  </div>\r\n</p-overlayPanel>\r\n"]}
459
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-editor.component.js","sourceRoot":"","sources":["../../../../../../../projects/keevo-components/src/lib/components/kv-inputs/kv-editor/kv-editor.component.ts","../../../../../../../projects/keevo-components/src/lib/components/kv-inputs/kv-editor/kv-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  computed,\r\n  effect,\r\n  ElementRef,\r\n  EventEmitter,\r\n  inject,\r\n  input,\r\n  Input,\r\n  model,\r\n  OnInit,\r\n  output,\r\n  Output,\r\n  Renderer2,\r\n  signal,\r\n  TemplateRef,\r\n  ViewChild,\r\n  SecurityContext,\r\n} from '@angular/core';\r\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\r\n\r\nimport Quill from 'quill';\r\nimport { OverlayPanel } from 'primeng/overlaypanel';\r\nimport { DialogService } from 'primeng/dynamicdialog';\r\n\r\nimport { BaseComponentInput } from '../../../api/base-components/base-component-input';\r\nimport { ComponentProviders } from '../../../api/helpers/component-providers';\r\nimport { ComponentService } from '../../../api/services/component.service';\r\nimport { KvInstrucoesReportComponent } from './components/kv-instrucoes-report/kv-instrucoes-report.component';\r\n\r\nimport {\r\n  KvEditorRelatorio,\r\n  KvEditorVariavel,\r\n  KvEditorQuillService,\r\n  KvEditorRelatorioService,\r\n  KvEditorMentionService,\r\n  KvEditorPdfService\r\n} from './kv-editor';\r\n\r\n@Component({\r\n  selector: 'kv-editor',\r\n  templateUrl: './kv-editor.component.html',\r\n  styleUrls: ['./kv-editor.component.scss'],\r\n  providers: ComponentProviders(KvEditorComponent),\r\n})\r\nexport class KvEditorComponent extends BaseComponentInput<string> implements OnInit {\r\n\r\n  constructor(\r\n    componentService: ComponentService,\r\n    private sanitizer: DomSanitizer\r\n  ) {\r\n    super(componentService);\r\n\r\n    effect(() => {\r\n      let readonly = this.readonly();\r\n      if (this.quill) {\r\n        this.quill.enable(!readonly);\r\n      }\r\n    });\r\n\r\n    effect(() => {\r\n      if (this.enablePreviewMode()) {\r\n        this.atualizarPreview();\r\n      }\r\n    });\r\n  }\r\n\r\n  // Injeção de serviços\r\n  private quillService = inject(KvEditorQuillService);\r\n  private relatorioService = inject(KvEditorRelatorioService);\r\n  private mentionService = inject(KvEditorMentionService);\r\n  private pdfService = inject(KvEditorPdfService);\r\n  private dialogService = inject(DialogService);\r\n\r\n  // Propriedades de configuração\r\n  /**\r\n   * @deprecated Essa propriedade não será mais utilizada por esse componente nas próximas versões.\r\n   */\r\n  @Input() canvaHeigth: string = '380px';\r\n\r\n  @Input() contentType: 'html' | 'text' = 'html';\r\n  @Input() debug: boolean = false;\r\n\r\n  // Eventos\r\n  @Output() onTextChange: EventEmitter<any> = new EventEmitter();\r\n  @Output() onSelectionChange: EventEmitter<any> = new EventEmitter();\r\n  @Output() outputRaw: EventEmitter<string> = new EventEmitter();\r\n  @Output() outputHtml: EventEmitter<string> = new EventEmitter();\r\n\r\n  // Propriedades internas\r\n  private updatingEditor: boolean = false;\r\n  private lastSelectionRange: any = null;\r\n  private editorReadyResolver!: () => void;\r\n  private editorReadyPromise = new Promise<void>((resolve) => {\r\n    this.editorReadyResolver = resolve;\r\n  });\r\n\r\n  // Instância do Quill\r\n  quill!: Quill;\r\n  htmlDoEditor = '';\r\n  quillDelta = Quill.import('delta');\r\n\r\n  // Signal para espelhamento do conteúdo do editor\r\n  htmlEspelho = signal<string>('');\r\n  previewContent = signal<SafeHtml>('');\r\n\r\n  // Signals para controle de estado\r\n  initLoadComplete = signal<boolean>(false);\r\n  isLoading = signal<boolean>(true);\r\n  editorToolbarHeight = signal<string>('3rem');\r\n  // tipoVisualizacao = signal<'valor' | 'descricao'>('descricao');\r\n  filteredVariables = signal<KvEditorVariavel[]>([]);\r\n  clearedTemplate = signal<boolean>(false);\r\n\r\n  //Input para habilitar preview\r\n  enablePreviewMode = input<boolean>(false);\r\n\r\n  // Inputs para relatórios\r\n  relatorios = input<KvEditorRelatorio[]>([]);\r\n  idRelatorioInitial = model<any>(0);\r\n  printButton = input<boolean>(true);\r\n  labelEmptyDropdown = input<string>('Selecione um relatório');\r\n  instrucoesTemplate = input<TemplateRef<any> | undefined>(undefined);\r\n  showHeader = input<boolean>(true);\r\n  readonly = input<boolean>(false);\r\n\r\n\r\n  // Computed properties para relatórios\r\n  idRelatorioSelected = computed(() => this.relatorioService.getIdRelatorioSelected());\r\n  relatorio = computed(() => this.relatorioService.getRelatorioSelected());\r\n  isLoadingPdf = computed(() => this.pdfService.getIsLoadingPdf());\r\n\r\n  // ViewChild para overlay panels\r\n  @ViewChild('opVariables') opVariables!: OverlayPanel;\r\n  @ViewChild('mentionAnchor') mentionAnchor!: ElementRef;\r\n\r\n  messages = [{ severity: 'info', detail: 'Message Content' }];\r\n\r\n  // Métodos para gerenciar relatórios\r\n  setRelatorioPorId(id: any): void {\r\n    const relatorio = this.relatorioService.setRelatorioPorId(id);\r\n    if (relatorio) {\r\n      this.setRelatorio(relatorio);\r\n    }\r\n  }\r\n\r\n  setRelatorio(relatorio: KvEditorRelatorio): void {\r\n    this.clearedTemplate.set(false);\r\n    this.relatorioService.setRelatorio(relatorio);\r\n    const modelo = relatorio.modeloRelatorio || '';\r\n    const variaveis = relatorio.variaveis || [];\r\n\r\n    this.htmlDoEditor = this.relatorioService.renderContrato(modelo, variaveis);\r\n    this.updatingEditor = true;\r\n    this.escrevaValor(this.htmlDoEditor);\r\n  }\r\n\r\n  override ngOnInit(): void {\r\n    super.ngOnInit();\r\n\r\n    // Inicializa os relatórios no serviço\r\n    this.relatorioService.setRelatorios(this.relatorios());\r\n\r\n    if (!this.quill) {\r\n      this.handleInit();\r\n    }\r\n\r\n    setTimeout(() => {\r\n      this.isLoading.set(false);\r\n    }, 1000);\r\n\r\n    if (this.idRelatorioInitial()) {\r\n      this.clearedTemplate.set(false);\r\n      this.setRelatorioPorId(this.idRelatorioInitial());\r\n    } else this.clearedTemplate.set(true);\r\n\r\n    setTimeout(() => {\r\n      if (this.enablePreviewMode()) {\r\n        this.atualizarPreview();\r\n      }\r\n    }, 1500);\r\n  }\r\n\r\n  async handleInit(): Promise<void> {\r\n    await this.quillService.loadCss();\r\n    this.initializeQuillEditor();\r\n  }\r\n\r\n  initializeQuillEditor(): void {\r\n    const config = {\r\n      theme: 'snow',\r\n      modules: {\r\n        toolbar: '#kv-editor-toolbar',\r\n        clipboard: {\r\n          matchVisual: false,\r\n          matchers: [\r\n            ['*', (node: any, delta: any) => {\r\n              return delta;\r\n            }]\r\n          ]\r\n        }\r\n      },\r\n      placeholder: this.label ? this.label : '',\r\n      readOnly: this.readonly(),\r\n      debug: this.debug,\r\n    };\r\n\r\n    this.quill = this.quillService.createQuillInstance('#kv-editor', config);\r\n\r\n    this.configurarHtmlClipboard();\r\n\r\n    this.setupQuillEvents();\r\n    this.editorReadyResolver();\r\n    this.initLoadComplete.set(true);\r\n\r\n    setTimeout(() => {\r\n      const control = this.formControl;\r\n      if (control && control.markAsPristine) {\r\n        control.markAsPristine();\r\n        control.markAsUntouched();\r\n      }\r\n    }, 0);\r\n  }\r\n\r\n  private setupQuillEvents(): void {\r\n    this.quill.on('selection-change', (range, oldRange, source) => {\r\n      if (range) {\r\n        this.lastSelectionRange = range;\r\n      }\r\n      this.onSelectionChange.emit({\r\n        range: range,\r\n        oldRange: oldRange,\r\n        source: source,\r\n      });\r\n    });\r\n\r\n    this.quill.on('text-change', (delta, oldContents, source) => {\r\n      if (source === 'user' && delta.ops) {\r\n        this.configurarHtmlAutoCompleteTag(delta);\r\n      }\r\n\r\n      if (this.relatorios().length > 0) {\r\n        this.handleMention();\r\n      }\r\n\r\n      if (!this.updatingEditor) {\r\n        this.updatingEditor = false;\r\n        this.escrevaValor(this.quill.getSemanticHTML(), this.quill.getText());\r\n\r\n        this.onTextChange.emit({\r\n          delta: delta,\r\n          oldContents: oldContents,\r\n          source: source,\r\n        });\r\n\r\n        this.outputRaw.emit(this.quill.getText());\r\n        this.outputHtml.emit(this.quill.getSemanticHTML());\r\n\r\n        if (this.enablePreviewMode()) {\r\n          this.atualizarPreview();\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  override writeValue(value: any): void {\r\n    this.updatingEditor = true;\r\n    this.escrevaValor(value);\r\n  }\r\n\r\n  async escrevaValor(htmlvalue: any, rawvalue?: any): Promise<void> {\r\n    if (!this.initLoadComplete()) {\r\n      await this.editorReadyPromise;\r\n    }\r\n\r\n    if (this.quill) {\r\n      if (this.updatingEditor) {\r\n        this.quill.clipboard.dangerouslyPasteHTML(htmlvalue);\r\n      }\r\n      this.updatingEditor = false;\r\n      this.value = htmlvalue;\r\n\r\n      if (rawvalue == \"\\n\" || this.value == \"\\n\") {\r\n        this.value = '';\r\n      }\r\n\r\n      if (this.enablePreviewMode()) {\r\n        setTimeout(() => this.atualizarPreview(), 100);\r\n      }\r\n    } else {\r\n      this.updatingEditor = false;\r\n    }\r\n\r\n    this.outputHtml.emit(this.quill.getSemanticHTML());\r\n  }\r\n\r\n  getEditorSize(): void {\r\n    let editorFieldHeight = document.getElementById('kv-editor-toolbar')?.offsetHeight;\r\n    if (editorFieldHeight) {\r\n      this.editorToolbarHeight.set(`${editorFieldHeight}px`);\r\n    }\r\n  }\r\n\r\n  async openRelatorio(): Promise<void> {\r\n    if (this.isLoadingPdf()) return;\r\n\r\n    const htmlContent = this.quill.getSemanticHTML();\r\n    const relatorio = this.relatorio();\r\n    // const tipoVisualizacao = this.tipoVisualizacao();\r\n\r\n    await this.pdfService.openRelatorio(htmlContent, relatorio, 'valor');\r\n  }\r\n\r\n  // Métodos para sistema de menções\r\n  handleMention(): void {\r\n    if (!this.relatorio()) return;\r\n\r\n    const result = this.mentionService.handleMention(this.quill, this.relatorio()!.variaveis);\r\n    this.filteredVariables.set(result.filteredVariables);\r\n\r\n    if (result.shouldShowPanel && result.mentionBounds) {\r\n      this.showVariablesPanel(result.mentionBounds);\r\n    } else {\r\n      this.closeVariablesPanel();\r\n    }\r\n  }\r\n\r\n  private showVariablesPanel(bounds: { top: number; left: number }): void {\r\n    const anchorEl = this.mentionAnchor.nativeElement;\r\n    anchorEl.style.top = `${bounds.top}px`;\r\n    anchorEl.style.left = `${bounds.left}px`;\r\n    this.opVariables.show(null, anchorEl);\r\n  }\r\n\r\n  selectVariableFromPanel(variable: KvEditorVariavel): void {\r\n    this.mentionService.insertVariable(this.quill, variable);\r\n    this.closeVariablesPanel();\r\n  }\r\n\r\n  closeVariablesPanel(): void {\r\n    if (this.opVariables) {\r\n      this.opVariables.hide();\r\n    }\r\n    this.mentionService.closeMention();\r\n  }\r\n\r\n  showInstrucoes(): void {\r\n    this.dialogService.open(KvInstrucoesReportComponent, {\r\n      header: 'Instruções',\r\n      width: '40%',\r\n      height: '30%',\r\n      modal: true,\r\n      closable: true,\r\n      data: {\r\n        template: this.instrucoesTemplate()\r\n      }\r\n    });\r\n  }\r\n\r\n  clearTemplate() {\r\n    // Limpa o template do editor\r\n    this.clearedTemplate.set(true);\r\n    this.setRelatorioPorId(0);\r\n    this.writeValue('');\r\n  }\r\n\r\n  private configurarHtmlClipboard(): void {\r\n    const editor = this.quill.root;\r\n    \r\n    editor.addEventListener('paste', (e: ClipboardEvent) => {\r\n      if (e.clipboardData) {\r\n        e.preventDefault();\r\n        e.stopPropagation();\r\n        \r\n        const html = e.clipboardData.getData('text/html');\r\n        const text = e.clipboardData.getData('text/plain');\r\n        \r\n        const selection = this.quill.getSelection();\r\n        if (!selection) return;\r\n        \r\n        if (html && html.trim()) {\r\n          const startIndex = selection.index;\r\n          \r\n          //a partir daqui é para evitar que o copiar seja duplicado\r\n          this.updatingEditor = true;\r\n          \r\n          this.quill.clipboard.dangerouslyPasteHTML(startIndex, html);\r\n          \r\n          setTimeout(() => {\r\n            this.updatingEditor = false;\r\n            \r\n            const newLength = this.quill.getLength();\r\n            this.quill.setSelection(newLength, 0);\r\n            \r\n            if (this.enablePreviewMode()) {\r\n              this.atualizarPreview();\r\n            }\r\n          }, 10);\r\n        } \r\n        else if (text && text.trim()) {\r\n          this.quill.insertText(selection.index, text, 'user');\r\n          this.quill.setSelection(selection.index + text.length, 0);\r\n        }\r\n      }\r\n    }, true);\r\n  }\r\n\r\n  //#region Métodos modo preview\r\n\r\n  private atualizarPreview(): void {\r\n    if (!this.quill) return;\r\n\r\n    let conteudoHtml = this.quill.root.innerHTML;\r\n\r\n    conteudoHtml = this.decodificarEntidadesHtml(conteudoHtml);\r\n    \r\n    this.htmlEspelho.set(conteudoHtml);\r\n\r\n    const conteudoProcessado = this.processarConteudoPreview(conteudoHtml);\r\n    this.previewContent.set(conteudoProcessado);\r\n  }\r\n\r\n  private decodificarEntidadesHtml(text: string): string {\r\n    const textarea = document.createElement('textarea');\r\n    textarea.innerHTML = text;\r\n    return textarea.value;\r\n  }\r\n\r\n  private configurarHtmlAutoCompleteTag(delta: any): void {\r\n    if (!delta.ops || delta.ops.length === 0) return;\r\n\r\n    const ultimoOp = delta.ops[delta.ops.length - 1];\r\n    if (ultimoOp.insert && typeof ultimoOp.insert === 'string' && ultimoOp.insert === '>') {\r\n      const textoAtual = this.quill.getText();\r\n      const posicaoCursor = this.quill.getSelection()?.index || 0;\r\n\r\n      const textoAntesCursor = textoAtual.substring(0, posicaoCursor);\r\n\r\n      const regexTagAberta = /<(\\w+)(?:\\s+[^>]*)?(?<!\\/)\\>$/;\r\n      const verificarTag = textoAntesCursor.match(regexTagAberta);\r\n\r\n      if (verificarTag) {\r\n        const tagName = verificarTag[1];\r\n\r\n        const tagsInline = ['img', 'br', 'hr', 'input', 'meta', 'link', 'area', 'base', 'col', 'embed', 'source', 'track', 'wbr'];\r\n\r\n        if (!tagsInline.includes(tagName.toLowerCase())) {\r\n          const textoDepoisCursor = textoAtual.substring(posicaoCursor);\r\n          const fecharTagRegex = new RegExp(`^<\\/${tagName}>`, 'i');\r\n\r\n          if (!fecharTagRegex.test(textoDepoisCursor)) {\r\n            this.updatingEditor = true;\r\n            this.quill.insertText(posicaoCursor, `</${tagName}>`, 'user');\r\n\r\n            setTimeout(() => {\r\n              this.quill.setSelection(posicaoCursor, 0);\r\n              this.updatingEditor = false;\r\n            }, 0);\r\n          }\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  private processarConteudoPreview(content: string): SafeHtml {\r\n    if (!content || content === '\\n') {\r\n      return this.sanitizer.bypassSecurityTrustHtml('<p class=\"text-gray-400 text-sm\">O conteúdo aparecerá aqui...</p>');\r\n    }\r\n\r\n    const styleRegex = /<style[^>]*>([\\s\\S]*?)<\\/style>/gi;\r\n    const styles: string[] = [];\r\n    let conteudoProcessado = content;\r\n\r\n    let match;\r\n    while ((match = styleRegex.exec(content)) !== null) {\r\n      styles.push(match[1]);\r\n    }\r\n\r\n    conteudoProcessado = this.processarVariaveisComHtml(conteudoProcessado);\r\n    conteudoProcessado = this.manterQuebrasLinhaHtml(conteudoProcessado);\r\n\r\n    let conteudoFinal = '<div class=\"kv-editor-preview-wrapper\">';\r\n\r\n    if (styles.length > 0) {\r\n      conteudoFinal += '<style>' + styles.join('\\n') + '</style>';\r\n    }\r\n\r\n    conteudoFinal += conteudoProcessado;\r\n    conteudoFinal += '</div>';\r\n\r\n    return this.sanitizer.bypassSecurityTrustHtml(conteudoFinal);\r\n  }\r\n\r\n  private manterQuebrasLinhaHtml(html: string): string {\r\n    return html;\r\n  }\r\n\r\n  private isHtmlString(str: string): boolean {\r\n    if (!str || typeof str !== 'string') return false;\r\n    \r\n    const trimmed = str.trim();\r\n    \r\n    if (!trimmed.startsWith('<') || !trimmed.endsWith('>')) return false;\r\n    \r\n    const htmlTagRegex = /<\\/?[a-z][\\s\\S]*?>/i;\r\n    const hasOpeningTag = /<[a-z][\\s\\S]*?>/i.test(trimmed);\r\n    const hasClosingTag = /<\\/[a-z][\\s\\S]*?>/i.test(trimmed);\r\n    \r\n    return htmlTagRegex.test(trimmed) && (hasOpeningTag || hasClosingTag);\r\n  }\r\n\r\n  private processarVariaveisComHtml(content: string): string {\r\n    if (!this.relatorio() || !this.relatorio()!.variaveis) {\r\n      return content;\r\n    }\r\n\r\n    let conteudoProcessado = content;\r\n    const variaveis = this.relatorio()!.variaveis;\r\n\r\n    variaveis.forEach(variavel => {\r\n      if (!this.isHtmlString(variavel.value)) {\r\n        return;\r\n      }\r\n\r\n      const placeholderId = `{${variavel.id}}`;\r\n      \r\n      if (conteudoProcessado.includes(placeholderId)) {\r\n        conteudoProcessado = conteudoProcessado.split(placeholderId).join(variavel.value);\r\n      }\r\n      \r\n\r\n      const patterns = [\r\n        `<span[^>]*class=\"[^\"]*mention[^\"]*\"[^>]*>\\\\s*${this.escapeRegex(variavel.descricao)}\\\\s*</span>`,\r\n        `<span[^>]*data-mention[^>]*>\\\\s*${this.escapeRegex(variavel.descricao)}\\\\s*</span>`,\r\n        `>\\\\s*${this.escapeRegex(variavel.descricao)}\\\\s*<`,\r\n        `<[^>]+>\\\\s*${this.escapeRegex(variavel.descricao)}\\\\s*</[^>]+>`\r\n      ];\r\n\r\n      let substituido = false;\r\n      for (const pattern of patterns) {\r\n        const regexMention = new RegExp(pattern, 'gi');\r\n        if (regexMention.test(conteudoProcessado)) {\r\n          conteudoProcessado = conteudoProcessado.replace(regexMention, \r\n            pattern.startsWith('>') ? `>${variavel.value}<` : variavel.value\r\n          );\r\n          substituido = true;\r\n          break;\r\n        }\r\n      }\r\n      \r\n      if (!substituido && conteudoProcessado.includes(variavel.descricao)) {\r\n        conteudoProcessado = conteudoProcessado.split(variavel.descricao).join(variavel.value);\r\n      }\r\n    });\r\n\r\n    return conteudoProcessado;\r\n  }\r\n\r\n  private escapeRegex(str: string): string {\r\n    return str.replace(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&');\r\n  }\r\n\r\n  get getPreviewContent(): SafeHtml {\r\n    return this.previewContent();\r\n  }\r\n\r\n  //#endregion\r\n}\r\n","<div\r\n  class=\"kv-editor-container h-full w-full max-h-full flex flex-column overflow-hidden\"\r\n>\r\n  <div\r\n    #editor\r\n    id=\"kv-editor-toolbar\"\r\n    [ngClass]=\"{ 'error-border-toolbar': hasControlError() }\"\r\n    class=\"{{ showHeader() ? 'flex' : 'hidden' }} flex-column flex-initial\"\r\n  >\r\n    @if(relatorios().length > 0) {\r\n    <div class=\"flex flex-row justify-content-between {{readonly() && 'pointer-events-none opacity-90'}}\">\r\n      <div class=\"flex flex-row gap-2\">\r\n        <div\r\n          class=\"flex flex-row align-items-center gap-2 p-2 border-round-lg border-1 border-gray-200 hover:shadow-1 hover:bg-gray-100 cursor-pointer transition-all transition-duration-300\"\r\n          (click)=\"op.toggle($event)\"\r\n        >\r\n          <span\r\n            class=\"material-symbols-outlined text-lg text-green-600 font-medium\"\r\n          >\r\n            contract\r\n          </span>\r\n          <span class=\"font-semibold text-xs text-gray-600\">{{\r\n            !clearedTemplate()\r\n              ? relatorio()?.label || labelEmptyDropdown()\r\n              : labelEmptyDropdown()\r\n          }}</span>\r\n          <span class=\"material-symbols-outlined text-lg\">\r\n            keyboard_arrow_down\r\n          </span>\r\n        </div>\r\n\r\n        @if(!clearedTemplate()) {\r\n        <div\r\n          class=\"flex flex-row align-items-center gap-2 p-2 border-round-lg border-1 border-gray-200 hover:shadow-1 hover:bg-gray-100 cursor-pointer transition-all transition-duration-300\"\r\n          (click)=\"clearTemplate()\"\r\n        >\r\n          <span\r\n            class=\"material-symbols-outlined text-lg text-orange-600 font-medium\"\r\n            [pTooltip]=\"'Limpar Template'\"\r\n          >\r\n            layers_clear\r\n          </span>\r\n        </div>\r\n        }\r\n\r\n        <div\r\n          class=\"flex flex-row align-items-center gap-2 p-2 border-round-lg border-1 border-gray-200 hover:shadow-1 hover:bg-gray-100 cursor-pointer transition-all transition-duration-300\"\r\n          (click)=\"showInstrucoes()\"\r\n        >\r\n          <span\r\n            class=\"material-symbols-outlined text-lg text-blue-600 font-medium\"\r\n          >\r\n            info\r\n          </span>\r\n          <span class=\"font-semibold text-xs text-gray-600\">Instruções</span>\r\n        </div>\r\n      </div>\r\n\r\n      <!-- @if(printButton()) {\r\n      <div\r\n        class=\"flex flex-row align-items-center gap-2 p-2 border-round-lg border-1 border-gray-200 hover:shadow-1 hover:bg-gray-100 cursor-pointer transition-all transition-duration-300\"\r\n        (click)=\"openRelatorio()\"\r\n      >\r\n        <span class=\"material-symbols-outlined text-lg font-medium\">\r\n          print\r\n        </span>\r\n        <span class=\"font-semibold text-xs text-gray-600\">Imprimir</span>\r\n      </div>\r\n      } -->\r\n    </div>\r\n\r\n    <p-divider class=\"w-full\"></p-divider>\r\n\r\n    }\r\n\r\n    <div\r\n      class=\"flex flex-row align-items-center justify-content-between w-full flex-initial\"\r\n    >\r\n      @if(isLoading()) {\r\n\r\n      <div class=\"flex flex-row align-items-center gap-3 w-full\">\r\n        <p-skeleton\r\n          styleClass=\"w-6rem\"\r\n          [style]=\"{ height: '2rem' }\"\r\n        ></p-skeleton>\r\n\r\n        <p-skeleton\r\n          styleClass=\"w-6rem\"\r\n          [style]=\"{ height: '2rem' }\"\r\n        ></p-skeleton>\r\n\r\n        <p-skeleton\r\n          styleClass=\"w-6rem\"\r\n          [style]=\"{ height: '2rem' }\"\r\n        ></p-skeleton>\r\n\r\n        <p-skeleton\r\n          styleClass=\"w-6rem\"\r\n          [style]=\"{ height: '2rem' }\"\r\n        ></p-skeleton>\r\n\r\n        <p-skeleton\r\n          styleClass=\"w-6rem\"\r\n          [style]=\"{ height: '2rem' }\"\r\n        ></p-skeleton>\r\n      </div>\r\n      }\r\n\r\n      <div\r\n        class=\"flex-row align-items-center flex-wrap gap-2 {{\r\n          isLoading() ? 'hidden' : 'flex'\r\n        }} w-full\"\r\n      >\r\n        <span class=\"ql-formats border-round-md\">\r\n          <select class=\"ql-font\">\r\n            <option value=\"roboto\">Roboto</option>\r\n            <option value=\"arial\">Arial</option>\r\n            <option value=\"times-new-roman\">Times New Roman</option>\r\n            <option value=\"monospace\">Monospace</option>\r\n            <option value=\"inter\">Inter</option>\r\n            <option selected>Sans Serif</option>\r\n            <option value=\"serif\">Serif</option>\r\n          </select>\r\n\r\n          <select class=\"ql-header\">\r\n            <option value=\"1\">Titulo</option>\r\n            <option value=\"2\">Subtitulo</option>\r\n            <option selected>Normal</option>\r\n          </select>\r\n\r\n          <span class=\"ql-format-group\">\r\n            <select title=\"Size\" class=\"ql-size\">\r\n              <option value=\"15px\">15px</option>\r\n              <option value=\"20px\">20px</option>\r\n              <option value=\"30px\">30px</option>\r\n              <option value=\"40px\">40px</option>\r\n              <option value=\"50px\">50px</option>\r\n              <option value=\"70px\">70px</option>\r\n              <option value=\"90px\">90px</option>\r\n            </select>\r\n          </span>\r\n        </span>\r\n\r\n        <p-divider layout=\"vertical\"></p-divider>\r\n\r\n        <span class=\"ql-formats border-round-md\">\r\n          <button class=\"ql-bold\"></button>\r\n          <button class=\"ql-italic\"></button>\r\n          <button class=\"ql-underline\"></button>\r\n          <button class=\"ql-strike\"></button>\r\n        </span>\r\n\r\n        <p-divider layout=\"vertical\"></p-divider>\r\n\r\n        <span class=\"ql-formats border-round-md\">\r\n          <select class=\"ql-color\"></select>\r\n          <select class=\"ql-background\"></select>\r\n        </span>\r\n\r\n        @if(true) {\r\n        <!-- <p-divider layout=\"vertical\"></p-divider>\r\n\r\n      <span class=\"ql-formats border-round-md\">\r\n        <button class=\"ql-header\" value=\"1\"></button>\r\n        <button class=\"ql-header\" value=\"2\"></button>\r\n      </span> -->\r\n\r\n        <p-divider layout=\"vertical\"></p-divider>\r\n\r\n        <span class=\"ql-formats border-round-md\">\r\n          <button class=\"ql-link\"></button>\r\n          <button class=\"ql-image\"></button>\r\n          <button class=\"ql-video\"></button>\r\n        </span>\r\n\r\n        <p-divider layout=\"vertical\"></p-divider>\r\n\r\n        <span class=\"ql-formats border-round-md\">\r\n          <button class=\"ql-list\" value=\"ordered\"></button>\r\n          <button class=\"ql-list\" value=\"bullet\"></button>\r\n          <select class=\"ql-align\"></select>\r\n        </span>\r\n        }\r\n      </div>\r\n    </div>\r\n  </div>\r\n  <div\r\n    style=\"height: 3px; border-top: none; border-bottom: none\"\r\n    [style.borderRight]=\"showHeader() ? '1px solid #e5e7eb' : 'none'\"\r\n    [style.borderLeft]=\"showHeader() ? '1px solid #e5e7eb' : 'none'\"\r\n  >\r\n    @if(isLoadingPdf()) {\r\n    <p-progressBar mode=\"indeterminate\" [style]=\"{ height: '3px' }\" />\r\n    }\r\n  </div>\r\n\r\n  <div class=\"flex flex-row flex-1 gap-0 overflow-auto\">\r\n    <div\r\n      id=\"kv-editor\"\r\n      class=\"overflow-auto flex-1 scrollstyle\"\r\n      [ngClass]=\"{\r\n        'error-border': hasControlError(),\r\n        'pointer-events-none opacity-60': isLoadingPdf()\r\n      }\"\r\n      [style.borderTop]=\"showHeader() ? 'none' : '1px solid #e5e7eb'\"\r\n      [style.borderRight]=\"enablePreviewMode() ? 'none' : '1px solid #e5e7eb'\"\r\n    ></div>\r\n\r\n    @if(enablePreviewMode()) {\r\n    <div class=\"flex flex-column flex-1\">\r\n      <div \r\n        class=\"flex align-items-center gap-2 px-3 py-2\" \r\n        [style.borderRight]=\"'1px solid #e5e7eb'\"\r\n        [style.borderLeft]=\"'1px solid #e5e7eb'\"\r\n      >\r\n        <span class=\"material-symbols-outlined text-blue-600 text-lg\">visibility</span>\r\n        <span class=\"font-semibold text-gray-700 text-sm\">Preview</span>\r\n      </div>\r\n      \r\n      <div\r\n        id=\"kv-editor-preview\"\r\n        class=\"overflow-auto flex-1 scrollstyle\"\r\n        [innerHTML]=\"getPreviewContent\"\r\n        [style.border]=\"'1px solid #e5e7eb'\"\r\n      ></div>\r\n    </div>\r\n    }\r\n  </div>\r\n\r\n</div>\r\n<kv-error [hasError]=\"hasControlError()\">{{ erroMessage() }}</kv-error>\r\n\r\n<!-- <link href=\"https://cdn.jsdelivr.net/npm/quill@2.0.2/dist/quill.snow.css\" rel=\"stylesheet\" /> -->\r\n<link href=\"https://fonts.googleapis.com/css?family=Roboto\" rel=\"stylesheet\" />\r\n<script src=\"https://cdn.jsdelivr.net/npm/quill@2.0.2/dist/quill.js\"></script>\r\n<script src=\"https://cdn.jsdelivr.net/npm/katex@0.16.9/dist/katex.min.js\"></script>\r\n\r\n<link\r\n  rel=\"stylesheet\"\r\n  href=\"https://cdn.jsdelivr.net/npm/quill@2.0.2/dist/quill.bubble.css\"\r\n/>\r\n<link\r\n  rel=\"stylesheet\"\r\n  href=\"https://cdnjs.cloudflare.com/ajax/libs/highlight.js/11.9.0/styles/atom-one-dark.min.css\"\r\n/>\r\n<link\r\n  rel=\"stylesheet\"\r\n  href=\"https://cdn.jsdelivr.net/npm/katex@0.16.9/dist/katex.min.css\"\r\n/>\r\n\r\n<p-overlayPanel #op styleClass=\"overflow-hidden\">\r\n  <div\r\n    class=\"grid m-0 gap-2 p-2 max-w-20rem overflow-y-auto scrollstyle\"\r\n    style=\"max-height: 16rem\"\r\n  >\r\n    @for(item of relatorios(); track $index) {\r\n    <div\r\n      class=\"col-12 cursor-pointer hover:bg-gray-100 transition-colors transition-duration-200 border-round-lg shadow-2 flex flex-column gap-2\"\r\n      (click)=\"setRelatorio(item)\"\r\n    >\r\n      <div\r\n        class=\"flex flex-row align-items-center gap-2 justify-content-between\"\r\n      >\r\n        <span class=\"text-sm font-medium w-full\">{{ item.label }}</span>\r\n\r\n        <kv-tags\r\n          class=\"transition-opacity transition-duration-300 {{\r\n            item?.id == idRelatorioSelected() ? 'opacity-100' : 'opacity-0'\r\n          }}\"\r\n          [tags]=\"[{ label: 'Selecionado', severity: 'primary' }]\"\r\n        ></kv-tags>\r\n      </div>\r\n      <span class=\"text-xs text-gray-500\">{{ item.descricao }}</span>\r\n    </div>\r\n    }\r\n  </div>\r\n</p-overlayPanel>\r\n\r\n<div class=\"kv-editor-container flex flex-column overflow-hidden relative\">\r\n  <div\r\n    #mentionAnchor\r\n    style=\"position: fixed; width: 1px; height: 1px; opacity: 0\"\r\n  ></div>\r\n</div>\r\n\r\n<p-overlayPanel\r\n  #opVariables\r\n  [appendTo]=\"'body'\"\r\n  (onHide)=\"closeVariablesPanel()\"\r\n>\r\n  <div\r\n    class=\"flex flex-column gap-1 p-1 overflow-y-auto scroll-virtual border-round-lg\"\r\n    style=\"max-height: 250px; min-width: 250px; background-color: #333333\"\r\n  >\r\n    @for(variable of filteredVariables(); track variable.id) {\r\n    <div\r\n      class=\"p-2 cursor-pointer transition-colors transition-duration-200 border-round-lg text-sm text-white option-dropdown\"\r\n      (click)=\"selectVariableFromPanel(variable)\"\r\n    >\r\n      {{ variable.descricao }} (\r\n      <span class=\"text-gray-400\">{{ variable.value }}</span> )\r\n    </div>\r\n    } @empty {\r\n    <div class=\"p-2 text-sm text-gray-500\">Nenhuma variável encontrada.</div>\r\n    }\r\n  </div>\r\n</p-overlayPanel>\r\n"]}
@@ -5807,6 +5807,7 @@ class KvEditorComponent extends BaseComponentInput {
5807
5807
  this.editorReadyResolver = resolve;
5808
5808
  });
5809
5809
  this.htmlDoEditor = '';
5810
+ this.quillDelta = Quill.import('delta');
5810
5811
  // Signal para espelhamento do conteúdo do editor
5811
5812
  this.htmlEspelho = signal('');
5812
5813
  this.previewContent = signal('');
@@ -5891,12 +5892,21 @@ class KvEditorComponent extends BaseComponentInput {
5891
5892
  theme: 'snow',
5892
5893
  modules: {
5893
5894
  toolbar: '#kv-editor-toolbar',
5895
+ clipboard: {
5896
+ matchVisual: false,
5897
+ matchers: [
5898
+ ['*', (node, delta) => {
5899
+ return delta;
5900
+ }]
5901
+ ]
5902
+ }
5894
5903
  },
5895
5904
  placeholder: this.label ? this.label : '',
5896
5905
  readOnly: this.readonly(),
5897
5906
  debug: this.debug,
5898
5907
  };
5899
5908
  this.quill = this.quillService.createQuillInstance('#kv-editor', config);
5909
+ this.configurarHtmlClipboard();
5900
5910
  this.setupQuillEvents();
5901
5911
  this.editorReadyResolver();
5902
5912
  this.initLoadComplete.set(true);
@@ -6029,6 +6039,39 @@ class KvEditorComponent extends BaseComponentInput {
6029
6039
  this.setRelatorioPorId(0);
6030
6040
  this.writeValue('');
6031
6041
  }
6042
+ configurarHtmlClipboard() {
6043
+ const editor = this.quill.root;
6044
+ editor.addEventListener('paste', (e) => {
6045
+ if (e.clipboardData) {
6046
+ e.preventDefault();
6047
+ e.stopPropagation();
6048
+ const html = e.clipboardData.getData('text/html');
6049
+ const text = e.clipboardData.getData('text/plain');
6050
+ const selection = this.quill.getSelection();
6051
+ if (!selection)
6052
+ return;
6053
+ if (html && html.trim()) {
6054
+ const startIndex = selection.index;
6055
+ //a partir daqui é para evitar que o copiar seja duplicado
6056
+ this.updatingEditor = true;
6057
+ this.quill.clipboard.dangerouslyPasteHTML(startIndex, html);
6058
+ setTimeout(() => {
6059
+ this.updatingEditor = false;
6060
+ const newLength = this.quill.getLength();
6061
+ this.quill.setSelection(newLength, 0);
6062
+ if (this.enablePreviewMode()) {
6063
+ this.atualizarPreview();
6064
+ }
6065
+ }, 10);
6066
+ }
6067
+ else if (text && text.trim()) {
6068
+ this.quill.insertText(selection.index, text, 'user');
6069
+ this.quill.setSelection(selection.index + text.length, 0);
6070
+ }
6071
+ }
6072
+ }, true);
6073
+ }
6074
+ //#region Métodos modo preview
6032
6075
  atualizarPreview() {
6033
6076
  if (!this.quill)
6034
6077
  return;
@@ -6113,41 +6156,30 @@ class KvEditorComponent extends BaseComponentInput {
6113
6156
  let conteudoProcessado = content;
6114
6157
  const variaveis = this.relatorio().variaveis;
6115
6158
  variaveis.forEach(variavel => {
6159
+ if (!this.isHtmlString(variavel.value)) {
6160
+ return;
6161
+ }
6116
6162
  const placeholderId = `{${variavel.id}}`;
6117
- //para buscar outros padrões de html pra variável
6118
- //obs: padronizar o uso de menções com spans data-mention
6163
+ if (conteudoProcessado.includes(placeholderId)) {
6164
+ conteudoProcessado = conteudoProcessado.split(placeholderId).join(variavel.value);
6165
+ }
6119
6166
  const patterns = [
6120
6167
  `<span[^>]*class="[^"]*mention[^"]*"[^>]*>\\s*${this.escapeRegex(variavel.descricao)}\\s*</span>`,
6121
6168
  `<span[^>]*data-mention[^>]*>\\s*${this.escapeRegex(variavel.descricao)}\\s*</span>`,
6122
6169
  `>\\s*${this.escapeRegex(variavel.descricao)}\\s*<`,
6123
6170
  `<[^>]+>\\s*${this.escapeRegex(variavel.descricao)}\\s*</[^>]+>`
6124
6171
  ];
6125
- if (conteudoProcessado.includes(placeholderId)) {
6126
- if (this.isHtmlString(variavel.value)) {
6127
- conteudoProcessado = conteudoProcessado.split(placeholderId).join(variavel.value);
6128
- }
6129
- }
6130
6172
  let substituido = false;
6131
6173
  for (const pattern of patterns) {
6132
6174
  const regexMention = new RegExp(pattern, 'gi');
6133
6175
  if (regexMention.test(conteudoProcessado)) {
6134
- if (this.isHtmlString(variavel.value)) {
6135
- const replacement = pattern.includes('>') && pattern.includes('<')
6136
- ? variavel.value
6137
- : `>${variavel.value}<`;
6138
- conteudoProcessado = conteudoProcessado.replace(regexMention, pattern.startsWith('>') ? `>${variavel.value}<` : variavel.value);
6139
- }
6140
- else {
6141
- conteudoProcessado = conteudoProcessado.replace(regexMention, pattern.startsWith('>') ? `>${variavel.value}<` : variavel.value);
6142
- }
6176
+ conteudoProcessado = conteudoProcessado.replace(regexMention, pattern.startsWith('>') ? `>${variavel.value}<` : variavel.value);
6143
6177
  substituido = true;
6144
6178
  break;
6145
6179
  }
6146
6180
  }
6147
6181
  if (!substituido && conteudoProcessado.includes(variavel.descricao)) {
6148
- if (this.isHtmlString(variavel.value)) {
6149
- conteudoProcessado = conteudoProcessado.split(variavel.descricao).join(variavel.value);
6150
- }
6182
+ conteudoProcessado = conteudoProcessado.split(variavel.descricao).join(variavel.value);
6151
6183
  }
6152
6184
  });
6153
6185
  return conteudoProcessado;