keevo-components 2.0.22 → 2.0.23
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.
|
@@ -52,6 +52,7 @@ export class KvContentViewerComponent {
|
|
|
52
52
|
}
|
|
53
53
|
else {
|
|
54
54
|
arquivo[this.keyVisualizado] = true;
|
|
55
|
+
this.contentViewer = true;
|
|
55
56
|
this.arquivoPreview.set(arquivo);
|
|
56
57
|
}
|
|
57
58
|
this.onSelectFile.emit(arquivo);
|
|
@@ -151,4 +152,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
|
|
|
151
152
|
}], onSelectFile: [{
|
|
152
153
|
type: Output
|
|
153
154
|
}] } });
|
|
154
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-content-viewer.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-content-viewer/kv-content-viewer.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-content-viewer/kv-content-viewer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, EventEmitter, input, Input, InputSignal, Output, signal, TemplateRef } from '@angular/core';\r\nimport { SafeHtml } from '@angular/platform-browser';\r\n\r\n@Component({\r\n  selector: 'kv-content-viewer',\r\n  templateUrl: './kv-content-viewer.component.html',\r\n  styleUrl: './kv-content-viewer.component.scss'\r\n})\r\nexport class KvContentViewerComponent {\r\n\r\n\r\n\r\n  // #region Signals\r\n dataSource: InputSignal<any[]> = input<any[]>([]);\r\n paginaInicial = signal<number>(1);\r\n arquivo = input<string | undefined>(undefined);\r\n arquivoPreview = signal<any>(undefined);\r\n nomeArquivo = signal<string>('');\r\n type = input<string | undefined>(undefined);\r\n blob = input<Blob>('' as any);\r\n idarquivo = signal<number | undefined>(undefined);\r\n ekpContent = input<SafeHtml | undefined>(undefined);\r\n totalItensCarregado = computed(\r\n  () => this.dataSource()?.length || 0\r\n);\r\n// #endregion\r\n\r\n// #region Properties\r\nempresaSelecionada!: any;\r\nidtipodocumento!: number[];\r\n@Input() extencaoDocumento!: string;\r\npreviewOn: boolean = false;\r\nselectedItem: any = {};\r\n@Input() totalRecords: number = 0;\r\nisLoading: boolean = false;\r\ndisplaySidebar: boolean = false;\r\nisSelected: boolean = false;\r\n@Input() visualizadorDocumentos: boolean = false;\r\n@Input() cardTemplate!: TemplateRef<any>;\r\n@Input() contentTemplate!: TemplateRef<any>;\r\n@Input() noDocumentSelectedTemplate!: TemplateRef<any>;\r\n@Input() noDocumentListTemplate!: TemplateRef<any>;\r\n@Input() buttonTemplate!: TemplateRef<any>;\r\n@Input() indvisualizado: boolean = false;\r\n@Input() btnTelaCheia: boolean = false;\r\n@Input() isLoadingSkeleton: boolean = false;\r\n@Input() borderCardNaoVisualizado: boolean = true;\r\ncontentViewer: boolean = false;\r\nkeyVisualizado: string = 'indvisualizado'; \r\n\r\ntodayDate(): string {\r\n  const today = new Date();\r\n  return today.toLocaleDateString('pt-BR', { day: '2-digit', month: '2-digit', year: 'numeric' });\r\n}\r\n// #endregion\r\n\r\n// #region Outputs\r\n@Output() onScrollHandler: EventEmitter<any> = new EventEmitter();\r\n@Output() onSelectFile: EventEmitter<any> = new EventEmitter();\r\n// #endregion\r\n\r\ntrackByFn(index: number, item: any): any {\r\n  return item.idarquivo; \r\n}\r\n\r\nisVisualizado(option: any): boolean {\r\n  return option[this.keyVisualizado] || false;\r\n}\r\n\r\nvisualizarPreview(arquivo: any, buttonTemplate?: boolean): void {\r\n  \r\n  if (buttonTemplate) {\r\n    this.contentViewer = true;\r\n  } else {\r\n    arquivo[this.keyVisualizado] = true;\r\n    this.arquivoPreview.set(arquivo);\r\n  }\r\n\r\n  this.onSelectFile.emit(arquivo);\r\n  \r\n}\r\n\r\nalternarTelaCheia() {\r\n  const element = document.getElementById('fullscreenDiv');\r\n  const button = document.getElementById('fullscreenBtn');\r\n\r\n  // Verifica se os elementos existem\r\n  if (element && button) {\r\n    if (!document.fullscreenElement) {\r\n      // Expandir para tela cheia\r\n      if (element.requestFullscreen) {\r\n        element.requestFullscreen();\r\n      } else if ((element as any).mozRequestFullScreen) { // Para Firefox\r\n        (element as any).mozRequestFullScreen();\r\n      } else if ((element as any).webkitRequestFullscreen) { // Para Chrome, Safari e Opera\r\n        (element as any).webkitRequestFullscreen();\r\n      } else if ((element as any).msRequestFullscreen) { // Para IE/Edge\r\n        (element as any).msRequestFullscreen();\r\n      }\r\n      button.textContent = 'close_fullscreen';\r\n    } else {\r\n      // Sair da tela cheia\r\n      if (document.exitFullscreen) {\r\n        document.exitFullscreen();\r\n      } else if ((document as any).mozCancelFullScreen) { // Para Firefox\r\n        (document as any).mozCancelFullScreen();\r\n      } else if ((document as any).webkitExitFullscreen) { // Para Chrome, Safari e Opera\r\n        (document as any).webkitExitFullscreen();\r\n      } else if ((document as any).msExitFullscreen) { // Para IE/Edge\r\n        (document as any).msExitFullscreen();\r\n      }\r\n      button.textContent = 'open_in_full';\r\n    }\r\n  }\r\n}\r\n\r\nngOnInit(): void {\r\n  document.addEventListener('fullscreenchange', () => {\r\n    const button = document.getElementById('fullscreenBtn');\r\n    \r\n    if (button) {\r\n      if (!document.fullscreenElement) {\r\n        button.textContent = 'open_in_full';\r\n      } else {\r\n        button.textContent = 'close_fullscreen';\r\n      }\r\n    }\r\n  });\r\n}\r\n\r\nscrollHandler($event: Event) {\r\n  const element = $event.target as HTMLElement;\r\n\r\n  //se o escroll chegar até o final\r\n  if (element.scrollHeight - element.scrollTop === element.clientHeight) {\r\n    // this.buscarProximosDocumentos();\r\n    this.onScrollHandler.emit($event);\r\n  }\r\n}\r\n\r\n}\r\n","<div class=\"flex flex-column md:flex-row gap-2 mt-3 custom-max-height\" style=\"height: 100%;\">\r\n  <!-- Lista de documentos -->\r\n  <div\r\n    class=\"card-perfil col-12 md:col-4 lg:col-3\"\r\n    (scroll)=\"scrollHandler($event)\"\r\n    [ngClass]=\"{\r\n      'overflow-y-scroll': dataSource().length > 0,\r\n      'overflow-y-hidden': dataSource().length === 0\r\n    }\"\r\n    style=\"position: relative; height: 100%; min-height: 15rem;\"\r\n  >\r\n    <div *ngIf=\"dataSource().length > 0; else emptyDocumentList\" class=\"col-12\">\r\n      <!-- Lista de cards -->\r\n      <div\r\n        *ngFor=\"let option of dataSource(); trackBy: trackByFn\"\r\n        class=\"card-normal outline-none border-round-xl w-full p-2 m-1 grid p-fluid flex flex-row flex-nowrap align-items-center justify-content-center cursor-pointer\"\r\n        (click)=\"visualizarPreview(option)\"\r\n        [ngClass]=\"{\r\n    'card-naoVisualizado': !isVisualizado(option) && borderCardNaoVisualizado,\r\n    'card-selected': option === arquivoPreview(),\r\n    'card-normal': option !== arquivoPreview(),\r\n   }\"\r\n      >\r\n        <div class=\"flex flex-grow-1 ml-2 flex-column gap-1 m-0 p-0 overflow-hidden text-overflow-ellipsis \" style=\"max-width: 100%;\">\r\n          <ng-container *ngIf=\"cardTemplate; else defaultTemplate\">\r\n            <ng-container\r\n              *ngTemplateOutlet=\"cardTemplate; context: { $implicit: option }\"\r\n            ></ng-container>\r\n          </ng-container>\r\n        </div>\r\n        <ng-template #defaultTemplate>\r\n          <div class=\"card-common-style default-card\">\r\n            <h1 class=\"font-bold text-base p-0 m-0\">Bem-vindo!</h1>\r\n            <p class=\"text-sm mt-2\">\r\n              Kv-file-preview aguardando um template... \r\n            </p>\r\n            <p class=\"font-bold text-sm p-0 m-0\">Data: {{ todayDate() }}</p>\r\n          </div>\r\n        </ng-template>\r\n      </div>\r\n\r\n    </div>\r\n\r\n    <ng-template #emptyDocumentList>\r\n\r\n      @if(isLoadingSkeleton){\r\n        <p-skeleton *ngFor=\"let i of [1, 2, 3, 4, 5, 6, 7, 8, 9]\"></p-skeleton>\r\n      }\r\n\r\n      @if(!noDocumentListTemplate) {\r\n      <div class=\"text-center text-gray-600 mt-4 m-3\" style=\"height: 100%\">\r\n        <div class=\" flex align-items-center gap-1\">\r\n          <span class=\"material-symbols-outlined\"> inbox </span>\r\n          <p>Nenhum documento disponível.</p>\r\n        </div>\r\n      </div>\r\n      } @else {\r\n      <div class=\"text-center mt-4 m-3\" style=\"height: 100%\">\r\n        <ng-container *ngTemplateOutlet=\"noDocumentListTemplate\"></ng-container>\r\n      </div>\r\n      }\r\n    </ng-template>\r\n\r\n    <!-- Contador de documentos - Fixo na parte inferior -->\r\n    <div\r\n      class=\"sticky-counter flex flex-row flex-1 px-2 justify-content-center p-2\"\r\n      style=\"position: sticky; bottom: -10px; background-color: white\"\r\n    >\r\n      <span>{{ totalItensCarregado() }} de {{ totalRecords }}</span>\r\n    </div>\r\n  </div>\r\n\r\n  <!-- Visualizador -->\r\n<div id=\"fullscreenDiv\" class=\"card-perfil col-12 md:col-8 lg:col-9\" style=\"position: relative; height: 100%;\"\r\n  [ngStyle]=\"{\r\n    'overflow-y': arquivoPreview() ? 'auto' : 'hidden'\r\n  }\">\r\n  @if(btnTelaCheia && !buttonTemplate)\r\n  {\r\n    <div class=\"grid\">\r\n      <div class=\"col\"></div>\r\n      <span id=\"fullscreenBtn\" (click)=\"alternarTelaCheia()\" class=\"material-symbols-outlined p-2 text-xl cursor-pointer\">\r\n        open_in_full\r\n      </span>\r\n    </div>\r\n  } @if(!btnTelaCheia && buttonTemplate && !contentViewer)\r\n  {\r\n    <div class=\"grid\">\r\n      <div class=\"col\"></div>\r\n      <span class=\"p-3\">\r\n        <span (click)=\"visualizarPreview(null, true)\">\r\n        <ng-container *ngTemplateOutlet=\"buttonTemplate\"></ng-container>\r\n        </span>\r\n      </span>\r\n    </div>\r\n  } @if(btnTelaCheia && buttonTemplate) {\r\n    <div class=\"grid\">\r\n      @if(!contentViewer) {\r\n        <span class=\"p-3\">\r\n          <span (click)=\"visualizarPreview(null, true)\">\r\n            <ng-container *ngTemplateOutlet=\"buttonTemplate\"></ng-container>\r\n          </span>\r\n        </span>\r\n      }\r\n      <div class=\"col\"></div>\r\n      <span id=\"fullscreenBtn\" (click)=\"alternarTelaCheia()\" class=\"material-symbols-outlined p-2 text-xl cursor-pointer\">\r\n        open_in_full\r\n      </span>\r\n    </div>\r\n  }\r\n  @if(visualizadorDocumentos) {\r\n    <ng-container *ngIf=\"arquivo(); else noDocumentSelected\">\r\n      @if(isLoading) {\r\n      <ngx-loading\r\n        [show]=\"isLoading\"\r\n        [config]=\"{ backdropBorderRadius: '3px', fullScreenBackdrop: false }\"\r\n      ></ngx-loading>\r\n      }\r\n      <kv-file-viewer-novo\r\n      *ngIf=\"extencaoDocumento !== 'ekp'\"\r\n        [arquivo]=\"arquivo()!\"\r\n        [type]=\"type()!\"\r\n        [blob]=\"blob()!\"\r\n        [width]=\"'100%'\" \r\n        [height]=\"'100%'\"\r\n        class=\"file-viewer\"\r\n        style=\"max-height: 100%;\"\r\n      >\r\n      </kv-file-viewer-novo>\r\n\r\n      <div\r\n        id=\"html-content\"\r\n        [innerHTML]=\"ekpContent()\"\r\n        *ngIf=\"extencaoDocumento === 'ekp'\"\r\n        class=\"ekp-content\"\r\n        style=\"overflow-y: auto; max-height: 100%;\"\r\n      ></div>\r\n    </ng-container>\r\n  } @else {\r\n    <ng-container *ngIf=\"arquivoPreview() || contentViewer; else noDocumentSelected\">\r\n      <ng-container\r\n        *ngTemplateOutlet=\"\r\n          contentTemplate;\r\n          context: { $implicit: arquivoPreview() }\r\n        \"\r\n        style=\"overflow-y: auto; max-height: 100%;\"\r\n      ></ng-container>\r\n    </ng-container>\r\n  }\r\n  <ng-template #noDocumentSelected>\r\n    @if(!noDocumentSelectedTemplate) {\r\n    <div\r\n      class=\"no-document-message flex flex-column align-items-center justify-content-center\"\r\n      style=\"height: 100%; overflow-y: auto;\"\r\n    >\r\n      <p class=\"text-center text-gray-500\">\r\n        Selecione um arquivo para visualização\r\n      </p>\r\n      <img\r\n        [src]=\"\r\n          'https://work-assets.keevo.com.br/img/Digital_personal_files-pana_3.png'\r\n        \"\r\n        style=\"max-height: 50%; margin-top: 2rem;\"\r\n        alt=\"\"\r\n      />\r\n    </div>\r\n    } @else {\r\n    <ng-container\r\n      *ngTemplateOutlet=\"noDocumentSelectedTemplate\"\r\n    ></ng-container>\r\n    }\r\n  </ng-template>\r\n</div>\r\n\r\n</div>\r\n"]}
|
|
155
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-content-viewer.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-content-viewer/kv-content-viewer.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-content-viewer/kv-content-viewer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, EventEmitter, input, Input, InputSignal, Output, signal, TemplateRef } from '@angular/core';\r\nimport { SafeHtml } from '@angular/platform-browser';\r\n\r\n@Component({\r\n  selector: 'kv-content-viewer',\r\n  templateUrl: './kv-content-viewer.component.html',\r\n  styleUrl: './kv-content-viewer.component.scss'\r\n})\r\nexport class KvContentViewerComponent {\r\n\r\n\r\n\r\n  // #region Signals\r\n dataSource: InputSignal<any[]> = input<any[]>([]);\r\n paginaInicial = signal<number>(1);\r\n arquivo = input<string | undefined>(undefined);\r\n arquivoPreview = signal<any>(undefined);\r\n nomeArquivo = signal<string>('');\r\n type = input<string | undefined>(undefined);\r\n blob = input<Blob>('' as any);\r\n idarquivo = signal<number | undefined>(undefined);\r\n ekpContent = input<SafeHtml | undefined>(undefined);\r\n totalItensCarregado = computed(\r\n  () => this.dataSource()?.length || 0\r\n);\r\n// #endregion\r\n\r\n// #region Properties\r\nempresaSelecionada!: any;\r\nidtipodocumento!: number[];\r\n@Input() extencaoDocumento!: string;\r\npreviewOn: boolean = false;\r\nselectedItem: any = {};\r\n@Input() totalRecords: number = 0;\r\nisLoading: boolean = false;\r\ndisplaySidebar: boolean = false;\r\nisSelected: boolean = false;\r\n@Input() visualizadorDocumentos: boolean = false;\r\n@Input() cardTemplate!: TemplateRef<any>;\r\n@Input() contentTemplate!: TemplateRef<any>;\r\n@Input() noDocumentSelectedTemplate!: TemplateRef<any>;\r\n@Input() noDocumentListTemplate!: TemplateRef<any>;\r\n@Input() buttonTemplate!: TemplateRef<any>;\r\n@Input() indvisualizado: boolean = false;\r\n@Input() btnTelaCheia: boolean = false;\r\n@Input() isLoadingSkeleton: boolean = false;\r\n@Input() borderCardNaoVisualizado: boolean = true;\r\ncontentViewer: boolean = false;\r\nkeyVisualizado: string = 'indvisualizado'; \r\n\r\ntodayDate(): string {\r\n  const today = new Date();\r\n  return today.toLocaleDateString('pt-BR', { day: '2-digit', month: '2-digit', year: 'numeric' });\r\n}\r\n// #endregion\r\n\r\n// #region Outputs\r\n@Output() onScrollHandler: EventEmitter<any> = new EventEmitter();\r\n@Output() onSelectFile: EventEmitter<any> = new EventEmitter();\r\n// #endregion\r\n\r\ntrackByFn(index: number, item: any): any {\r\n  return item.idarquivo; \r\n}\r\n\r\nisVisualizado(option: any): boolean {\r\n  return option[this.keyVisualizado] || false;\r\n}\r\n\r\nvisualizarPreview(arquivo: any, buttonTemplate?: boolean): void {\r\n  \r\n  if (buttonTemplate) {\r\n    this.contentViewer = true;\r\n  } else {\r\n    arquivo[this.keyVisualizado] = true;\r\n    this.contentViewer = true;\r\n    this.arquivoPreview.set(arquivo);\r\n  }\r\n\r\n  this.onSelectFile.emit(arquivo);\r\n  \r\n}\r\n\r\nalternarTelaCheia() {\r\n  const element = document.getElementById('fullscreenDiv');\r\n  const button = document.getElementById('fullscreenBtn');\r\n\r\n  // Verifica se os elementos existem\r\n  if (element && button) {\r\n    if (!document.fullscreenElement) {\r\n      // Expandir para tela cheia\r\n      if (element.requestFullscreen) {\r\n        element.requestFullscreen();\r\n      } else if ((element as any).mozRequestFullScreen) { // Para Firefox\r\n        (element as any).mozRequestFullScreen();\r\n      } else if ((element as any).webkitRequestFullscreen) { // Para Chrome, Safari e Opera\r\n        (element as any).webkitRequestFullscreen();\r\n      } else if ((element as any).msRequestFullscreen) { // Para IE/Edge\r\n        (element as any).msRequestFullscreen();\r\n      }\r\n      button.textContent = 'close_fullscreen';\r\n    } else {\r\n      // Sair da tela cheia\r\n      if (document.exitFullscreen) {\r\n        document.exitFullscreen();\r\n      } else if ((document as any).mozCancelFullScreen) { // Para Firefox\r\n        (document as any).mozCancelFullScreen();\r\n      } else if ((document as any).webkitExitFullscreen) { // Para Chrome, Safari e Opera\r\n        (document as any).webkitExitFullscreen();\r\n      } else if ((document as any).msExitFullscreen) { // Para IE/Edge\r\n        (document as any).msExitFullscreen();\r\n      }\r\n      button.textContent = 'open_in_full';\r\n    }\r\n  }\r\n}\r\n\r\nngOnInit(): void {\r\n  document.addEventListener('fullscreenchange', () => {\r\n    const button = document.getElementById('fullscreenBtn');\r\n    \r\n    if (button) {\r\n      if (!document.fullscreenElement) {\r\n        button.textContent = 'open_in_full';\r\n      } else {\r\n        button.textContent = 'close_fullscreen';\r\n      }\r\n    }\r\n  });\r\n}\r\n\r\nscrollHandler($event: Event) {\r\n  const element = $event.target as HTMLElement;\r\n\r\n  //se o escroll chegar até o final\r\n  if (element.scrollHeight - element.scrollTop === element.clientHeight) {\r\n    // this.buscarProximosDocumentos();\r\n    this.onScrollHandler.emit($event);\r\n  }\r\n}\r\n\r\n}\r\n","<div class=\"flex flex-column md:flex-row gap-2 mt-3 custom-max-height\" style=\"height: 100%;\">\r\n  <!-- Lista de documentos -->\r\n  <div\r\n    class=\"card-perfil col-12 md:col-4 lg:col-3\"\r\n    (scroll)=\"scrollHandler($event)\"\r\n    [ngClass]=\"{\r\n      'overflow-y-scroll': dataSource().length > 0,\r\n      'overflow-y-hidden': dataSource().length === 0\r\n    }\"\r\n    style=\"position: relative; height: 100%; min-height: 15rem;\"\r\n  >\r\n    <div *ngIf=\"dataSource().length > 0; else emptyDocumentList\" class=\"col-12\">\r\n      <!-- Lista de cards -->\r\n      <div\r\n        *ngFor=\"let option of dataSource(); trackBy: trackByFn\"\r\n        class=\"card-normal outline-none border-round-xl w-full p-2 m-1 grid p-fluid flex flex-row flex-nowrap align-items-center justify-content-center cursor-pointer\"\r\n        (click)=\"visualizarPreview(option)\"\r\n        [ngClass]=\"{\r\n    'card-naoVisualizado': !isVisualizado(option) && borderCardNaoVisualizado,\r\n    'card-selected': option === arquivoPreview(),\r\n    'card-normal': option !== arquivoPreview(),\r\n   }\"\r\n      >\r\n        <div class=\"flex flex-grow-1 ml-2 flex-column gap-1 m-0 p-0 overflow-hidden text-overflow-ellipsis \" style=\"max-width: 100%;\">\r\n          <ng-container *ngIf=\"cardTemplate; else defaultTemplate\">\r\n            <ng-container\r\n              *ngTemplateOutlet=\"cardTemplate; context: { $implicit: option }\"\r\n            ></ng-container>\r\n          </ng-container>\r\n        </div>\r\n        <ng-template #defaultTemplate>\r\n          <div class=\"card-common-style default-card\">\r\n            <h1 class=\"font-bold text-base p-0 m-0\">Bem-vindo!</h1>\r\n            <p class=\"text-sm mt-2\">\r\n              Kv-file-preview aguardando um template... \r\n            </p>\r\n            <p class=\"font-bold text-sm p-0 m-0\">Data: {{ todayDate() }}</p>\r\n          </div>\r\n        </ng-template>\r\n      </div>\r\n\r\n    </div>\r\n\r\n    <ng-template #emptyDocumentList>\r\n\r\n      @if(isLoadingSkeleton){\r\n        <p-skeleton *ngFor=\"let i of [1, 2, 3, 4, 5, 6, 7, 8, 9]\"></p-skeleton>\r\n      }\r\n\r\n      @if(!noDocumentListTemplate) {\r\n      <div class=\"text-center text-gray-600 mt-4 m-3\" style=\"height: 100%\">\r\n        <div class=\" flex align-items-center gap-1\">\r\n          <span class=\"material-symbols-outlined\"> inbox </span>\r\n          <p>Nenhum documento disponível.</p>\r\n        </div>\r\n      </div>\r\n      } @else {\r\n      <div class=\"text-center mt-4 m-3\" style=\"height: 100%\">\r\n        <ng-container *ngTemplateOutlet=\"noDocumentListTemplate\"></ng-container>\r\n      </div>\r\n      }\r\n    </ng-template>\r\n\r\n    <!-- Contador de documentos - Fixo na parte inferior -->\r\n    <div\r\n      class=\"sticky-counter flex flex-row flex-1 px-2 justify-content-center p-2\"\r\n      style=\"position: sticky; bottom: -10px; background-color: white\"\r\n    >\r\n      <span>{{ totalItensCarregado() }} de {{ totalRecords }}</span>\r\n    </div>\r\n  </div>\r\n\r\n  <!-- Visualizador -->\r\n<div id=\"fullscreenDiv\" class=\"card-perfil col-12 md:col-8 lg:col-9\" style=\"position: relative; height: 100%;\"\r\n  [ngStyle]=\"{\r\n    'overflow-y': arquivoPreview() ? 'auto' : 'hidden'\r\n  }\">\r\n  @if(btnTelaCheia && !buttonTemplate)\r\n  {\r\n    <div class=\"grid\">\r\n      <div class=\"col\"></div>\r\n      <span id=\"fullscreenBtn\" (click)=\"alternarTelaCheia()\" class=\"material-symbols-outlined p-2 text-xl cursor-pointer\">\r\n        open_in_full\r\n      </span>\r\n    </div>\r\n  } @if(!btnTelaCheia && buttonTemplate && !contentViewer)\r\n  {\r\n    <div class=\"grid\">\r\n      <div class=\"col\"></div>\r\n      <span class=\"p-3\">\r\n        <span (click)=\"visualizarPreview(null, true)\">\r\n        <ng-container *ngTemplateOutlet=\"buttonTemplate\"></ng-container>\r\n        </span>\r\n      </span>\r\n    </div>\r\n  } @if(btnTelaCheia && buttonTemplate) {\r\n    <div class=\"grid\">\r\n      @if(!contentViewer) {\r\n        <span class=\"p-3\">\r\n          <span (click)=\"visualizarPreview(null, true)\">\r\n            <ng-container *ngTemplateOutlet=\"buttonTemplate\"></ng-container>\r\n          </span>\r\n        </span>\r\n      }\r\n      <div class=\"col\"></div>\r\n      <span id=\"fullscreenBtn\" (click)=\"alternarTelaCheia()\" class=\"material-symbols-outlined p-2 text-xl cursor-pointer\">\r\n        open_in_full\r\n      </span>\r\n    </div>\r\n  }\r\n  @if(visualizadorDocumentos) {\r\n    <ng-container *ngIf=\"arquivo(); else noDocumentSelected\">\r\n      @if(isLoading) {\r\n      <ngx-loading\r\n        [show]=\"isLoading\"\r\n        [config]=\"{ backdropBorderRadius: '3px', fullScreenBackdrop: false }\"\r\n      ></ngx-loading>\r\n      }\r\n      <kv-file-viewer-novo\r\n      *ngIf=\"extencaoDocumento !== 'ekp'\"\r\n        [arquivo]=\"arquivo()!\"\r\n        [type]=\"type()!\"\r\n        [blob]=\"blob()!\"\r\n        [width]=\"'100%'\" \r\n        [height]=\"'100%'\"\r\n        class=\"file-viewer\"\r\n        style=\"max-height: 100%;\"\r\n      >\r\n      </kv-file-viewer-novo>\r\n\r\n      <div\r\n        id=\"html-content\"\r\n        [innerHTML]=\"ekpContent()\"\r\n        *ngIf=\"extencaoDocumento === 'ekp'\"\r\n        class=\"ekp-content\"\r\n        style=\"overflow-y: auto; max-height: 100%;\"\r\n      ></div>\r\n    </ng-container>\r\n  } @else {\r\n    <ng-container *ngIf=\"arquivoPreview() || contentViewer; else noDocumentSelected\">\r\n      <ng-container\r\n        *ngTemplateOutlet=\"\r\n          contentTemplate;\r\n          context: { $implicit: arquivoPreview() }\r\n        \"\r\n        style=\"overflow-y: auto; max-height: 100%;\"\r\n      ></ng-container>\r\n    </ng-container>\r\n  }\r\n  <ng-template #noDocumentSelected>\r\n    @if(!noDocumentSelectedTemplate) {\r\n    <div\r\n      class=\"no-document-message flex flex-column align-items-center justify-content-center\"\r\n      style=\"height: 100%; overflow-y: auto;\"\r\n    >\r\n      <p class=\"text-center text-gray-500\">\r\n        Selecione um arquivo para visualização\r\n      </p>\r\n      <img\r\n        [src]=\"\r\n          'https://work-assets.keevo.com.br/img/Digital_personal_files-pana_3.png'\r\n        \"\r\n        style=\"max-height: 50%; margin-top: 2rem;\"\r\n        alt=\"\"\r\n      />\r\n    </div>\r\n    } @else {\r\n    <ng-container\r\n      *ngTemplateOutlet=\"noDocumentSelectedTemplate\"\r\n    ></ng-container>\r\n    }\r\n  </ng-template>\r\n</div>\r\n\r\n</div>\r\n"]}
|