keevo-components 2.0.104 → 2.0.106
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 +1 -2
- package/esm2022/lib/components/kv-timeline/kv-timeline.component.mjs +3 -3
- package/fesm2022/keevo-components.mjs +2 -3
- package/fesm2022/keevo-components.mjs.map +1 -1
- package/lib/components/kv-buttons/kv-button-popup/kv-button-popup.component.d.ts +1 -1
- package/package.json +1 -1
|
@@ -56,7 +56,6 @@ export class KvEditorComponent extends BaseComponentInput {
|
|
|
56
56
|
this.idRelatorioInitial = model(0);
|
|
57
57
|
this.printButton = input(true);
|
|
58
58
|
this.labelEmptyDropdown = input('Selecione um relatório');
|
|
59
|
-
// @Input() instrucoesTemplate?: TemplateRef<any>;
|
|
60
59
|
this.instrucoesTemplate = input(undefined);
|
|
61
60
|
// Computed properties para relatórios
|
|
62
61
|
this.idRelatorioSelected = computed(() => this.relatorioService.getIdRelatorioSelected());
|
|
@@ -264,4 +263,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
|
|
|
264
263
|
type: ViewChild,
|
|
265
264
|
args: ['mentionAnchor']
|
|
266
265
|
}] } });
|
|
267
|
-
//# 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} from '@angular/core';\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(componentService: ComponentService) {\r\n    super(componentService);\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() readonly: boolean = false;\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  // 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  // Inputs para relatórios\r\n  relatorios = input<KvEditorRelatorio[]>([]);\r\n  idRelatorioInitial = model<number>(0);\r\n  printButton = input<boolean>(true);\r\n  labelEmptyDropdown = input<string>('Selecione um relatório');\r\n  // @Input() instrucoesTemplate?: TemplateRef<any>;\r\n  instrucoesTemplate = input<TemplateRef<any> | undefined>(undefined);\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: number): 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\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 (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    });\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    } 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","<div\r\n  class=\"kv-editor-container h-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=\"flex flex-column flex-initial\"\r\n  >\r\n    @if(relatorios().length > 0) {\r\n    <div class=\"flex flex-row justify-content-between\">\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() ? (relatorio()?.label || labelEmptyDropdown()) : 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=\"\r\n      height: 3px;\r\n      border-right: 1px solid #e5e7eb;\r\n      border-left: 1px solid #e5e7eb;\r\n      border-top: none;\r\n      border-bottom: none;\r\n    \"\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\r\n    id=\"kv-editor\"\r\n    class=\"overflow-auto w-full flex-1 scrollstyle\"\r\n    [ngClass]=\"{\r\n      'error-border': hasControlError(),\r\n      'pointer-events-none opacity-60': isLoadingPdf()\r\n    }\"\r\n    style=\"border-top: none\"\r\n  ></div>\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"]}
|
|
266
|
+
//# 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} from '@angular/core';\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(componentService: ComponentService) {\r\n    super(componentService);\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() readonly: boolean = false;\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  // 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  // Inputs para relatórios\r\n  relatorios = input<KvEditorRelatorio[]>([]);\r\n  idRelatorioInitial = model<number>(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\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: number): 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\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 (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    });\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    } 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","<div\r\n  class=\"kv-editor-container h-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=\"flex flex-column flex-initial\"\r\n  >\r\n    @if(relatorios().length > 0) {\r\n    <div class=\"flex flex-row justify-content-between\">\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() ? (relatorio()?.label || labelEmptyDropdown()) : 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=\"\r\n      height: 3px;\r\n      border-right: 1px solid #e5e7eb;\r\n      border-left: 1px solid #e5e7eb;\r\n      border-top: none;\r\n      border-bottom: none;\r\n    \"\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\r\n    id=\"kv-editor\"\r\n    class=\"overflow-auto w-full flex-1 scrollstyle\"\r\n    [ngClass]=\"{\r\n      'error-border': hasControlError(),\r\n      'pointer-events-none opacity-60': isLoadingPdf()\r\n    }\"\r\n    style=\"border-top: none\"\r\n  ></div>\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"]}
|
|
@@ -48,11 +48,11 @@ export class KvTimelineComponent {
|
|
|
48
48
|
this.layout = 'vertical';
|
|
49
49
|
}
|
|
50
50
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvTimelineComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
51
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.8", type: KvTimelineComponent, isStandalone: true, selector: "kv-timeline", inputs: { dataSource: { classPropertyName: "dataSource", publicName: "dataSource", isSignal: true, isRequired: false, transformFunction: null }, getSeverityFn: { classPropertyName: "getSeverityFn", publicName: "getSeverityFn", isSignal: false, isRequired: false, transformFunction: null }, getLastActiveCount: { classPropertyName: "getLastActiveCount", publicName: "getLastActiveCount", isSignal: false, isRequired: false, transformFunction: null }, lastOnly: { classPropertyName: "lastOnly", publicName: "lastOnly", isSignal: false, isRequired: false, transformFunction: null }, align: { classPropertyName: "align", publicName: "align", isSignal: false, isRequired: false, transformFunction: null }, layout: { classPropertyName: "layout", publicName: "layout", isSignal: false, isRequired: false, transformFunction: null }, oppositeTemplate: { classPropertyName: "oppositeTemplate", publicName: "oppositeTemplate", isSignal: false, isRequired: false, transformFunction: null }, contentTemplate: { classPropertyName: "contentTemplate", publicName: "contentTemplate", isSignal: false, isRequired: false, transformFunction: null } }, ngImport: i0, template: "<div class=\"card\">\r\n <p-timeline [value]=\"parsedEvents\" [align]=\"align\" [layout]=\"layout\" >\r\n\r\n <ng-template pTemplate=\"marker\" let-event>\r\n <span class=\"material-symbols-outlined\" [ngStyle]=\"{
|
|
51
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.8", type: KvTimelineComponent, isStandalone: true, selector: "kv-timeline", inputs: { dataSource: { classPropertyName: "dataSource", publicName: "dataSource", isSignal: true, isRequired: false, transformFunction: null }, getSeverityFn: { classPropertyName: "getSeverityFn", publicName: "getSeverityFn", isSignal: false, isRequired: false, transformFunction: null }, getLastActiveCount: { classPropertyName: "getLastActiveCount", publicName: "getLastActiveCount", isSignal: false, isRequired: false, transformFunction: null }, lastOnly: { classPropertyName: "lastOnly", publicName: "lastOnly", isSignal: false, isRequired: false, transformFunction: null }, align: { classPropertyName: "align", publicName: "align", isSignal: false, isRequired: false, transformFunction: null }, layout: { classPropertyName: "layout", publicName: "layout", isSignal: false, isRequired: false, transformFunction: null }, oppositeTemplate: { classPropertyName: "oppositeTemplate", publicName: "oppositeTemplate", isSignal: false, isRequired: false, transformFunction: null }, contentTemplate: { classPropertyName: "contentTemplate", publicName: "contentTemplate", isSignal: false, isRequired: false, transformFunction: null } }, ngImport: i0, template: "<div class=\"card\">\r\n <p-timeline [value]=\"parsedEvents\" [align]=\"align\" [layout]=\"layout\" >\r\n\r\n <ng-template pTemplate=\"marker\" let-event>\r\n <span class=\"material-symbols-outlined\" [ngStyle]=\"{\r\n color: event.timelineColor,\r\n fontSize: '1.6rem',\r\n 'font-variation-settings': '\\'FILL\\' 1, \\'wght\\' 400, \\'GRAD\\' 0, \\'opsz\\' 24'\r\n }\">\r\n {{ event.timelineIcon }}\r\n </span>\r\n </ng-template>\r\n\r\n <!-- TIMELINE OPPOSITE CONTENT -->\r\n <ng-template pTemplate=\"opposite\" let-event>\r\n <ng-container\r\n *ngTemplateOutlet=\"oppositeTemplate; context: { $implicit: event }\">\r\n </ng-container>\r\n </ng-template>\r\n\r\n <!-- TIMELINE CONTENT -->\r\n <ng-template pTemplate=\"content\" let-event>\r\n <ng-container\r\n *ngTemplateOutlet=\"contentTemplate; context: { $implicit: event }\">\r\n </ng-container>\r\n </ng-template>\r\n </p-timeline>\r\n</div>\r\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: TimelineModule }, { kind: "component", type: i2.Timeline, selector: "p-timeline", inputs: ["value", "style", "styleClass", "align", "layout"] }, { kind: "directive", type: i3.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }] }); }
|
|
52
52
|
}
|
|
53
53
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvTimelineComponent, decorators: [{
|
|
54
54
|
type: Component,
|
|
55
|
-
args: [{ selector: 'kv-timeline', standalone: true, imports: [CommonModule, TimelineModule], template: "<div class=\"card\">\r\n <p-timeline [value]=\"parsedEvents\" [align]=\"align\" [layout]=\"layout\" >\r\n\r\n <ng-template pTemplate=\"marker\" let-event>\r\n <span class=\"material-symbols-outlined\" [ngStyle]=\"{
|
|
55
|
+
args: [{ selector: 'kv-timeline', standalone: true, imports: [CommonModule, TimelineModule], template: "<div class=\"card\">\r\n <p-timeline [value]=\"parsedEvents\" [align]=\"align\" [layout]=\"layout\" >\r\n\r\n <ng-template pTemplate=\"marker\" let-event>\r\n <span class=\"material-symbols-outlined\" [ngStyle]=\"{\r\n color: event.timelineColor,\r\n fontSize: '1.6rem',\r\n 'font-variation-settings': '\\'FILL\\' 1, \\'wght\\' 400, \\'GRAD\\' 0, \\'opsz\\' 24'\r\n }\">\r\n {{ event.timelineIcon }}\r\n </span>\r\n </ng-template>\r\n\r\n <!-- TIMELINE OPPOSITE CONTENT -->\r\n <ng-template pTemplate=\"opposite\" let-event>\r\n <ng-container\r\n *ngTemplateOutlet=\"oppositeTemplate; context: { $implicit: event }\">\r\n </ng-container>\r\n </ng-template>\r\n\r\n <!-- TIMELINE CONTENT -->\r\n <ng-template pTemplate=\"content\" let-event>\r\n <ng-container\r\n *ngTemplateOutlet=\"contentTemplate; context: { $implicit: event }\">\r\n </ng-container>\r\n </ng-template>\r\n </p-timeline>\r\n</div>\r\n" }]
|
|
56
56
|
}], ctorParameters: () => [], propDecorators: { getSeverityFn: [{
|
|
57
57
|
type: Input
|
|
58
58
|
}], getLastActiveCount: [{
|
|
@@ -68,4 +68,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
|
|
|
68
68
|
}], contentTemplate: [{
|
|
69
69
|
type: Input
|
|
70
70
|
}] } });
|
|
71
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
71
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-timeline.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-timeline/kv-timeline.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-timeline/kv-timeline.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, ContentChild, Input, TemplateRef } from '@angular/core';\r\nimport { TimelineModule } from 'primeng/timeline';\r\nimport { input } from '@angular/core';\r\n\r\ntype TimelineSeverity = 'in_progress' | 'success' | 'cancelled' | 'error' | 'paused' | 'waiting';\r\n\r\nconst TIMELINE_SEVERITY_MAP: Record<TimelineSeverity, { timelineIcon: string; timelineColor: string }> = {\r\n  in_progress: { timelineIcon: 'motion_play', timelineColor: '#0091C2' },\r\n  success: { timelineIcon: 'check_circle', timelineColor: '#0A8765' },\r\n  cancelled: { timelineIcon: 'do_not_disturb_on', timelineColor: '#CBD5E1' },\r\n  error: { timelineIcon: 'motion_photos_paused', timelineColor: '#B91C1C' },\r\n  paused: { timelineIcon: 'pause_circle', timelineColor: '#E1963D' },\r\n  waiting: { timelineIcon: 'clock_loader_10', timelineColor: '#0A3A78' }\r\n};\r\n\r\n@Component({\r\n  selector: 'kv-timeline',\r\n  standalone: true,\r\n  imports: [CommonModule, TimelineModule],\r\n  templateUrl: './kv-timeline.component.html',\r\n  styleUrl: './kv-timeline.component.scss'\r\n})\r\nexport class KvTimelineComponent {\r\n    dataSource = input<any[]>();\r\n    \r\n    @Input() getSeverityFn!: (item: any) => TimelineSeverity;\r\n    @Input() getLastActiveCount?: (dataSource: any[]) => number;\r\n\r\n    @Input() lastOnly = false;\r\n    @Input() align!: string;\r\n    @Input() layout: 'horizontal' | 'vertical' = 'vertical';\r\n    @Input() oppositeTemplate!: TemplateRef<any>;\r\n    @Input() contentTemplate!: TemplateRef<any>;\r\n    \r\n    get parsedEvents() {\r\n      const original = this.dataSource() ?? [];\r\n\r\n      // Dinamicamente calcula quantos eventos terão severity real\r\n      const dynamicLastCount =\r\n      this.lastOnly && this.getLastActiveCount\r\n        ? this.getLastActiveCount(original)\r\n        : 1;\r\n\r\n      return original.map((item, index, array) => {\r\n        const realSeverity = this.getSeverityFn(item);\r\n\r\n        if (this.lastOnly) {\r\n          const dynamicLastCount =\r\n            this.getLastActiveCount?.(original) ?? 1;\r\n\r\n          const reversed = [...array].reverse();\r\n          const indices = reversed\r\n            .map((e, i) => ({\r\n              index: array.length - 1 - i,\r\n              severity: this.getSeverityFn(e)\r\n            }))\r\n            .filter(e => e.severity !== 'success')\r\n            .slice(0, dynamicLastCount)\r\n            .map(e => e.index);\r\n\r\n          const severity = indices.includes(index) ? realSeverity : 'success';\r\n          const { timelineIcon, timelineColor } = TIMELINE_SEVERITY_MAP[severity];\r\n\r\n          return { ...item, severity, timelineIcon, timelineColor };\r\n        }\r\n\r\n        const { timelineIcon, timelineColor } = TIMELINE_SEVERITY_MAP[realSeverity];\r\n        return { ...item, severity: realSeverity, timelineIcon, timelineColor };\r\n      });\r\n    }\r\n    \r\n    constructor() {\r\n      \r\n    }\r\n\r\n}\r\n","<div class=\"card\">\r\n    <p-timeline [value]=\"parsedEvents\" [align]=\"align\" [layout]=\"layout\" >\r\n\r\n       <ng-template pTemplate=\"marker\" let-event>\r\n        <span class=\"material-symbols-outlined\" [ngStyle]=\"{\r\n            color: event.timelineColor,\r\n            fontSize: '1.6rem',\r\n            'font-variation-settings': '\\'FILL\\' 1, \\'wght\\' 400, \\'GRAD\\' 0, \\'opsz\\' 24'\r\n        }\">\r\n            {{ event.timelineIcon }}\r\n        </span>\r\n        </ng-template>\r\n\r\n        <!-- TIMELINE OPPOSITE CONTENT -->\r\n        <ng-template pTemplate=\"opposite\" let-event>\r\n            <ng-container\r\n              *ngTemplateOutlet=\"oppositeTemplate; context: { $implicit: event }\">\r\n            </ng-container>\r\n        </ng-template>\r\n\r\n        <!-- TIMELINE CONTENT -->\r\n        <ng-template pTemplate=\"content\" let-event>\r\n            <ng-container\r\n              *ngTemplateOutlet=\"contentTemplate; context: { $implicit: event }\">\r\n            </ng-container>\r\n        </ng-template>\r\n    </p-timeline>\r\n</div>\r\n"]}
|
|
@@ -5770,7 +5770,6 @@ class KvEditorComponent extends BaseComponentInput {
|
|
|
5770
5770
|
this.idRelatorioInitial = model(0);
|
|
5771
5771
|
this.printButton = input(true);
|
|
5772
5772
|
this.labelEmptyDropdown = input('Selecione um relatório');
|
|
5773
|
-
// @Input() instrucoesTemplate?: TemplateRef<any>;
|
|
5774
5773
|
this.instrucoesTemplate = input(undefined);
|
|
5775
5774
|
// Computed properties para relatórios
|
|
5776
5775
|
this.idRelatorioSelected = computed(() => this.relatorioService.getIdRelatorioSelected());
|
|
@@ -11942,11 +11941,11 @@ class KvTimelineComponent {
|
|
|
11942
11941
|
this.layout = 'vertical';
|
|
11943
11942
|
}
|
|
11944
11943
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvTimelineComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
11945
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.8", type: KvTimelineComponent, isStandalone: true, selector: "kv-timeline", inputs: { dataSource: { classPropertyName: "dataSource", publicName: "dataSource", isSignal: true, isRequired: false, transformFunction: null }, getSeverityFn: { classPropertyName: "getSeverityFn", publicName: "getSeverityFn", isSignal: false, isRequired: false, transformFunction: null }, getLastActiveCount: { classPropertyName: "getLastActiveCount", publicName: "getLastActiveCount", isSignal: false, isRequired: false, transformFunction: null }, lastOnly: { classPropertyName: "lastOnly", publicName: "lastOnly", isSignal: false, isRequired: false, transformFunction: null }, align: { classPropertyName: "align", publicName: "align", isSignal: false, isRequired: false, transformFunction: null }, layout: { classPropertyName: "layout", publicName: "layout", isSignal: false, isRequired: false, transformFunction: null }, oppositeTemplate: { classPropertyName: "oppositeTemplate", publicName: "oppositeTemplate", isSignal: false, isRequired: false, transformFunction: null }, contentTemplate: { classPropertyName: "contentTemplate", publicName: "contentTemplate", isSignal: false, isRequired: false, transformFunction: null } }, ngImport: i0, template: "<div class=\"card\">\r\n <p-timeline [value]=\"parsedEvents\" [align]=\"align\" [layout]=\"layout\" >\r\n\r\n <ng-template pTemplate=\"marker\" let-event>\r\n <span class=\"material-symbols-outlined\" [ngStyle]=\"{
|
|
11944
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.8", type: KvTimelineComponent, isStandalone: true, selector: "kv-timeline", inputs: { dataSource: { classPropertyName: "dataSource", publicName: "dataSource", isSignal: true, isRequired: false, transformFunction: null }, getSeverityFn: { classPropertyName: "getSeverityFn", publicName: "getSeverityFn", isSignal: false, isRequired: false, transformFunction: null }, getLastActiveCount: { classPropertyName: "getLastActiveCount", publicName: "getLastActiveCount", isSignal: false, isRequired: false, transformFunction: null }, lastOnly: { classPropertyName: "lastOnly", publicName: "lastOnly", isSignal: false, isRequired: false, transformFunction: null }, align: { classPropertyName: "align", publicName: "align", isSignal: false, isRequired: false, transformFunction: null }, layout: { classPropertyName: "layout", publicName: "layout", isSignal: false, isRequired: false, transformFunction: null }, oppositeTemplate: { classPropertyName: "oppositeTemplate", publicName: "oppositeTemplate", isSignal: false, isRequired: false, transformFunction: null }, contentTemplate: { classPropertyName: "contentTemplate", publicName: "contentTemplate", isSignal: false, isRequired: false, transformFunction: null } }, ngImport: i0, template: "<div class=\"card\">\r\n <p-timeline [value]=\"parsedEvents\" [align]=\"align\" [layout]=\"layout\" >\r\n\r\n <ng-template pTemplate=\"marker\" let-event>\r\n <span class=\"material-symbols-outlined\" [ngStyle]=\"{\r\n color: event.timelineColor,\r\n fontSize: '1.6rem',\r\n 'font-variation-settings': '\\'FILL\\' 1, \\'wght\\' 400, \\'GRAD\\' 0, \\'opsz\\' 24'\r\n }\">\r\n {{ event.timelineIcon }}\r\n </span>\r\n </ng-template>\r\n\r\n <!-- TIMELINE OPPOSITE CONTENT -->\r\n <ng-template pTemplate=\"opposite\" let-event>\r\n <ng-container\r\n *ngTemplateOutlet=\"oppositeTemplate; context: { $implicit: event }\">\r\n </ng-container>\r\n </ng-template>\r\n\r\n <!-- TIMELINE CONTENT -->\r\n <ng-template pTemplate=\"content\" let-event>\r\n <ng-container\r\n *ngTemplateOutlet=\"contentTemplate; context: { $implicit: event }\">\r\n </ng-container>\r\n </ng-template>\r\n </p-timeline>\r\n</div>\r\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: TimelineModule }, { kind: "component", type: i2$6.Timeline, selector: "p-timeline", inputs: ["value", "style", "styleClass", "align", "layout"] }, { kind: "directive", type: i1$2.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }] }); }
|
|
11946
11945
|
}
|
|
11947
11946
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvTimelineComponent, decorators: [{
|
|
11948
11947
|
type: Component,
|
|
11949
|
-
args: [{ selector: 'kv-timeline', standalone: true, imports: [CommonModule, TimelineModule], template: "<div class=\"card\">\r\n <p-timeline [value]=\"parsedEvents\" [align]=\"align\" [layout]=\"layout\" >\r\n\r\n <ng-template pTemplate=\"marker\" let-event>\r\n <span class=\"material-symbols-outlined\" [ngStyle]=\"{
|
|
11948
|
+
args: [{ selector: 'kv-timeline', standalone: true, imports: [CommonModule, TimelineModule], template: "<div class=\"card\">\r\n <p-timeline [value]=\"parsedEvents\" [align]=\"align\" [layout]=\"layout\" >\r\n\r\n <ng-template pTemplate=\"marker\" let-event>\r\n <span class=\"material-symbols-outlined\" [ngStyle]=\"{\r\n color: event.timelineColor,\r\n fontSize: '1.6rem',\r\n 'font-variation-settings': '\\'FILL\\' 1, \\'wght\\' 400, \\'GRAD\\' 0, \\'opsz\\' 24'\r\n }\">\r\n {{ event.timelineIcon }}\r\n </span>\r\n </ng-template>\r\n\r\n <!-- TIMELINE OPPOSITE CONTENT -->\r\n <ng-template pTemplate=\"opposite\" let-event>\r\n <ng-container\r\n *ngTemplateOutlet=\"oppositeTemplate; context: { $implicit: event }\">\r\n </ng-container>\r\n </ng-template>\r\n\r\n <!-- TIMELINE CONTENT -->\r\n <ng-template pTemplate=\"content\" let-event>\r\n <ng-container\r\n *ngTemplateOutlet=\"contentTemplate; context: { $implicit: event }\">\r\n </ng-container>\r\n </ng-template>\r\n </p-timeline>\r\n</div>\r\n" }]
|
|
11950
11949
|
}], ctorParameters: () => [], propDecorators: { getSeverityFn: [{
|
|
11951
11950
|
type: Input
|
|
11952
11951
|
}], getLastActiveCount: [{
|