keevo-components 2.0.199 → 2.0.200
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/esm2022/lib/components/kv-inputs/kv-editor/kv-editor.component.mjs +62 -1
- package/fesm2022/keevo-components.mjs +61 -0
- package/fesm2022/keevo-components.mjs.map +1 -1
- package/lib/components/kv-inputs/kv-editor/kv-editor.component.d.ts +3 -0
- package/lib/components/kv-table-viewer/kv-table-viewer.component.d.ts +1 -1
- package/package.json +1 -1
|
@@ -320,6 +320,7 @@ export class KvEditorComponent extends BaseComponentInput {
|
|
|
320
320
|
while ((match = styleRegex.exec(content)) !== null) {
|
|
321
321
|
styles.push(match[1]);
|
|
322
322
|
}
|
|
323
|
+
conteudoProcessado = this.processarVariaveisComHtml(conteudoProcessado);
|
|
323
324
|
conteudoProcessado = this.manterQuebrasLinhaHtml(conteudoProcessado);
|
|
324
325
|
let conteudoFinal = '<div class="kv-editor-preview-wrapper">';
|
|
325
326
|
if (styles.length > 0) {
|
|
@@ -332,6 +333,66 @@ export class KvEditorComponent extends BaseComponentInput {
|
|
|
332
333
|
manterQuebrasLinhaHtml(html) {
|
|
333
334
|
return html;
|
|
334
335
|
}
|
|
336
|
+
isHtmlString(str) {
|
|
337
|
+
if (!str || typeof str !== 'string')
|
|
338
|
+
return false;
|
|
339
|
+
const trimmed = str.trim();
|
|
340
|
+
if (!trimmed.startsWith('<') || !trimmed.endsWith('>'))
|
|
341
|
+
return false;
|
|
342
|
+
const htmlTagRegex = /<\/?[a-z][\s\S]*?>/i;
|
|
343
|
+
const hasOpeningTag = /<[a-z][\s\S]*?>/i.test(trimmed);
|
|
344
|
+
const hasClosingTag = /<\/[a-z][\s\S]*?>/i.test(trimmed);
|
|
345
|
+
return htmlTagRegex.test(trimmed) && (hasOpeningTag || hasClosingTag);
|
|
346
|
+
}
|
|
347
|
+
processarVariaveisComHtml(content) {
|
|
348
|
+
if (!this.relatorio() || !this.relatorio().variaveis) {
|
|
349
|
+
return content;
|
|
350
|
+
}
|
|
351
|
+
let conteudoProcessado = content;
|
|
352
|
+
const variaveis = this.relatorio().variaveis;
|
|
353
|
+
variaveis.forEach(variavel => {
|
|
354
|
+
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
|
|
357
|
+
const patterns = [
|
|
358
|
+
`<span[^>]*class="[^"]*mention[^"]*"[^>]*>\\s*${this.escapeRegex(variavel.descricao)}\\s*</span>`,
|
|
359
|
+
`<span[^>]*data-mention[^>]*>\\s*${this.escapeRegex(variavel.descricao)}\\s*</span>`,
|
|
360
|
+
`>\\s*${this.escapeRegex(variavel.descricao)}\\s*<`,
|
|
361
|
+
`<[^>]+>\\s*${this.escapeRegex(variavel.descricao)}\\s*</[^>]+>`
|
|
362
|
+
];
|
|
363
|
+
if (conteudoProcessado.includes(placeholderId)) {
|
|
364
|
+
if (this.isHtmlString(variavel.value)) {
|
|
365
|
+
conteudoProcessado = conteudoProcessado.split(placeholderId).join(variavel.value);
|
|
366
|
+
}
|
|
367
|
+
}
|
|
368
|
+
let substituido = false;
|
|
369
|
+
for (const pattern of patterns) {
|
|
370
|
+
const regexMention = new RegExp(pattern, 'gi');
|
|
371
|
+
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
|
+
}
|
|
381
|
+
substituido = true;
|
|
382
|
+
break;
|
|
383
|
+
}
|
|
384
|
+
}
|
|
385
|
+
if (!substituido && conteudoProcessado.includes(variavel.descricao)) {
|
|
386
|
+
if (this.isHtmlString(variavel.value)) {
|
|
387
|
+
conteudoProcessado = conteudoProcessado.split(variavel.descricao).join(variavel.value);
|
|
388
|
+
}
|
|
389
|
+
}
|
|
390
|
+
});
|
|
391
|
+
return conteudoProcessado;
|
|
392
|
+
}
|
|
393
|
+
escapeRegex(str) {
|
|
394
|
+
return str.replace(/[.*+?^${}()|[\]\\]/g, '\\$&');
|
|
395
|
+
}
|
|
335
396
|
get getPreviewContent() {
|
|
336
397
|
return this.previewContent();
|
|
337
398
|
}
|
|
@@ -362,4 +423,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
|
|
|
362
423
|
type: ViewChild,
|
|
363
424
|
args: ['mentionAnchor']
|
|
364
425
|
}] } });
|
|
365
|
-
//# 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.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  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"]}
|
|
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"]}
|
|
@@ -6082,6 +6082,7 @@ class KvEditorComponent extends BaseComponentInput {
|
|
|
6082
6082
|
while ((match = styleRegex.exec(content)) !== null) {
|
|
6083
6083
|
styles.push(match[1]);
|
|
6084
6084
|
}
|
|
6085
|
+
conteudoProcessado = this.processarVariaveisComHtml(conteudoProcessado);
|
|
6085
6086
|
conteudoProcessado = this.manterQuebrasLinhaHtml(conteudoProcessado);
|
|
6086
6087
|
let conteudoFinal = '<div class="kv-editor-preview-wrapper">';
|
|
6087
6088
|
if (styles.length > 0) {
|
|
@@ -6094,6 +6095,66 @@ class KvEditorComponent extends BaseComponentInput {
|
|
|
6094
6095
|
manterQuebrasLinhaHtml(html) {
|
|
6095
6096
|
return html;
|
|
6096
6097
|
}
|
|
6098
|
+
isHtmlString(str) {
|
|
6099
|
+
if (!str || typeof str !== 'string')
|
|
6100
|
+
return false;
|
|
6101
|
+
const trimmed = str.trim();
|
|
6102
|
+
if (!trimmed.startsWith('<') || !trimmed.endsWith('>'))
|
|
6103
|
+
return false;
|
|
6104
|
+
const htmlTagRegex = /<\/?[a-z][\s\S]*?>/i;
|
|
6105
|
+
const hasOpeningTag = /<[a-z][\s\S]*?>/i.test(trimmed);
|
|
6106
|
+
const hasClosingTag = /<\/[a-z][\s\S]*?>/i.test(trimmed);
|
|
6107
|
+
return htmlTagRegex.test(trimmed) && (hasOpeningTag || hasClosingTag);
|
|
6108
|
+
}
|
|
6109
|
+
processarVariaveisComHtml(content) {
|
|
6110
|
+
if (!this.relatorio() || !this.relatorio().variaveis) {
|
|
6111
|
+
return content;
|
|
6112
|
+
}
|
|
6113
|
+
let conteudoProcessado = content;
|
|
6114
|
+
const variaveis = this.relatorio().variaveis;
|
|
6115
|
+
variaveis.forEach(variavel => {
|
|
6116
|
+
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
|
|
6119
|
+
const patterns = [
|
|
6120
|
+
`<span[^>]*class="[^"]*mention[^"]*"[^>]*>\\s*${this.escapeRegex(variavel.descricao)}\\s*</span>`,
|
|
6121
|
+
`<span[^>]*data-mention[^>]*>\\s*${this.escapeRegex(variavel.descricao)}\\s*</span>`,
|
|
6122
|
+
`>\\s*${this.escapeRegex(variavel.descricao)}\\s*<`,
|
|
6123
|
+
`<[^>]+>\\s*${this.escapeRegex(variavel.descricao)}\\s*</[^>]+>`
|
|
6124
|
+
];
|
|
6125
|
+
if (conteudoProcessado.includes(placeholderId)) {
|
|
6126
|
+
if (this.isHtmlString(variavel.value)) {
|
|
6127
|
+
conteudoProcessado = conteudoProcessado.split(placeholderId).join(variavel.value);
|
|
6128
|
+
}
|
|
6129
|
+
}
|
|
6130
|
+
let substituido = false;
|
|
6131
|
+
for (const pattern of patterns) {
|
|
6132
|
+
const regexMention = new RegExp(pattern, 'gi');
|
|
6133
|
+
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
|
+
}
|
|
6143
|
+
substituido = true;
|
|
6144
|
+
break;
|
|
6145
|
+
}
|
|
6146
|
+
}
|
|
6147
|
+
if (!substituido && conteudoProcessado.includes(variavel.descricao)) {
|
|
6148
|
+
if (this.isHtmlString(variavel.value)) {
|
|
6149
|
+
conteudoProcessado = conteudoProcessado.split(variavel.descricao).join(variavel.value);
|
|
6150
|
+
}
|
|
6151
|
+
}
|
|
6152
|
+
});
|
|
6153
|
+
return conteudoProcessado;
|
|
6154
|
+
}
|
|
6155
|
+
escapeRegex(str) {
|
|
6156
|
+
return str.replace(/[.*+?^${}()|[\]\\]/g, '\\$&');
|
|
6157
|
+
}
|
|
6097
6158
|
get getPreviewContent() {
|
|
6098
6159
|
return this.previewContent();
|
|
6099
6160
|
}
|