keevo-components 1.8.417 → 1.8.419

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.
Files changed (22) hide show
  1. package/esm2022/lib/api/base-components/base-component-dropdown.mjs +2 -2
  2. package/esm2022/lib/api/base-components/base-component-multi-select.mjs +12 -9
  3. package/esm2022/lib/api/components/table/table.config.mjs +1 -1
  4. package/esm2022/lib/api/components/table/table.paginate.mjs +2 -2
  5. package/esm2022/lib/api/pipes/capitalize.pipe.mjs +7 -1
  6. package/esm2022/lib/components/kv-content-viewer/kv-content-viewer.component.mjs +45 -3
  7. package/esm2022/lib/components/kv-layout/dropdown-master/dropdown-master.component.mjs +3 -3
  8. package/esm2022/lib/components/kv-layout/layout/kv-layout.component.mjs +3 -3
  9. package/esm2022/lib/components/kv-table/kv-table.component.mjs +9 -3
  10. package/esm2022/lib/components/kv-table-edit/kv-table-edit.component.mjs +6 -3
  11. package/esm2022/lib/components/kv-table-expandable/kv-table-expandable.component.mjs +20 -4
  12. package/esm2022/lib/components/kv-tree-table/kv-tree-table.component.mjs +3 -3
  13. package/fesm2022/keevo-components.mjs +101 -25
  14. package/fesm2022/keevo-components.mjs.map +1 -1
  15. package/lib/api/base-components/base-component-multi-select.d.ts +1 -0
  16. package/lib/api/components/table/table.config.d.ts +1 -0
  17. package/lib/api/pipes/capitalize.pipe.d.ts +1 -0
  18. package/lib/components/kv-content-viewer/kv-content-viewer.component.d.ts +3 -1
  19. package/lib/components/kv-table/kv-table.component.d.ts +2 -1
  20. package/lib/components/kv-table-edit/kv-table-edit.component.d.ts +2 -1
  21. package/lib/components/kv-table-expandable/kv-table-expandable.component.d.ts +6 -3
  22. package/package.json +1 -1
@@ -166,7 +166,7 @@ export class BaseComponentDropDown extends BaseComponentInput {
166
166
  }
167
167
  capitalizeOptions(options) {
168
168
  if (this.capitalize) {
169
- return options.map((option) => {
169
+ return options?.map((option) => {
170
170
  option[this.optionLabel] = this.transformCapitalize(option[this.optionLabel]);
171
171
  return option;
172
172
  });
@@ -224,4 +224,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
224
224
  }], requestComplete: [{
225
225
  type: Output
226
226
  }] } });
227
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-component-dropdown.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/api/base-components/base-component-dropdown.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  Type,\r\n} from '@angular/core';\r\n\r\nimport { FormControl } from '@angular/forms';\r\nimport { Observable, debounceTime, finalize, of } from 'rxjs';\r\nimport { DialogService } from 'primeng/dynamicdialog';\r\nimport { BaseComponentInput } from './base-component-input';\r\nimport { ComponentService } from '../services/component.service';\r\nimport { ObjectService } from '../services/object.service';\r\nimport { filtroCombo } from '../components/dropdown/filtro.combo';\r\n\r\n@Component({\r\n  template: '',\r\n})\r\nexport abstract class BaseComponentDropDown extends BaseComponentInput<any> implements OnInit {\r\n\r\n  @Input() filteredOptions!: any[];\r\n  @Input() options!: any[];\r\n  @Input() optionLabel!: string;\r\n  @Input() optionValue!: string;\r\n  @Input() optionDisabled!: string;\r\n\r\n  @Input() capitalize: boolean = false;\r\n  \r\n  @Input() group!: boolean;\r\n  @Input() optionGroupLabel!: string;\r\n  @Input() optionGroupChildren!: string;\r\n\r\n  @Input() filter: boolean = true;\r\n  @Input() lazy: boolean = false;\r\n  @Input() loading: boolean = false;\r\n\r\n  @Input() showAddButton: boolean = false;\r\n  @Input() showClear: boolean = true;\r\n  @Input() widthField?: string;\r\n\r\n  @Output() onAddClick: EventEmitter<any> = new EventEmitter();\r\n  @Output() onClick: EventEmitter<any> = new EventEmitter();\r\n  @Output() onLoadCombo: EventEmitter<any> = new EventEmitter();\r\n  @Output() onSelectionChange: EventEmitter<any> = new EventEmitter();\r\n  @Output() onSelectionValue: EventEmitter<any> = new EventEmitter();\r\n  @Output() requestComplete: EventEmitter<any> = new EventEmitter();\r\n\r\n  prepositions: string[] = [\r\n    'de',\r\n    'da',\r\n    'do',\r\n    'em',\r\n    'no',\r\n    'na',\r\n    'para',\r\n    'por',\r\n    'com',\r\n    'a',\r\n    'o',\r\n    'e',\r\n  ];\r\n\r\n  constructor(\r\n    componentService: ComponentService,\r\n    private dialogService: DialogService\r\n  ) {\r\n    super(componentService);\r\n    this.registerOnTouched(() => { });\r\n  }\r\n\r\n  override ngOnInit(): void {\r\n    super.ngOnInit();\r\n    this.setPlaceHolder('Selecione um valor');\r\n\r\n    if (!this.lazy) this.carregarCombo();\r\n  }\r\n\r\n  protected addClick(event: Event) {\r\n    this.onAddClick.emit(event);\r\n  }\r\n\r\n  public carregarCombo(filtro?: filtroCombo): void {\r\n    \r\n    if (filtro) {\r\n      this.carregarComboObs(this.listarCombo(filtro));\r\n    }\r\n    else {\r\n      this.carregarComboObs(this.listar());\r\n    }\r\n  }\r\n\r\n  protected carregarComboObs(obs: Observable<any>) {\r\n    if (obs) {\r\n      obs\r\n        .pipe\r\n        (\r\n          debounceTime(450),\r\n          this.loadingCombo()\r\n        )\r\n        .subscribe({\r\n          next: (data: any) => {\r\n            this.options = this.capitalizeOptions(data);\r\n            this.filteredOptions = this.options;\r\n            this.requestComplete.emit(true);\r\n          },\r\n          error: (error: any) => {\r\n            console.log(error);\r\n          },\r\n        });\r\n    }\r\n  }\r\n\r\n  public emptyMessage() {\r\n    return (this.lazy ? 'Digite para pesquisar' : 'Nenhum resultado encontrado');\r\n  }\r\n\r\n  public filterOptions(field: string, value: any): void {\r\n    if (this.options) {\r\n      let lista = ObjectService.filterObject(this.options, field, value);\r\n      if (lista?.length > 0) {\r\n        of(lista).subscribe((opts: any[]) => {\r\n          this.filteredOptions = this.capitalizeOptions(opts);\r\n        });\r\n      } else this.filteredOptions = [];\r\n    }\r\n  }\r\n\r\n  protected listar(): any { }\r\n  protected listarCombo(value: any): any { }\r\n\r\n  loadingCombo = (): any => {\r\n    if (!this.lazy) {\r\n      return (src: Observable<any>) => {\r\n        this.loading = true;\r\n        return src.pipe(finalize(() => {\r\n          this.loading = false;\r\n        }));\r\n      };\r\n    }\r\n  };\r\n\r\n  protected openDialog(\r\n    componentType: Type<any>,\r\n    width?: string,\r\n    height?: string\r\n  ) {\r\n    const ref = this.dialogService.open(componentType, {\r\n      width: width || '70%',\r\n      height: height,\r\n      closable: false,\r\n      maximizable: true,\r\n      data: { popup: true },\r\n    });\r\n\r\n    ref.onClose.subscribe((id: any) => {\r\n      if (id) {\r\n        this.listar()\r\n          .pipe(this.loadingCombo())\r\n          .subscribe((data: any) => {\r\n            this.options = this.capitalizeOptions(data);\r\n            this.filteredOptions = this.options;\r\n            if (id) this.formControl?.setValue(id);\r\n          });\r\n      }\r\n    });\r\n  }\r\n\r\n  protected onInputChange(event: any) {\r\n    this.onSelectionValue.emit(event);\r\n\r\n    if (this.formControl) {\r\n      const controlName = this.getName(this.formControl as FormControl);\r\n      if (controlName) {\r\n        let currentItem = ObjectService.findObject(\r\n          this.options,\r\n          controlName,\r\n          event.value\r\n        );\r\n        this.onSelectionChange.emit(currentItem);\r\n      }\r\n    }\r\n  }\r\n\r\n  onInputClick(event: any) {\r\n    this.onClick.emit(event);\r\n  }\r\n\r\n  onInputFilter(event: any) {\r\n    if (event) {\r\n      if (event.filter) {\r\n        if (event.filter.length > 2) {\r\n          let fil = { termoPesquisa: event.filter } as filtroCombo;\r\n          this.carregarCombo(fil);\r\n          this.onLoadCombo.emit(fil);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  override writeValue(value: any): void {\r\n    if (this.lazy && value) {\r\n      let fil = { id: value } as filtroCombo;\r\n      this.carregarCombo(fil);\r\n      this.onLoadCombo.emit(fil);\r\n    }\r\n    this.value = value;\r\n  }\r\n\r\n  \r\n  transformCapitalize(value: string): string {\r\n    \r\n    if (!value) return value;\r\n  \r\n    return value\r\n      .split(' ')\r\n      .map((word, index) => {\r\n        if (\r\n          index !== 0 &&\r\n          this.prepositions.includes(word.toLocaleLowerCase())\r\n        ) {\r\n          return word.toLocaleLowerCase();\r\n        }\r\n        return (\r\n          word.charAt(0).toLocaleUpperCase() + word.slice(1).toLocaleLowerCase()\r\n        );\r\n      })\r\n      .join(' ');\r\n  }\r\n\r\n  capitalizeOptions(options: any[]): any[] {\r\n    \r\n    if (this.capitalize) {\r\n      return options.map((option: any) => {\r\n        option[this.optionLabel] = this.transformCapitalize(option[this.optionLabel]);\r\n      \r\n        return option;\r\n      });\r\n    }\r\n    return options;\r\n  }\r\n}"]}
227
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-component-dropdown.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/api/base-components/base-component-dropdown.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  Type,\r\n} from '@angular/core';\r\n\r\nimport { FormControl } from '@angular/forms';\r\nimport { Observable, debounceTime, finalize, of } from 'rxjs';\r\nimport { DialogService } from 'primeng/dynamicdialog';\r\nimport { BaseComponentInput } from './base-component-input';\r\nimport { ComponentService } from '../services/component.service';\r\nimport { ObjectService } from '../services/object.service';\r\nimport { filtroCombo } from '../components/dropdown/filtro.combo';\r\n\r\n@Component({\r\n  template: '',\r\n})\r\nexport abstract class BaseComponentDropDown extends BaseComponentInput<any> implements OnInit {\r\n\r\n  @Input() filteredOptions!: any[];\r\n  @Input() options!: any[];\r\n  @Input() optionLabel!: string;\r\n  @Input() optionValue!: string;\r\n  @Input() optionDisabled!: string;\r\n\r\n  @Input() capitalize: boolean = false;\r\n  \r\n  @Input() group!: boolean;\r\n  @Input() optionGroupLabel!: string;\r\n  @Input() optionGroupChildren!: string;\r\n\r\n  @Input() filter: boolean = true;\r\n  @Input() lazy: boolean = false;\r\n  @Input() loading: boolean = false;\r\n\r\n  @Input() showAddButton: boolean = false;\r\n  @Input() showClear: boolean = true;\r\n  @Input() widthField?: string;\r\n\r\n  @Output() onAddClick: EventEmitter<any> = new EventEmitter();\r\n  @Output() onClick: EventEmitter<any> = new EventEmitter();\r\n  @Output() onLoadCombo: EventEmitter<any> = new EventEmitter();\r\n  @Output() onSelectionChange: EventEmitter<any> = new EventEmitter();\r\n  @Output() onSelectionValue: EventEmitter<any> = new EventEmitter();\r\n  @Output() requestComplete: EventEmitter<any> = new EventEmitter();\r\n\r\n  prepositions: string[] = [\r\n    'de',\r\n    'da',\r\n    'do',\r\n    'em',\r\n    'no',\r\n    'na',\r\n    'para',\r\n    'por',\r\n    'com',\r\n    'a',\r\n    'o',\r\n    'e',\r\n  ];\r\n\r\n  constructor(\r\n    componentService: ComponentService,\r\n    private dialogService: DialogService\r\n  ) {\r\n    super(componentService);\r\n    this.registerOnTouched(() => { });\r\n  }\r\n\r\n  override ngOnInit(): void {\r\n    super.ngOnInit();\r\n    this.setPlaceHolder('Selecione um valor');\r\n\r\n    if (!this.lazy) this.carregarCombo();\r\n  }\r\n\r\n  protected addClick(event: Event) {\r\n    this.onAddClick.emit(event);\r\n  }\r\n\r\n  public carregarCombo(filtro?: filtroCombo): void {\r\n    \r\n    if (filtro) {\r\n      this.carregarComboObs(this.listarCombo(filtro));\r\n    }\r\n    else {\r\n      this.carregarComboObs(this.listar());\r\n    }\r\n  }\r\n\r\n  protected carregarComboObs(obs: Observable<any>) {\r\n    if (obs) {\r\n      obs\r\n        .pipe\r\n        (\r\n          debounceTime(450),\r\n          this.loadingCombo()\r\n        )\r\n        .subscribe({\r\n          next: (data: any) => {\r\n            this.options = this.capitalizeOptions(data);\r\n            this.filteredOptions = this.options;\r\n            this.requestComplete.emit(true);\r\n          },\r\n          error: (error: any) => {\r\n            console.log(error);\r\n          },\r\n        });\r\n    }\r\n  }\r\n\r\n  public emptyMessage() {\r\n    return (this.lazy ? 'Digite para pesquisar' : 'Nenhum resultado encontrado');\r\n  }\r\n\r\n  public filterOptions(field: string, value: any): void {\r\n    if (this.options) {\r\n      let lista = ObjectService.filterObject(this.options, field, value);\r\n      if (lista?.length > 0) {\r\n        of(lista).subscribe((opts: any[]) => {\r\n          this.filteredOptions = this.capitalizeOptions(opts);\r\n        });\r\n      } else this.filteredOptions = [];\r\n    }\r\n  }\r\n\r\n  protected listar(): any { }\r\n  protected listarCombo(value: any): any { }\r\n\r\n  loadingCombo = (): any => {\r\n    if (!this.lazy) {\r\n      return (src: Observable<any>) => {\r\n        this.loading = true;\r\n        return src.pipe(finalize(() => {\r\n          this.loading = false;\r\n        }));\r\n      };\r\n    }\r\n  };\r\n\r\n  protected openDialog(\r\n    componentType: Type<any>,\r\n    width?: string,\r\n    height?: string\r\n  ) {\r\n    const ref = this.dialogService.open(componentType, {\r\n      width: width || '70%',\r\n      height: height,\r\n      closable: false,\r\n      maximizable: true,\r\n      data: { popup: true },\r\n    });\r\n\r\n    ref.onClose.subscribe((id: any) => {\r\n      if (id) {\r\n        this.listar()\r\n          .pipe(this.loadingCombo())\r\n          .subscribe((data: any) => {\r\n            this.options = this.capitalizeOptions(data);\r\n            this.filteredOptions = this.options;\r\n            if (id) this.formControl?.setValue(id);\r\n          });\r\n      }\r\n    });\r\n  }\r\n\r\n  protected onInputChange(event: any) {\r\n    this.onSelectionValue.emit(event);\r\n\r\n    if (this.formControl) {\r\n      const controlName = this.getName(this.formControl as FormControl);\r\n      if (controlName) {\r\n        let currentItem = ObjectService.findObject(\r\n          this.options,\r\n          controlName,\r\n          event.value\r\n        );\r\n        this.onSelectionChange.emit(currentItem);\r\n      }\r\n    }\r\n  }\r\n\r\n  onInputClick(event: any) {\r\n    this.onClick.emit(event);\r\n  }\r\n\r\n  onInputFilter(event: any) {\r\n    if (event) {\r\n      if (event.filter) {\r\n        if (event.filter.length > 2) {\r\n          let fil = { termoPesquisa: event.filter } as filtroCombo;\r\n          this.carregarCombo(fil);\r\n          this.onLoadCombo.emit(fil);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  override writeValue(value: any): void {\r\n    if (this.lazy && value) {\r\n      let fil = { id: value } as filtroCombo;\r\n      this.carregarCombo(fil);\r\n      this.onLoadCombo.emit(fil);\r\n    }\r\n    this.value = value;\r\n  }\r\n\r\n  \r\n  transformCapitalize(value: string): string {\r\n    \r\n    if (!value) return value;\r\n  \r\n    return value\r\n      .split(' ')\r\n      .map((word, index) => {\r\n        if (\r\n          index !== 0 &&\r\n          this.prepositions.includes(word.toLocaleLowerCase())\r\n        ) {\r\n          return word.toLocaleLowerCase();\r\n        }\r\n        return (\r\n          word.charAt(0).toLocaleUpperCase() + word.slice(1).toLocaleLowerCase()\r\n        );\r\n      })\r\n      .join(' ');\r\n  }\r\n\r\n  capitalizeOptions(options: any[]): any[] {\r\n    \r\n    if (this.capitalize) {\r\n      return options?.map((option: any) => {\r\n        option[this.optionLabel] = this.transformCapitalize(option[this.optionLabel]);\r\n      \r\n        return option;\r\n      });\r\n    }\r\n    return options;\r\n  }\r\n}"]}
@@ -32,6 +32,10 @@ export class BaseComponentMultiSelect extends BaseComponentInput {
32
32
  'o',
33
33
  'e',
34
34
  ];
35
+ this.romanNumerals = [
36
+ 'I', 'II', 'III', 'IV', 'V', 'VI', 'VII', 'VIII', 'IX', 'X', 'XI', 'XII', 'XIII', 'XIV', 'XV',
37
+ 'XVI', 'XVII', 'XVIII', 'XIX', 'XX'
38
+ ];
35
39
  this.registerOnTouched(() => { });
36
40
  }
37
41
  ngOnInit() {
@@ -115,16 +119,15 @@ export class BaseComponentMultiSelect extends BaseComponentInput {
115
119
  transformCapitalize(value) {
116
120
  if (!value)
117
121
  return value;
118
- return value
119
- .split(' ')
120
- .map((word, index) => {
121
- if (index !== 0 &&
122
- this.prepositions.includes(word.toLocaleLowerCase())) {
122
+ return value.split(' ').map((word, index) => {
123
+ if (this.romanNumerals.includes(word.toUpperCase())) {
124
+ return word;
125
+ }
126
+ if (index !== 0 && this.prepositions.includes(word.toLocaleLowerCase())) {
123
127
  return word.toLocaleLowerCase();
124
128
  }
125
- return (word.charAt(0).toLocaleUpperCase() + word.slice(1).toLocaleLowerCase());
126
- })
127
- .join(' ');
129
+ return word.charAt(0).toLocaleUpperCase() + word.slice(1).toLocaleLowerCase();
130
+ }).join(' ');
128
131
  }
129
132
  capitalizeOptions(options) {
130
133
  if (this.capitalize) {
@@ -168,4 +171,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
168
171
  }], onClick: [{
169
172
  type: Output
170
173
  }] } });
171
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-component-multi-select.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/api/base-components/base-component-multi-select.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n} from '@angular/core';\r\n\r\nimport { FormControl } from '@angular/forms';\r\nimport { Observable, of } from 'rxjs';\r\nimport { BaseComponentInput } from './base-component-input';\r\nimport { ComponentService } from '../services/component.service';\r\nimport { ObjectService } from '../services/object.service';\r\nimport { filtroCombo } from '../components/dropdown/filtro.combo';\r\n\r\n@Component({\r\n  template: '',\r\n})\r\nexport abstract class BaseComponentMultiSelect extends BaseComponentInput<any> implements OnInit {\r\n\r\n  @Input() options: any = [];\r\n  @Input() optionLabel!: string;\r\n  @Input() optionValue!: string;\r\n  @Input() filter: boolean = false;\r\n  @Input() showClear: boolean = false;\r\n\r\n  @Input() lazy: boolean = false;\r\n  @Input() filteredOptions: any = [];\r\n\r\n  @Input() capitalize: boolean = false;\r\n\r\n  @Output() onSelectionChange: EventEmitter<any> = new EventEmitter();\r\n  @Output() onPanelHide: EventEmitter<any> = new EventEmitter();\r\n  @Output() onSelectionValue: EventEmitter<any> = new EventEmitter();\r\n  @Output() onClick: EventEmitter<any> = new EventEmitter();\r\n\r\n  loadedCombo: boolean = false;\r\n\r\n  prepositions: string[] = [\r\n    'de',\r\n    'da',\r\n    'do',\r\n    'em',\r\n    'no',\r\n    'na',\r\n    'para',\r\n    'por',\r\n    'com',\r\n    'a',\r\n    'o',\r\n    'e',\r\n  ];\r\n\r\n  constructor(\r\n    componentService: ComponentService,\r\n  ) {\r\n    super(componentService);\r\n    this.registerOnTouched(() => { });\r\n  }\r\n\r\n  override ngOnInit(): void {\r\n    super.ngOnInit();\r\n    this.setPlaceHolder('Selecione um valor');\r\n\r\n    if (!this.lazy) this.carregarCombo();\r\n  }\r\n\r\n  public carregarCombo(filtro?: filtroCombo): void {\r\n    if (filtro) {\r\n      this.carregarComboObs(this.listarCombo(filtro));\r\n    }\r\n    else {\r\n      this.carregarComboObs(this.listar());\r\n    }\r\n  }\r\n\r\n  private carregarComboObs(obs: Observable<any>) {\r\n\r\n    if (obs) {\r\n      obs\r\n        .subscribe({\r\n          next: (data: any) => {\r\n            console.log(JSON.stringify(data))\r\n            this.options = this.capitalizeOptions(data);\r\n            this.filteredOptions = this.options;\r\n            this.loadedCombo = true\r\n          },\r\n          error: (error: any) => {\r\n            console.log(error);\r\n          },\r\n        });\r\n    }\r\n  }\r\n\r\n  public filterOptions(field: string, value: any): void {\r\n    if (this.options) {\r\n      let lista = ObjectService.filterObject(this.options, field, value);\r\n      if (lista?.length > 0) {\r\n        of(lista).subscribe((opts: any[]) => {\r\n          this.filteredOptions = this.capitalizeOptions(opts);\r\n\r\n        });\r\n      } else this.filteredOptions = [];\r\n    }\r\n  }\r\n\r\n  protected onInputChange(event: any) {\r\n    this.onSelectionValue.emit(event);\r\n\r\n    if (this.formControl) {\r\n      const controlName = this.getName(this.formControl as FormControl);\r\n      if (controlName) {\r\n        let currentItem = ObjectService.findObject(\r\n          this.options,\r\n          controlName,\r\n          event.value\r\n        );\r\n        this.onSelectionChange.emit(currentItem);\r\n      }\r\n    }\r\n  }\r\n\r\n  onInputClick(event: any) {\r\n    this.onClick.emit(event);\r\n  }\r\n\r\n  onInputFilter(event: any) {\r\n    if (event) {\r\n      if (event.filter) {\r\n        if (event.filter.length > 2) {\r\n          this.carregarCombo({ termoPesquisa: event.filter } as filtroCombo);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  protected listar(): any { }\r\n  protected listarCombo(value: any): any { }\r\n\r\n  panelHide(event: any) {\r\n    this.onPanelHide.emit(event);\r\n  }\r\n\r\n  public override get baseInputClass(): string {\r\n    return `p-multiselect-sm ${this.hasError ? 'ng-invalid ng-dirty' : ''}`;\r\n  }\r\n\r\n  selectionChange(event: any) {\r\n    this.onSelectionChange.emit(event);\r\n  }\r\n\r\n  public requestCompleted() {\r\n    return this.loadedCombo;\r\n  }\r\n\r\n  transformCapitalize(value: string): string {\r\n    \r\n    if (!value) return value;\r\n  \r\n    return value\r\n      .split(' ')\r\n      .map((word, index) => {\r\n        if (\r\n          index !== 0 &&\r\n          this.prepositions.includes(word.toLocaleLowerCase())\r\n        ) {\r\n          return word.toLocaleLowerCase();\r\n        }\r\n        return (\r\n          word.charAt(0).toLocaleUpperCase() + word.slice(1).toLocaleLowerCase()\r\n        );\r\n      })\r\n      .join(' ');\r\n  }\r\n\r\n  capitalizeOptions(options: any[]): any[] {\r\n    if (this.capitalize) {\r\n      return options.map((option: any) => {\r\n        option[this.optionLabel] = this.transformCapitalize(option[this.optionLabel]);\r\n      \r\n        return option;\r\n      });\r\n    }\r\n    return options;\r\n  }\r\n\r\n}\r\n"]}
174
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-component-multi-select.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/api/base-components/base-component-multi-select.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n} from '@angular/core';\r\n\r\nimport { FormControl } from '@angular/forms';\r\nimport { Observable, of } from 'rxjs';\r\nimport { BaseComponentInput } from './base-component-input';\r\nimport { ComponentService } from '../services/component.service';\r\nimport { ObjectService } from '../services/object.service';\r\nimport { filtroCombo } from '../components/dropdown/filtro.combo';\r\n\r\n@Component({\r\n  template: '',\r\n})\r\nexport abstract class BaseComponentMultiSelect extends BaseComponentInput<any> implements OnInit {\r\n\r\n  @Input() options: any = [];\r\n  @Input() optionLabel!: string;\r\n  @Input() optionValue!: string;\r\n  @Input() filter: boolean = false;\r\n  @Input() showClear: boolean = false;\r\n\r\n  @Input() lazy: boolean = false;\r\n  @Input() filteredOptions: any = [];\r\n\r\n  @Input() capitalize: boolean = false;\r\n\r\n  @Output() onSelectionChange: EventEmitter<any> = new EventEmitter();\r\n  @Output() onPanelHide: EventEmitter<any> = new EventEmitter();\r\n  @Output() onSelectionValue: EventEmitter<any> = new EventEmitter();\r\n  @Output() onClick: EventEmitter<any> = new EventEmitter();\r\n\r\n  loadedCombo: boolean = false;\r\n\r\n  prepositions: string[] = [\r\n    'de',\r\n    'da',\r\n    'do',\r\n    'em',\r\n    'no',\r\n    'na',\r\n    'para',\r\n    'por',\r\n    'com',\r\n    'a',\r\n    'o',\r\n    'e',\r\n  ];\r\n\r\n  romanNumerals: string[] = [\r\n    'I', 'II', 'III', 'IV', 'V', 'VI', 'VII', 'VIII', 'IX', 'X', 'XI', 'XII', 'XIII', 'XIV', 'XV', \r\n    'XVI', 'XVII', 'XVIII', 'XIX', 'XX'\r\n  ];\r\n\r\n  constructor(\r\n    componentService: ComponentService,\r\n  ) {\r\n    super(componentService);\r\n    this.registerOnTouched(() => { });\r\n  }\r\n\r\n  override ngOnInit(): void {\r\n    super.ngOnInit();\r\n    this.setPlaceHolder('Selecione um valor');\r\n\r\n    if (!this.lazy) this.carregarCombo();\r\n  }\r\n\r\n  public carregarCombo(filtro?: filtroCombo): void {\r\n    if (filtro) {\r\n      this.carregarComboObs(this.listarCombo(filtro));\r\n    }\r\n    else {\r\n      this.carregarComboObs(this.listar());\r\n    }\r\n  }\r\n\r\n  private carregarComboObs(obs: Observable<any>) {\r\n\r\n    if (obs) {\r\n      obs\r\n        .subscribe({\r\n          next: (data: any) => {\r\n            console.log(JSON.stringify(data))\r\n            this.options = this.capitalizeOptions(data);\r\n            this.filteredOptions = this.options;\r\n            this.loadedCombo = true\r\n          },\r\n          error: (error: any) => {\r\n            console.log(error);\r\n          },\r\n        });\r\n    }\r\n  }\r\n\r\n  public filterOptions(field: string, value: any): void {\r\n    if (this.options) {\r\n      let lista = ObjectService.filterObject(this.options, field, value);\r\n      if (lista?.length > 0) {\r\n        of(lista).subscribe((opts: any[]) => {\r\n          this.filteredOptions = this.capitalizeOptions(opts);\r\n\r\n        });\r\n      } else this.filteredOptions = [];\r\n    }\r\n  }\r\n\r\n  protected onInputChange(event: any) {\r\n    this.onSelectionValue.emit(event);\r\n\r\n    if (this.formControl) {\r\n      const controlName = this.getName(this.formControl as FormControl);\r\n      if (controlName) {\r\n        let currentItem = ObjectService.findObject(\r\n          this.options,\r\n          controlName,\r\n          event.value\r\n        );\r\n        this.onSelectionChange.emit(currentItem);\r\n      }\r\n    }\r\n  }\r\n\r\n  onInputClick(event: any) {\r\n    this.onClick.emit(event);\r\n  }\r\n\r\n  onInputFilter(event: any) {\r\n    if (event) {\r\n      if (event.filter) {\r\n        if (event.filter.length > 2) {\r\n          this.carregarCombo({ termoPesquisa: event.filter } as filtroCombo);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  protected listar(): any { }\r\n  protected listarCombo(value: any): any { }\r\n\r\n  panelHide(event: any) {\r\n    this.onPanelHide.emit(event);\r\n  }\r\n\r\n  public override get baseInputClass(): string {\r\n    return `p-multiselect-sm ${this.hasError ? 'ng-invalid ng-dirty' : ''}`;\r\n  }\r\n\r\n  selectionChange(event: any) {\r\n    this.onSelectionChange.emit(event);\r\n  }\r\n\r\n  public requestCompleted() {\r\n    return this.loadedCombo;\r\n  }\r\n\r\n  transformCapitalize(value: string): string {\r\n    if (!value) return value;\r\n\r\n    return value.split(' ').map((word, index) => {\r\n      if (this.romanNumerals.includes(word.toUpperCase())) {\r\n        return word;\r\n      }\r\n\r\n      if (index !== 0 && this.prepositions.includes(word.toLocaleLowerCase())) {\r\n        return word.toLocaleLowerCase();\r\n      }\r\n\r\n      return word.charAt(0).toLocaleUpperCase() + word.slice(1).toLocaleLowerCase();\r\n    }).join(' ');\r\n  }\r\n  capitalizeOptions(options: any[]): any[] {\r\n    if (this.capitalize) {\r\n      return options.map((option: any) => {\r\n        option[this.optionLabel] = this.transformCapitalize(option[this.optionLabel]);\r\n      \r\n        return option;\r\n      });\r\n    }\r\n    return options;\r\n  }\r\n\r\n}\r\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUuY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2Vldm8tY29tcG9uZW50cy9zcmMvbGliL2FwaS9jb21wb25lbnRzL3RhYmxlL3RhYmxlLmNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVGFibGVDb25maWdDb2x1bW4gfSBmcm9tICcuL3RhYmxlLmNvbmZpZy5jb2x1bW4nO1xyXG5pbXBvcnQgeyBLdk1lbnVJdGVtLCBWYWx1ZU9yRm4gfSBmcm9tICcuL2t2LW1lbnVpdGVtJztcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgVGFibGVDb25maWcge1xyXG4gIGFjdGlvbnM/OiBLdk1lbnVJdGVtW107XHJcbiAgYWN0aW9uc0xvdGU/OiBBY3Rpb25zTG90ZUl0ZW1bXTtcclxuICBjb2x1bW5zOiBUYWJsZUNvbmZpZ0NvbHVtbltdO1xyXG4gIGRhdGFLZXk/OiBzdHJpbmc7XHJcbiAgcm93cz86IGFueTtcclxuICB0aXRsZT86IHN0cmluZztcclxuICBzdWJ0aXRsZT86IHN0cmluZztcclxuICBsYXp5OiBib29sZWFuO1xyXG4gIGZpZWxkR3JvdXA/OiBzdHJpbmc7XHJcbiAgZW5hYmxlQ2F0aW9uPzogYm9vbGVhbjtcclxuICBlbmFibGVGaWx0ZXI/OiBib29sZWFuO1xyXG4gIGVuYWJsZVNlbGVjdD86IGJvb2xlYW47XHJcbiAgZW5hYmxlVG9nZ2xlTm9kZXM/OiBib29sZWFuO1xyXG4gIC8vIHZpc2libGVDb250cm9sQ2hlY2tib3hGdW5jdGlvbj86IChyb3dEYXRhOiBhbnkpID0+IGJvb2xlYW47IC8vIEEgZnVuw6fDo28gcXVlIGNvbnRyb2xhIGEgZWRpw6fDo29cclxuICBkaXNhYmxlQ29udHJvbENoZWNrYm94RnVuY3Rpb24/OiAocm93RGF0YTogYW55LCByb3dOb2RlPzogYW55KSA9PiBib29sZWFuOyAvLyBBIGZ1bsOnw6NvIHF1ZSBjb250cm9sYSBhIGVkacOnw6NvXHJcbiAgZmllbGRHcm91cENvbG9yRnVuY3Rpb24/OiAoZGF0YTogYW55KSA9PiBzdHJpbmc7IC8vIE7Do28gw6kgdXRpbGl6YWRvXHJcbiAgZGlzYWJsZVJvdz86IChyb3dEYXRhOiBhbnkpID0+IGJvb2xlYW47XHJcbn1cclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgQWN0aW9uc0xvdGVJdGVtIHtcclxuICAvKipcclxuICAgKiBJZ25vcmFkbyBwb3IgZW5xdWFudG9cclxuICAgKi9cclxuICBzZXZlcml0eT86ICdwcmltYXJ5JyB8ICdzZWNvbmRhcnknIHwgJ3RlcnRpYXJ5JztcclxuICBpY29uOiBzdHJpbmc7XHJcbiAgc2hvd0Fjb2VzTG90ZT86IGJvb2xlYW47XHJcbiAgdG9vbHRpcD86IFZhbHVlT3JGbjxzdHJpbmcgfCB1bmRlZmluZWQ+O1xyXG4gIGRpc2FibGVkPzogVmFsdWVPckZuPGJvb2xlYW4gfCB1bmRlZmluZWQ+O1xyXG4gIHZpc2libGU/OiBWYWx1ZU9yRm48Ym9vbGVhbiB8IHVuZGVmaW5lZD47XHJcbiAgY29tbWFuZD86ICgpID0+IHZvaWQ7XHJcbn1cclxuIl19
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUuY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2Vldm8tY29tcG9uZW50cy9zcmMvbGliL2FwaS9jb21wb25lbnRzL3RhYmxlL3RhYmxlLmNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVGFibGVDb25maWdDb2x1bW4gfSBmcm9tICcuL3RhYmxlLmNvbmZpZy5jb2x1bW4nO1xyXG5pbXBvcnQgeyBLdk1lbnVJdGVtLCBWYWx1ZU9yRm4gfSBmcm9tICcuL2t2LW1lbnVpdGVtJztcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgVGFibGVDb25maWcge1xyXG4gIGFjdGlvbnM/OiBLdk1lbnVJdGVtW107XHJcbiAgYWN0aW9uc0xvdGU/OiBBY3Rpb25zTG90ZUl0ZW1bXTtcclxuICBjb2x1bW5zOiBUYWJsZUNvbmZpZ0NvbHVtbltdO1xyXG4gIGRhdGFLZXk/OiBzdHJpbmc7XHJcbiAgcm93cz86IGFueTtcclxuICB0aXRsZT86IHN0cmluZztcclxuICBzdWJ0aXRsZT86IHN0cmluZztcclxuICBsYXp5OiBib29sZWFuO1xyXG4gIGZpZWxkR3JvdXA/OiBzdHJpbmc7XHJcbiAgZW5hYmxlQ2F0aW9uPzogYm9vbGVhbjtcclxuICBlbmFibGVGaWx0ZXI/OiBib29sZWFuO1xyXG4gIGVuYWJsZVNlbGVjdD86IGJvb2xlYW47XHJcbiAgZW5hYmxlVG9nZ2xlTm9kZXM/OiBib29sZWFuO1xyXG4gIHRlbXBsYXRlUm93RXhwYW5kZWQ/OiBhbnk7XHJcbiAgLy8gdmlzaWJsZUNvbnRyb2xDaGVja2JveEZ1bmN0aW9uPzogKHJvd0RhdGE6IGFueSkgPT4gYm9vbGVhbjsgLy8gQSBmdW7Dp8OjbyBxdWUgY29udHJvbGEgYSBlZGnDp8Ojb1xyXG4gIGRpc2FibGVDb250cm9sQ2hlY2tib3hGdW5jdGlvbj86IChyb3dEYXRhOiBhbnksIHJvd05vZGU/OiBhbnkpID0+IGJvb2xlYW47IC8vIEEgZnVuw6fDo28gcXVlIGNvbnRyb2xhIGEgZWRpw6fDo29cclxuICBmaWVsZEdyb3VwQ29sb3JGdW5jdGlvbj86IChkYXRhOiBhbnkpID0+IHN0cmluZzsgLy8gTsOjbyDDqSB1dGlsaXphZG9cclxuICBkaXNhYmxlUm93PzogKHJvd0RhdGE6IGFueSkgPT4gYm9vbGVhbjtcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBBY3Rpb25zTG90ZUl0ZW0ge1xyXG4gIC8qKlxyXG4gICAqIElnbm9yYWRvIHBvciBlbnF1YW50b1xyXG4gICAqL1xyXG4gIHNldmVyaXR5PzogJ3ByaW1hcnknIHwgJ3NlY29uZGFyeScgfCAndGVydGlhcnknO1xyXG4gIGljb246IHN0cmluZztcclxuICBzaG93QWNvZXNMb3RlPzogYm9vbGVhbjtcclxuICB0b29sdGlwPzogVmFsdWVPckZuPHN0cmluZyB8IHVuZGVmaW5lZD47XHJcbiAgZGlzYWJsZWQ/OiBWYWx1ZU9yRm48Ym9vbGVhbiB8IHVuZGVmaW5lZD47XHJcbiAgdmlzaWJsZT86IFZhbHVlT3JGbjxib29sZWFuIHwgdW5kZWZpbmVkPjtcclxuICBjb21tYW5kPzogKCkgPT4gdm9pZDtcclxufVxyXG4iXX0=
@@ -1,10 +1,10 @@
1
1
  export class TablePaginate {
2
2
  constructor() {
3
3
  this.paginaInicial = 1;
4
- this.tamanhoPagina = 10;
4
+ this.tamanhoPagina = 15;
5
5
  this.termoPesquisa = '';
6
6
  this.ordenacao = '';
7
7
  this.ordernacaoGroup = { column: '', direction: '' };
8
8
  }
9
9
  }
10
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUucGFnaW5hdGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9rZWV2by1jb21wb25lbnRzL3NyYy9saWIvYXBpL2NvbXBvbmVudHMvdGFibGUvdGFibGUucGFnaW5hdGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxPQUFPLGFBQWE7SUFBMUI7UUFDRSxrQkFBYSxHQUFXLENBQUMsQ0FBQztRQUMxQixrQkFBYSxHQUFXLEVBQUUsQ0FBQztRQUMzQixrQkFBYSxHQUFXLEVBQUUsQ0FBQztRQUMzQixjQUFTLEdBQVcsRUFBRSxDQUFDO1FBQ3ZCLG9CQUFlLEdBQTJDLEVBQUUsTUFBTSxFQUFFLEVBQUUsRUFBRSxTQUFTLEVBQUUsRUFBRSxFQUFFLENBQUM7SUFDMUYsQ0FBQztDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNsYXNzIFRhYmxlUGFnaW5hdGUge1xyXG4gIHBhZ2luYUluaWNpYWw6IG51bWJlciA9IDE7XHJcbiAgdGFtYW5ob1BhZ2luYTogbnVtYmVyID0gMTA7XHJcbiAgdGVybW9QZXNxdWlzYTogc3RyaW5nID0gJyc7XHJcbiAgb3JkZW5hY2FvOiBzdHJpbmcgPSAnJztcclxuICBvcmRlcm5hY2FvR3JvdXA/OiB7IGNvbHVtbjogc3RyaW5nLCBkaXJlY3Rpb246IHN0cmluZyB9ID0geyBjb2x1bW46ICcnLCBkaXJlY3Rpb246ICcnIH07XHJcbn1cclxuIl19
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUucGFnaW5hdGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9rZWV2by1jb21wb25lbnRzL3NyYy9saWIvYXBpL2NvbXBvbmVudHMvdGFibGUvdGFibGUucGFnaW5hdGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxPQUFPLGFBQWE7SUFBMUI7UUFDRSxrQkFBYSxHQUFXLENBQUMsQ0FBQztRQUMxQixrQkFBYSxHQUFXLEVBQUUsQ0FBQztRQUMzQixrQkFBYSxHQUFXLEVBQUUsQ0FBQztRQUMzQixjQUFTLEdBQVcsRUFBRSxDQUFDO1FBQ3ZCLG9CQUFlLEdBQTJDLEVBQUUsTUFBTSxFQUFFLEVBQUUsRUFBRSxTQUFTLEVBQUUsRUFBRSxFQUFFLENBQUM7SUFDMUYsQ0FBQztDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNsYXNzIFRhYmxlUGFnaW5hdGUge1xyXG4gIHBhZ2luYUluaWNpYWw6IG51bWJlciA9IDE7XHJcbiAgdGFtYW5ob1BhZ2luYTogbnVtYmVyID0gMTU7XHJcbiAgdGVybW9QZXNxdWlzYTogc3RyaW5nID0gJyc7XHJcbiAgb3JkZW5hY2FvOiBzdHJpbmcgPSAnJztcclxuICBvcmRlcm5hY2FvR3JvdXA/OiB7IGNvbHVtbjogc3RyaW5nLCBkaXJlY3Rpb246IHN0cmluZyB9ID0geyBjb2x1bW46ICcnLCBkaXJlY3Rpb246ICcnIH07XHJcbn1cclxuIl19
@@ -9,6 +9,9 @@ export class CapitalizePipe {
9
9
  'I', 'II', 'III', 'IV', 'V', 'VI', 'VII', 'VIII', 'IX', 'X', 'XI', 'XII', 'XIII', 'XIV', 'XV',
10
10
  'XVI', 'XVII', 'XVIII', 'XIX', 'XX'
11
11
  ];
12
+ this.siglas = [
13
+ 'UI', 'UX', 'TI'
14
+ ];
12
15
  }
13
16
  transform(value) {
14
17
  if (!value)
@@ -17,6 +20,9 @@ export class CapitalizePipe {
17
20
  if (this.romanNumerals.includes(word.toUpperCase())) {
18
21
  return word;
19
22
  }
23
+ if (this.siglas.includes(word.toUpperCase())) {
24
+ return word;
25
+ }
20
26
  if (index !== 0 && this.prepositions.includes(word.toLocaleLowerCase())) {
21
27
  return word.toLocaleLowerCase();
22
28
  }
@@ -32,4 +38,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
32
38
  name: 'capitalize'
33
39
  }]
34
40
  }] });
35
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FwaXRhbGl6ZS5waXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2Vldm8tY29tcG9uZW50cy9zcmMvbGliL2FwaS9waXBlcy9jYXBpdGFsaXplLnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUM7O0FBS3BELE1BQU0sT0FBTyxjQUFjO0lBSDNCO1FBS1UsaUJBQVksR0FBYTtZQUMvQixJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUc7U0FDeEUsQ0FBQztRQUVNLGtCQUFhLEdBQWE7WUFDaEMsR0FBRyxFQUFFLElBQUksRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFLEdBQUcsRUFBRSxJQUFJLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUsR0FBRyxFQUFFLElBQUksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxJQUFJO1lBQzdGLEtBQUssRUFBRSxNQUFNLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRSxJQUFJO1NBQ3BDLENBQUM7S0FpQkg7SUFmQyxTQUFTLENBQUMsS0FBYTtRQUNyQixJQUFJLENBQUMsS0FBSztZQUFFLE9BQU8sS0FBSyxDQUFDO1FBRXpCLE9BQU8sS0FBSyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLEVBQUUsS0FBSyxFQUFFLEVBQUU7WUFDMUMsSUFBSSxJQUFJLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUMsRUFBRSxDQUFDO2dCQUNwRCxPQUFPLElBQUksQ0FBQztZQUNkLENBQUM7WUFFRCxJQUFJLEtBQUssS0FBSyxDQUFDLElBQUksSUFBSSxDQUFDLFlBQVksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLGlCQUFpQixFQUFFLENBQUMsRUFBRSxDQUFDO2dCQUN4RSxPQUFPLElBQUksQ0FBQyxpQkFBaUIsRUFBRSxDQUFDO1lBQ2xDLENBQUM7WUFFRCxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsaUJBQWlCLEVBQUUsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLGlCQUFpQixFQUFFLENBQUM7UUFDaEYsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ2YsQ0FBQzs4R0F6QlUsY0FBYzs0R0FBZCxjQUFjOzsyRkFBZCxjQUFjO2tCQUgxQixJQUFJO21CQUFDO29CQUNKLElBQUksRUFBRSxZQUFZO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBQaXBlKHtcclxuICBuYW1lOiAnY2FwaXRhbGl6ZSdcclxufSlcclxuZXhwb3J0IGNsYXNzIENhcGl0YWxpemVQaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XHJcblxyXG4gIHByaXZhdGUgcHJlcG9zaXRpb25zOiBzdHJpbmdbXSA9IFtcclxuICAgICdkZScsICdkYScsICdkbycsICdlbScsICdubycsICduYScsICdwYXJhJywgJ3BvcicsICdjb20nLCAnYScsICdvJywgJ2UnXHJcbiAgXTtcclxuXHJcbiAgcHJpdmF0ZSByb21hbk51bWVyYWxzOiBzdHJpbmdbXSA9IFtcclxuICAgICdJJywgJ0lJJywgJ0lJSScsICdJVicsICdWJywgJ1ZJJywgJ1ZJSScsICdWSUlJJywgJ0lYJywgJ1gnLCAnWEknLCAnWElJJywgJ1hJSUknLCAnWElWJywgJ1hWJywgXHJcbiAgICAnWFZJJywgJ1hWSUknLCAnWFZJSUknLCAnWElYJywgJ1hYJ1xyXG4gIF07XHJcblxyXG4gIHRyYW5zZm9ybSh2YWx1ZTogc3RyaW5nKTogc3RyaW5nIHtcclxuICAgIGlmICghdmFsdWUpIHJldHVybiB2YWx1ZTtcclxuXHJcbiAgICByZXR1cm4gdmFsdWUuc3BsaXQoJyAnKS5tYXAoKHdvcmQsIGluZGV4KSA9PiB7XHJcbiAgICAgIGlmICh0aGlzLnJvbWFuTnVtZXJhbHMuaW5jbHVkZXMod29yZC50b1VwcGVyQ2FzZSgpKSkge1xyXG4gICAgICAgIHJldHVybiB3b3JkO1xyXG4gICAgICB9XHJcblxyXG4gICAgICBpZiAoaW5kZXggIT09IDAgJiYgdGhpcy5wcmVwb3NpdGlvbnMuaW5jbHVkZXMod29yZC50b0xvY2FsZUxvd2VyQ2FzZSgpKSkge1xyXG4gICAgICAgIHJldHVybiB3b3JkLnRvTG9jYWxlTG93ZXJDYXNlKCk7XHJcbiAgICAgIH1cclxuXHJcbiAgICAgIHJldHVybiB3b3JkLmNoYXJBdCgwKS50b0xvY2FsZVVwcGVyQ2FzZSgpICsgd29yZC5zbGljZSgxKS50b0xvY2FsZUxvd2VyQ2FzZSgpO1xyXG4gICAgfSkuam9pbignICcpO1xyXG4gIH1cclxufVxyXG4iXX0=
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FwaXRhbGl6ZS5waXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2Vldm8tY29tcG9uZW50cy9zcmMvbGliL2FwaS9waXBlcy9jYXBpdGFsaXplLnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUM7O0FBS3BELE1BQU0sT0FBTyxjQUFjO0lBSDNCO1FBS1UsaUJBQVksR0FBYTtZQUMvQixJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxHQUFHLEVBQUUsR0FBRyxFQUFFLEdBQUc7U0FDeEUsQ0FBQztRQUVNLGtCQUFhLEdBQWE7WUFDaEMsR0FBRyxFQUFFLElBQUksRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFLEdBQUcsRUFBRSxJQUFJLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUsR0FBRyxFQUFFLElBQUksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBRSxJQUFJO1lBQzdGLEtBQUssRUFBRSxNQUFNLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRSxJQUFJO1NBQ3BDLENBQUM7UUFFTSxXQUFNLEdBQWE7WUFDekIsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJO1NBQ2pCLENBQUM7S0FxQkg7SUFuQkMsU0FBUyxDQUFDLEtBQWE7UUFDckIsSUFBSSxDQUFDLEtBQUs7WUFBRSxPQUFPLEtBQUssQ0FBQztRQUV6QixPQUFPLEtBQUssQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxFQUFFLEtBQUssRUFBRSxFQUFFO1lBQzFDLElBQUksSUFBSSxDQUFDLGFBQWEsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDLEVBQUUsQ0FBQztnQkFDcEQsT0FBTyxJQUFJLENBQUM7WUFDZCxDQUFDO1lBRUQsSUFBSSxJQUFJLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUMsRUFBRSxDQUFDO2dCQUM3QyxPQUFPLElBQUksQ0FBQztZQUNkLENBQUM7WUFFRCxJQUFJLEtBQUssS0FBSyxDQUFDLElBQUksSUFBSSxDQUFDLFlBQVksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLGlCQUFpQixFQUFFLENBQUMsRUFBRSxDQUFDO2dCQUN4RSxPQUFPLElBQUksQ0FBQyxpQkFBaUIsRUFBRSxDQUFDO1lBQ2xDLENBQUM7WUFFRCxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsaUJBQWlCLEVBQUUsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLGlCQUFpQixFQUFFLENBQUM7UUFDaEYsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ2YsQ0FBQzs4R0FqQ1UsY0FBYzs0R0FBZCxjQUFjOzsyRkFBZCxjQUFjO2tCQUgxQixJQUFJO21CQUFDO29CQUNKLElBQUksRUFBRSxZQUFZO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBQaXBlKHtcclxuICBuYW1lOiAnY2FwaXRhbGl6ZSdcclxufSlcclxuZXhwb3J0IGNsYXNzIENhcGl0YWxpemVQaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XHJcblxyXG4gIHByaXZhdGUgcHJlcG9zaXRpb25zOiBzdHJpbmdbXSA9IFtcclxuICAgICdkZScsICdkYScsICdkbycsICdlbScsICdubycsICduYScsICdwYXJhJywgJ3BvcicsICdjb20nLCAnYScsICdvJywgJ2UnXHJcbiAgXTtcclxuXHJcbiAgcHJpdmF0ZSByb21hbk51bWVyYWxzOiBzdHJpbmdbXSA9IFtcclxuICAgICdJJywgJ0lJJywgJ0lJSScsICdJVicsICdWJywgJ1ZJJywgJ1ZJSScsICdWSUlJJywgJ0lYJywgJ1gnLCAnWEknLCAnWElJJywgJ1hJSUknLCAnWElWJywgJ1hWJywgXHJcbiAgICAnWFZJJywgJ1hWSUknLCAnWFZJSUknLCAnWElYJywgJ1hYJ1xyXG4gIF07XHJcblxyXG4gIHByaXZhdGUgc2lnbGFzOiBzdHJpbmdbXSA9IFtcclxuICAgICdVSScsICdVWCcsICdUSSdcclxuICBdO1xyXG5cclxuICB0cmFuc2Zvcm0odmFsdWU6IHN0cmluZyk6IHN0cmluZyB7XHJcbiAgICBpZiAoIXZhbHVlKSByZXR1cm4gdmFsdWU7XHJcblxyXG4gICAgcmV0dXJuIHZhbHVlLnNwbGl0KCcgJykubWFwKCh3b3JkLCBpbmRleCkgPT4ge1xyXG4gICAgICBpZiAodGhpcy5yb21hbk51bWVyYWxzLmluY2x1ZGVzKHdvcmQudG9VcHBlckNhc2UoKSkpIHtcclxuICAgICAgICByZXR1cm4gd29yZDtcclxuICAgICAgfVxyXG5cclxuICAgICAgaWYgKHRoaXMuc2lnbGFzLmluY2x1ZGVzKHdvcmQudG9VcHBlckNhc2UoKSkpIHtcclxuICAgICAgICByZXR1cm4gd29yZDtcclxuICAgICAgfVxyXG5cclxuICAgICAgaWYgKGluZGV4ICE9PSAwICYmIHRoaXMucHJlcG9zaXRpb25zLmluY2x1ZGVzKHdvcmQudG9Mb2NhbGVMb3dlckNhc2UoKSkpIHtcclxuICAgICAgICByZXR1cm4gd29yZC50b0xvY2FsZUxvd2VyQ2FzZSgpO1xyXG4gICAgICB9XHJcblxyXG4gICAgICByZXR1cm4gd29yZC5jaGFyQXQoMCkudG9Mb2NhbGVVcHBlckNhc2UoKSArIHdvcmQuc2xpY2UoMSkudG9Mb2NhbGVMb3dlckNhc2UoKTtcclxuICAgIH0pLmpvaW4oJyAnKTtcclxuICB9XHJcbn1cclxuIl19
@@ -24,6 +24,7 @@ export class KvContentViewerComponent {
24
24
  this.isSelected = false;
25
25
  this.visualizadorDocumentos = false;
26
26
  this.indvisualizado = false;
27
+ this.btnTelaCheia = false;
27
28
  this.keyVisualizado = 'indvisualizado';
28
29
  // #endregion
29
30
  // #region Outputs
@@ -46,6 +47,45 @@ export class KvContentViewerComponent {
46
47
  this.arquivoPreview.set(arquivo);
47
48
  this.onSelectFile.emit(arquivo);
48
49
  }
50
+ alternarTelaCheia() {
51
+ const element = document.getElementById('fullscreenDiv');
52
+ const button = document.getElementById('fullscreenBtn');
53
+ // Verifica se os elementos existem
54
+ if (element && button) {
55
+ if (!document.fullscreenElement) {
56
+ // Expandir para tela cheia
57
+ if (element.requestFullscreen) {
58
+ element.requestFullscreen();
59
+ }
60
+ else if (element.mozRequestFullScreen) { // Para Firefox
61
+ element.mozRequestFullScreen();
62
+ }
63
+ else if (element.webkitRequestFullscreen) { // Para Chrome, Safari e Opera
64
+ element.webkitRequestFullscreen();
65
+ }
66
+ else if (element.msRequestFullscreen) { // Para IE/Edge
67
+ element.msRequestFullscreen();
68
+ }
69
+ button.textContent = 'close_fullscreen';
70
+ }
71
+ else {
72
+ // Sair da tela cheia
73
+ if (document.exitFullscreen) {
74
+ document.exitFullscreen();
75
+ }
76
+ else if (document.mozCancelFullScreen) { // Para Firefox
77
+ document.mozCancelFullScreen();
78
+ }
79
+ else if (document.webkitExitFullscreen) { // Para Chrome, Safari e Opera
80
+ document.webkitExitFullscreen();
81
+ }
82
+ else if (document.msExitFullscreen) { // Para IE/Edge
83
+ document.msExitFullscreen();
84
+ }
85
+ button.textContent = 'open_in_full';
86
+ }
87
+ }
88
+ }
49
89
  scrollHandler($event) {
50
90
  const element = $event.target;
51
91
  //se o escroll chegar até o final
@@ -55,11 +95,11 @@ export class KvContentViewerComponent {
55
95
  }
56
96
  }
57
97
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvContentViewerComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
58
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: KvContentViewerComponent, selector: "kv-content-viewer", inputs: { dataSource: { classPropertyName: "dataSource", publicName: "dataSource", isSignal: true, isRequired: false, transformFunction: null }, arquivo: { classPropertyName: "arquivo", publicName: "arquivo", isSignal: true, isRequired: false, transformFunction: null }, type: { classPropertyName: "type", publicName: "type", isSignal: true, isRequired: false, transformFunction: null }, blob: { classPropertyName: "blob", publicName: "blob", isSignal: true, isRequired: false, transformFunction: null }, ekpContent: { classPropertyName: "ekpContent", publicName: "ekpContent", isSignal: true, isRequired: false, transformFunction: null }, extencaoDocumento: { classPropertyName: "extencaoDocumento", publicName: "extencaoDocumento", isSignal: false, isRequired: false, transformFunction: null }, totalRecords: { classPropertyName: "totalRecords", publicName: "totalRecords", isSignal: false, isRequired: false, transformFunction: null }, visualizadorDocumentos: { classPropertyName: "visualizadorDocumentos", publicName: "visualizadorDocumentos", isSignal: false, isRequired: false, transformFunction: null }, cardTemplate: { classPropertyName: "cardTemplate", publicName: "cardTemplate", isSignal: false, isRequired: false, transformFunction: null }, contentTemplate: { classPropertyName: "contentTemplate", publicName: "contentTemplate", isSignal: false, isRequired: false, transformFunction: null }, noDocumentSelectedTemplate: { classPropertyName: "noDocumentSelectedTemplate", publicName: "noDocumentSelectedTemplate", isSignal: false, isRequired: false, transformFunction: null }, noDocumentListTemplate: { classPropertyName: "noDocumentListTemplate", publicName: "noDocumentListTemplate", isSignal: false, isRequired: false, transformFunction: null }, indvisualizado: { classPropertyName: "indvisualizado", publicName: "indvisualizado", isSignal: false, isRequired: false, transformFunction: null } }, outputs: { onScrollHandler: "onScrollHandler", onSelectFile: "onSelectFile" }, ngImport: i0, template: "<div class=\"flex flex-column md:flex-row gap-2 mt-3 custom-max-height\" style=\"height: 1000vh;\">\r\n <!-- Lista de documentos -->\r\n <div\r\n class=\"card-perfil overflow-x-hidden\"\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; max-height: calc(100vh - 100px);\"\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 style=\"min-height: 5rem\"\r\n (click)=\"visualizarPreview(option)\"\r\n [ngClass]=\"{\r\n 'card-naoVisualizado': !isVisualizado(option),\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 </div>\r\n\r\n <ng-template #emptyDocumentList>\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\u00EDvel.</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: 0; 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 class=\"card-perfil col-12 md:col-8 lg:col-9\" style=\"position: relative\">\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 >\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 ></div>\r\n </ng-container>\r\n } @else {\r\n <ng-container *ngIf=\"arquivoPreview(); else noDocumentSelected\">\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n contentTemplate;\r\n context: { $implicit: arquivoPreview() }\r\n \"\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%\"\r\n >\r\n <p class=\"text-center text-gray-500\">\r\n Selecione um arquivo para visualiza\u00E7\u00E3o\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</div>\r\n", styles: ["@charset \"UTF-8\";.farol-statuspublicacao{margin-right:.5rem;width:.35rem;border-radius:1rem;-webkit-border-radius:1rem;-moz-border-radius:1rem;-ms-border-radius:1rem;-o-border-radius:1rem}:host ::ng-deep .p-sidebar{border-radius:5px;position:absolute;height:var(--sidebar-height)}:host ::ng-deep .p-sidebar .p-sidebar-content{overflow:auto;border:1px solid #e5e7eb;border-radius:5px;margin-top:1rem}.card-perfil{border:1.5px solid #CBD5E1;background:#fff;border-radius:6px;max-height:100%}:host ::ng-deep .p-fieldset .p-fieldset-content{padding-bottom:0}:host ::ng-deep .p-sidebar .p-sidebar-close{display:none}.card-normal{border:1.5px solid #CBD5E1}.card-naoVisualizado{border-left:4px solid #e6671f!important}.parent-container{height:100%;display:flex;flex-direction:column}.file-viewer{margin:auto}.ekp-content{min-height:20rem;padding:1rem;overflow-y:auto;border-radius:5px}ngx-loading{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1000}.card{transition:all .3s ease;border:1px solid transparent}.card-normal:hover{border:1px solid #a9a9a9;box-shadow:0 4px 8px #0000001a}.card-selected{background-color:#f0f0f0;border:1px solid #c0c0c0;box-shadow:0 6px 12px #00000026;transform:scale(1.02)}.loading-spinner{display:flex;align-items:center;justify-content:center;height:100%;font-size:1.5rem;color:#666}#html-content{width:100%;height:100%;overflow-y:auto}:host ::ng-deep .list-card-button .kv-button{width:22px;height:22px}:host ::ng-deep .list-card-button .kv-button .material-symbols-outlined.only-icon.icon-normal[_ngcontent-ng-c4083184952]{font-size:1rem}.custom-max-height{max-height:calc(100vh - 300px)}@media (max-height: 915px){.custom-max-height{max-height:94%}}@media (max-height: 805px){.custom-max-height{max-height:90%}}@media (max-height: 720px){.custom-max-height{max-height:85%}}.download-icon{font-size:20px;cursor:pointer;transition:transform .3s ease,color .3s ease}.download-icon:hover{color:#0f6cbd;transform:scale(1.2)}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.KvFileViewerNovoComponent, selector: "kv-file-viewer-novo", inputs: ["arquivo", "type", "blob", "width", "height"] }, { kind: "component", type: i3.NgxLoadingComponent, selector: "ngx-loading", inputs: ["show", "config", "template"] }] }); }
98
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: KvContentViewerComponent, selector: "kv-content-viewer", inputs: { dataSource: { classPropertyName: "dataSource", publicName: "dataSource", isSignal: true, isRequired: false, transformFunction: null }, arquivo: { classPropertyName: "arquivo", publicName: "arquivo", isSignal: true, isRequired: false, transformFunction: null }, type: { classPropertyName: "type", publicName: "type", isSignal: true, isRequired: false, transformFunction: null }, blob: { classPropertyName: "blob", publicName: "blob", isSignal: true, isRequired: false, transformFunction: null }, ekpContent: { classPropertyName: "ekpContent", publicName: "ekpContent", isSignal: true, isRequired: false, transformFunction: null }, extencaoDocumento: { classPropertyName: "extencaoDocumento", publicName: "extencaoDocumento", isSignal: false, isRequired: false, transformFunction: null }, totalRecords: { classPropertyName: "totalRecords", publicName: "totalRecords", isSignal: false, isRequired: false, transformFunction: null }, visualizadorDocumentos: { classPropertyName: "visualizadorDocumentos", publicName: "visualizadorDocumentos", isSignal: false, isRequired: false, transformFunction: null }, cardTemplate: { classPropertyName: "cardTemplate", publicName: "cardTemplate", isSignal: false, isRequired: false, transformFunction: null }, contentTemplate: { classPropertyName: "contentTemplate", publicName: "contentTemplate", isSignal: false, isRequired: false, transformFunction: null }, noDocumentSelectedTemplate: { classPropertyName: "noDocumentSelectedTemplate", publicName: "noDocumentSelectedTemplate", isSignal: false, isRequired: false, transformFunction: null }, noDocumentListTemplate: { classPropertyName: "noDocumentListTemplate", publicName: "noDocumentListTemplate", isSignal: false, isRequired: false, transformFunction: null }, indvisualizado: { classPropertyName: "indvisualizado", publicName: "indvisualizado", isSignal: false, isRequired: false, transformFunction: null }, btnTelaCheia: { classPropertyName: "btnTelaCheia", publicName: "btnTelaCheia", isSignal: false, isRequired: false, transformFunction: null } }, outputs: { onScrollHandler: "onScrollHandler", onSelectFile: "onSelectFile" }, ngImport: i0, template: "<div class=\"flex flex-column md:flex-row gap-2 mt-3 custom-max-height\" style=\"height: 1000vh;\">\r\n <!-- Lista de documentos -->\r\n <div\r\n class=\"card-perfil overflow-x-hidden\"\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; max-height: calc(100vh - 100px);\"\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 style=\"min-height: 5rem\"\r\n (click)=\"visualizarPreview(option)\"\r\n [ngClass]=\"{\r\n 'card-naoVisualizado': !isVisualizado(option),\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 </div>\r\n\r\n <ng-template #emptyDocumentList>\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\u00EDvel.</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: 0; 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\">\r\n @if(btnTelaCheia)\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 }\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 >\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 ></div>\r\n </ng-container>\r\n } @else {\r\n <ng-container *ngIf=\"arquivoPreview(); else noDocumentSelected\">\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n contentTemplate;\r\n context: { $implicit: arquivoPreview() }\r\n \"\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%\"\r\n >\r\n <p class=\"text-center text-gray-500\">\r\n Selecione um arquivo para visualiza\u00E7\u00E3o\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</div>\r\n", styles: ["@charset \"UTF-8\";.farol-statuspublicacao{margin-right:.5rem;width:.35rem;border-radius:1rem;-webkit-border-radius:1rem;-moz-border-radius:1rem;-ms-border-radius:1rem;-o-border-radius:1rem}:host ::ng-deep .p-sidebar{border-radius:5px;position:absolute;height:var(--sidebar-height)}:host ::ng-deep .p-sidebar .p-sidebar-content{overflow:auto;border:1px solid #e5e7eb;border-radius:5px;margin-top:1rem}.card-perfil{border:1.5px solid #CBD5E1;background:#fff;border-radius:6px;max-height:100%}:host ::ng-deep .p-fieldset .p-fieldset-content{padding-bottom:0}:host ::ng-deep .p-sidebar .p-sidebar-close{display:none}.card-normal{border:1.5px solid #CBD5E1}.card-naoVisualizado{border-left:4px solid #e6671f!important}.parent-container{height:100%;display:flex;flex-direction:column}.file-viewer{margin:auto}.ekp-content{min-height:20rem;padding:1rem;overflow-y:auto;border-radius:5px}ngx-loading{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1000}.card{transition:all .3s ease;border:1px solid transparent}.card-normal:hover{border:1px solid #a9a9a9;box-shadow:0 4px 8px #0000001a}.card-selected{background-color:#f0f0f0;border:1px solid #c0c0c0;box-shadow:0 6px 12px #00000026;transform:scale(1.02)}.loading-spinner{display:flex;align-items:center;justify-content:center;height:100%;font-size:1.5rem;color:#666}#html-content{width:100%;height:100%;overflow-y:auto}:host ::ng-deep .list-card-button .kv-button{width:22px;height:22px}:host ::ng-deep .list-card-button .kv-button .material-symbols-outlined.only-icon.icon-normal[_ngcontent-ng-c4083184952]{font-size:1rem}.custom-max-height{max-height:calc(100vh - 300px)}@media (max-height: 915px){.custom-max-height{max-height:94%}}@media (max-height: 805px){.custom-max-height{max-height:90%}}@media (max-height: 720px){.custom-max-height{max-height:85%}}.download-icon{font-size:20px;cursor:pointer;transition:transform .3s ease,color .3s ease}.download-icon:hover{color:#0f6cbd;transform:scale(1.2)}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.KvFileViewerNovoComponent, selector: "kv-file-viewer-novo", inputs: ["arquivo", "type", "blob", "width", "height"] }, { kind: "component", type: i3.NgxLoadingComponent, selector: "ngx-loading", inputs: ["show", "config", "template"] }] }); }
59
99
  }
60
100
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvContentViewerComponent, decorators: [{
61
101
  type: Component,
62
- args: [{ selector: 'kv-content-viewer', template: "<div class=\"flex flex-column md:flex-row gap-2 mt-3 custom-max-height\" style=\"height: 1000vh;\">\r\n <!-- Lista de documentos -->\r\n <div\r\n class=\"card-perfil overflow-x-hidden\"\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; max-height: calc(100vh - 100px);\"\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 style=\"min-height: 5rem\"\r\n (click)=\"visualizarPreview(option)\"\r\n [ngClass]=\"{\r\n 'card-naoVisualizado': !isVisualizado(option),\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 </div>\r\n\r\n <ng-template #emptyDocumentList>\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\u00EDvel.</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: 0; 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 class=\"card-perfil col-12 md:col-8 lg:col-9\" style=\"position: relative\">\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 >\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 ></div>\r\n </ng-container>\r\n } @else {\r\n <ng-container *ngIf=\"arquivoPreview(); else noDocumentSelected\">\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n contentTemplate;\r\n context: { $implicit: arquivoPreview() }\r\n \"\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%\"\r\n >\r\n <p class=\"text-center text-gray-500\">\r\n Selecione um arquivo para visualiza\u00E7\u00E3o\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</div>\r\n", styles: ["@charset \"UTF-8\";.farol-statuspublicacao{margin-right:.5rem;width:.35rem;border-radius:1rem;-webkit-border-radius:1rem;-moz-border-radius:1rem;-ms-border-radius:1rem;-o-border-radius:1rem}:host ::ng-deep .p-sidebar{border-radius:5px;position:absolute;height:var(--sidebar-height)}:host ::ng-deep .p-sidebar .p-sidebar-content{overflow:auto;border:1px solid #e5e7eb;border-radius:5px;margin-top:1rem}.card-perfil{border:1.5px solid #CBD5E1;background:#fff;border-radius:6px;max-height:100%}:host ::ng-deep .p-fieldset .p-fieldset-content{padding-bottom:0}:host ::ng-deep .p-sidebar .p-sidebar-close{display:none}.card-normal{border:1.5px solid #CBD5E1}.card-naoVisualizado{border-left:4px solid #e6671f!important}.parent-container{height:100%;display:flex;flex-direction:column}.file-viewer{margin:auto}.ekp-content{min-height:20rem;padding:1rem;overflow-y:auto;border-radius:5px}ngx-loading{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1000}.card{transition:all .3s ease;border:1px solid transparent}.card-normal:hover{border:1px solid #a9a9a9;box-shadow:0 4px 8px #0000001a}.card-selected{background-color:#f0f0f0;border:1px solid #c0c0c0;box-shadow:0 6px 12px #00000026;transform:scale(1.02)}.loading-spinner{display:flex;align-items:center;justify-content:center;height:100%;font-size:1.5rem;color:#666}#html-content{width:100%;height:100%;overflow-y:auto}:host ::ng-deep .list-card-button .kv-button{width:22px;height:22px}:host ::ng-deep .list-card-button .kv-button .material-symbols-outlined.only-icon.icon-normal[_ngcontent-ng-c4083184952]{font-size:1rem}.custom-max-height{max-height:calc(100vh - 300px)}@media (max-height: 915px){.custom-max-height{max-height:94%}}@media (max-height: 805px){.custom-max-height{max-height:90%}}@media (max-height: 720px){.custom-max-height{max-height:85%}}.download-icon{font-size:20px;cursor:pointer;transition:transform .3s ease,color .3s ease}.download-icon:hover{color:#0f6cbd;transform:scale(1.2)}\n"] }]
102
+ args: [{ selector: 'kv-content-viewer', template: "<div class=\"flex flex-column md:flex-row gap-2 mt-3 custom-max-height\" style=\"height: 1000vh;\">\r\n <!-- Lista de documentos -->\r\n <div\r\n class=\"card-perfil overflow-x-hidden\"\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; max-height: calc(100vh - 100px);\"\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 style=\"min-height: 5rem\"\r\n (click)=\"visualizarPreview(option)\"\r\n [ngClass]=\"{\r\n 'card-naoVisualizado': !isVisualizado(option),\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 </div>\r\n\r\n <ng-template #emptyDocumentList>\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\u00EDvel.</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: 0; 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\">\r\n @if(btnTelaCheia)\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 }\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 >\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 ></div>\r\n </ng-container>\r\n } @else {\r\n <ng-container *ngIf=\"arquivoPreview(); else noDocumentSelected\">\r\n <ng-container\r\n *ngTemplateOutlet=\"\r\n contentTemplate;\r\n context: { $implicit: arquivoPreview() }\r\n \"\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%\"\r\n >\r\n <p class=\"text-center text-gray-500\">\r\n Selecione um arquivo para visualiza\u00E7\u00E3o\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</div>\r\n", styles: ["@charset \"UTF-8\";.farol-statuspublicacao{margin-right:.5rem;width:.35rem;border-radius:1rem;-webkit-border-radius:1rem;-moz-border-radius:1rem;-ms-border-radius:1rem;-o-border-radius:1rem}:host ::ng-deep .p-sidebar{border-radius:5px;position:absolute;height:var(--sidebar-height)}:host ::ng-deep .p-sidebar .p-sidebar-content{overflow:auto;border:1px solid #e5e7eb;border-radius:5px;margin-top:1rem}.card-perfil{border:1.5px solid #CBD5E1;background:#fff;border-radius:6px;max-height:100%}:host ::ng-deep .p-fieldset .p-fieldset-content{padding-bottom:0}:host ::ng-deep .p-sidebar .p-sidebar-close{display:none}.card-normal{border:1.5px solid #CBD5E1}.card-naoVisualizado{border-left:4px solid #e6671f!important}.parent-container{height:100%;display:flex;flex-direction:column}.file-viewer{margin:auto}.ekp-content{min-height:20rem;padding:1rem;overflow-y:auto;border-radius:5px}ngx-loading{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1000}.card{transition:all .3s ease;border:1px solid transparent}.card-normal:hover{border:1px solid #a9a9a9;box-shadow:0 4px 8px #0000001a}.card-selected{background-color:#f0f0f0;border:1px solid #c0c0c0;box-shadow:0 6px 12px #00000026;transform:scale(1.02)}.loading-spinner{display:flex;align-items:center;justify-content:center;height:100%;font-size:1.5rem;color:#666}#html-content{width:100%;height:100%;overflow-y:auto}:host ::ng-deep .list-card-button .kv-button{width:22px;height:22px}:host ::ng-deep .list-card-button .kv-button .material-symbols-outlined.only-icon.icon-normal[_ngcontent-ng-c4083184952]{font-size:1rem}.custom-max-height{max-height:calc(100vh - 300px)}@media (max-height: 915px){.custom-max-height{max-height:94%}}@media (max-height: 805px){.custom-max-height{max-height:90%}}@media (max-height: 720px){.custom-max-height{max-height:85%}}.download-icon{font-size:20px;cursor:pointer;transition:transform .3s ease,color .3s ease}.download-icon:hover{color:#0f6cbd;transform:scale(1.2)}\n"] }]
63
103
  }], propDecorators: { extencaoDocumento: [{
64
104
  type: Input
65
105
  }], totalRecords: [{
@@ -76,9 +116,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
76
116
  type: Input
77
117
  }], indvisualizado: [{
78
118
  type: Input
119
+ }], btnTelaCheia: [{
120
+ type: Input
79
121
  }], onScrollHandler: [{
80
122
  type: Output
81
123
  }], onSelectFile: [{
82
124
  type: Output
83
125
  }] } });
84
- //# 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() indvisualizado: 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): void {\r\n  arquivo[this.keyVisualizado] = true;\r\n\r\n  this.arquivoPreview.set(arquivo);\r\n  this.onSelectFile.emit(arquivo);\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: 1000vh;\">\r\n  <!-- Lista de documentos -->\r\n  <div\r\n    class=\"card-perfil overflow-x-hidden\"\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; max-height: calc(100vh - 100px);\"\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        style=\"min-height: 5rem\"\r\n        (click)=\"visualizarPreview(option)\"\r\n        [ngClass]=\"{\r\n    'card-naoVisualizado': !isVisualizado(option),\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    </div>\r\n\r\n    <ng-template #emptyDocumentList>\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: 0; 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 class=\"card-perfil col-12 md:col-8 lg:col-9\" style=\"position: relative\">\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        >\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        ></div>\r\n      </ng-container>\r\n    } @else {\r\n      <ng-container *ngIf=\"arquivoPreview(); else noDocumentSelected\">\r\n        <ng-container\r\n          *ngTemplateOutlet=\"\r\n            contentTemplate;\r\n            context: { $implicit: arquivoPreview() }\r\n          \"\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%\"\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</div>\r\n"]}
126
+ //# 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() indvisualizado: boolean = false;\r\n@Input() btnTelaCheia: 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): void {\r\n  arquivo[this.keyVisualizado] = true;\r\n\r\n  this.arquivoPreview.set(arquivo);\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\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: 1000vh;\">\r\n  <!-- Lista de documentos -->\r\n  <div\r\n    class=\"card-perfil overflow-x-hidden\"\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; max-height: calc(100vh - 100px);\"\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        style=\"min-height: 5rem\"\r\n        (click)=\"visualizarPreview(option)\"\r\n        [ngClass]=\"{\r\n    'card-naoVisualizado': !isVisualizado(option),\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    </div>\r\n\r\n    <ng-template #emptyDocumentList>\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: 0; 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\">\r\n    @if(btnTelaCheia)\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    }\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        >\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        ></div>\r\n      </ng-container>\r\n    } @else {\r\n      <ng-container *ngIf=\"arquivoPreview(); else noDocumentSelected\">\r\n        <ng-container\r\n          *ngTemplateOutlet=\"\r\n            contentTemplate;\r\n            context: { $implicit: arquivoPreview() }\r\n          \"\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%\"\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</div>\r\n"]}
@@ -15,14 +15,14 @@ export class DropdownMasterComponent extends BaseComponentDropDownExternal {
15
15
  return of(this.masters || []);
16
16
  }
17
17
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: DropdownMasterComponent, deps: [{ token: i1.ComponentService }, { token: i2.DialogService }], target: i0.ɵɵFactoryTarget.Component }); }
18
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.8", type: DropdownMasterComponent, selector: "dropdown-master", inputs: { formControlName: "formControlName", masters: "masters" }, providers: ComponentProviders(DropdownMasterComponent), usesInheritance: true, ngImport: i0, template: "<div [formGroup]=\"formGroup\">\r\n <kv-dropdown\r\n componentId=\"idmaster\"\r\n label=\"Licen\u00E7a\"\r\n optionLabel=\"idmasternome\"\r\n optionValue=\"idmaster\"\r\n [options]=\"options\"\r\n [filter]=\"true\"\r\n [filteredOptions]=\"filteredOptions\"\r\n [formControlName]=\"formControlName\"\r\n [loading]=\"loading\"\r\n [showClear]=\"false\"\r\n (onSelectionChange)=\"onInputChange($event)\"\r\n (onSelectionValue)=\"onInputChange($event)\">\r\n </kv-dropdown>\r\n</div>", styles: [""], dependencies: [{ kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "component", type: i4.KvDropdownComponent, selector: "kv-dropdown", inputs: ["filterPlaceholder", "placeholder", "dropDowValue", "itemTemplate", "selectedItemTemplate", "virtualScroll", "virtualScrollItemSize", "appendTo"], outputs: ["onLazyLoad"] }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }] }); }
18
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.8", type: DropdownMasterComponent, selector: "dropdown-master", inputs: { formControlName: "formControlName", masters: "masters" }, providers: ComponentProviders(DropdownMasterComponent), usesInheritance: true, ngImport: i0, template: "<div [formGroup]=\"formGroup\">\r\n <kv-dropdown\r\n componentId=\"idmaster\"\r\n optionLabel=\"idmasternome\"\r\n optionValue=\"idmaster\"\r\n [options]=\"options\"\r\n [filter]=\"true\"\r\n [filteredOptions]=\"filteredOptions\"\r\n [formControlName]=\"formControlName\"\r\n [loading]=\"loading\"\r\n [showClear]=\"false\"\r\n (onSelectionChange)=\"onInputChange($event)\"\r\n (onSelectionValue)=\"onInputChange($event)\">\r\n </kv-dropdown>\r\n</div>", styles: [""], dependencies: [{ kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "component", type: i4.KvDropdownComponent, selector: "kv-dropdown", inputs: ["filterPlaceholder", "placeholder", "dropDowValue", "itemTemplate", "selectedItemTemplate", "virtualScroll", "virtualScrollItemSize", "appendTo"], outputs: ["onLazyLoad"] }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }] }); }
19
19
  }
20
20
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: DropdownMasterComponent, decorators: [{
21
21
  type: Component,
22
- args: [{ selector: 'dropdown-master', providers: ComponentProviders(DropdownMasterComponent), template: "<div [formGroup]=\"formGroup\">\r\n <kv-dropdown\r\n componentId=\"idmaster\"\r\n label=\"Licen\u00E7a\"\r\n optionLabel=\"idmasternome\"\r\n optionValue=\"idmaster\"\r\n [options]=\"options\"\r\n [filter]=\"true\"\r\n [filteredOptions]=\"filteredOptions\"\r\n [formControlName]=\"formControlName\"\r\n [loading]=\"loading\"\r\n [showClear]=\"false\"\r\n (onSelectionChange)=\"onInputChange($event)\"\r\n (onSelectionValue)=\"onInputChange($event)\">\r\n </kv-dropdown>\r\n</div>" }]
22
+ args: [{ selector: 'dropdown-master', providers: ComponentProviders(DropdownMasterComponent), template: "<div [formGroup]=\"formGroup\">\r\n <kv-dropdown\r\n componentId=\"idmaster\"\r\n optionLabel=\"idmasternome\"\r\n optionValue=\"idmaster\"\r\n [options]=\"options\"\r\n [filter]=\"true\"\r\n [filteredOptions]=\"filteredOptions\"\r\n [formControlName]=\"formControlName\"\r\n [loading]=\"loading\"\r\n [showClear]=\"false\"\r\n (onSelectionChange)=\"onInputChange($event)\"\r\n (onSelectionValue)=\"onInputChange($event)\">\r\n </kv-dropdown>\r\n</div>" }]
23
23
  }], ctorParameters: () => [{ type: i1.ComponentService }, { type: i2.DialogService }], propDecorators: { formControlName: [{
24
24
  type: Input
25
25
  }], masters: [{
26
26
  type: Input
27
27
  }] } });
28
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24tbWFzdGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tlZXZvLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2t2LWxheW91dC9kcm9wZG93bi1tYXN0ZXIvZHJvcGRvd24tbWFzdGVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tlZXZvLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2t2LWxheW91dC9kcm9wZG93bi1tYXN0ZXIvZHJvcGRvd24tbWFzdGVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxTQUFTLEVBQ1QsS0FBSyxFQUNOLE1BQU0sZUFBZSxDQUFDO0FBSXZCLE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDMUIsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sMENBQTBDLENBQUM7QUFDOUUsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sK0RBQStELENBQUM7Ozs7OztBQVM5RyxNQUFNLE9BQU8sdUJBQXdCLFNBQVEsNkJBQTZCO0lBS3hFLFlBQ0UsZ0JBQWtDLEVBQ2xDLGFBQTRCO1FBRTVCLEtBQUssQ0FBQyxnQkFBZ0IsRUFBRSxhQUFhLENBQUMsQ0FBQztJQUN6QyxDQUFDO0lBRWtCLE1BQU07UUFDdkIsT0FBTyxFQUFFLENBQUMsSUFBSSxDQUFDLE9BQU8sSUFBSSxFQUFFLENBQUMsQ0FBQztJQUNoQyxDQUFDOzhHQWRVLHVCQUF1QjtrR0FBdkIsdUJBQXVCLDhHQUZ2QixrQkFBa0IsQ0FBQyx1QkFBdUIsQ0FBQyxpRENoQnhELHVnQkFlTTs7MkZER08sdUJBQXVCO2tCQU5uQyxTQUFTOytCQUNFLGlCQUFpQixhQUdoQixrQkFBa0IseUJBQXlCO2lIQUk3QyxlQUFlO3NCQUF2QixLQUFLO2dCQUNHLE9BQU87c0JBQWYsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XHJcbiAgQ29tcG9uZW50LFxyXG4gIElucHV0XHJcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5pbXBvcnQgeyBEaWFsb2dTZXJ2aWNlIH0gZnJvbSAncHJpbWVuZy9keW5hbWljZGlhbG9nJztcclxuXHJcbmltcG9ydCB7IG9mIH0gZnJvbSAncnhqcyc7XHJcbmltcG9ydCB7IENvbXBvbmVudFByb3ZpZGVycyB9IGZyb20gJy4uLy4uLy4uL2FwaS9oZWxwZXJzL2NvbXBvbmVudC1wcm92aWRlcnMnO1xyXG5pbXBvcnQgeyBCYXNlQ29tcG9uZW50RHJvcERvd25FeHRlcm5hbCB9IGZyb20gJy4uLy4uLy4uL2FwaS9iYXNlLWNvbXBvbmVudHMvYmFzZS1jb21wb25lbnQtZHJvcGRvd24tZXh0ZXJuYWwnO1xyXG5pbXBvcnQgeyBDb21wb25lbnRTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vLi4vYXBpL3NlcnZpY2VzL2NvbXBvbmVudC5zZXJ2aWNlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnZHJvcGRvd24tbWFzdGVyJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vZHJvcGRvd24tbWFzdGVyLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9kcm9wZG93bi1tYXN0ZXIuY29tcG9uZW50LnNjc3MnXSxcclxuICBwcm92aWRlcnM6IENvbXBvbmVudFByb3ZpZGVycyhEcm9wZG93bk1hc3RlckNvbXBvbmVudCksXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBEcm9wZG93bk1hc3RlckNvbXBvbmVudCBleHRlbmRzIEJhc2VDb21wb25lbnREcm9wRG93bkV4dGVybmFsIHtcclxuXHJcbiAgQElucHV0KCkgZm9ybUNvbnRyb2xOYW1lITogc3RyaW5nO1xyXG4gIEBJbnB1dCgpIG1hc3RlcnMhOiBhbnlbXTtcclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBjb21wb25lbnRTZXJ2aWNlOiBDb21wb25lbnRTZXJ2aWNlLFxyXG4gICAgZGlhbG9nU2VydmljZTogRGlhbG9nU2VydmljZSxcclxuICApIHtcclxuICAgIHN1cGVyKGNvbXBvbmVudFNlcnZpY2UsIGRpYWxvZ1NlcnZpY2UpO1xyXG4gIH1cclxuXHJcbiAgcHJvdGVjdGVkIG92ZXJyaWRlIGxpc3RhcigpIHtcclxuICAgIHJldHVybiBvZih0aGlzLm1hc3RlcnMgfHwgW10pO1xyXG4gIH1cclxufSIsIjxkaXYgW2Zvcm1Hcm91cF09XCJmb3JtR3JvdXBcIj5cclxuICA8a3YtZHJvcGRvd25cclxuICAgIGNvbXBvbmVudElkPVwiaWRtYXN0ZXJcIlxyXG4gICAgbGFiZWw9XCJMaWNlbsOnYVwiXHJcbiAgICBvcHRpb25MYWJlbD1cImlkbWFzdGVybm9tZVwiXHJcbiAgICBvcHRpb25WYWx1ZT1cImlkbWFzdGVyXCJcclxuICAgIFtvcHRpb25zXT1cIm9wdGlvbnNcIlxyXG4gICAgW2ZpbHRlcl09XCJ0cnVlXCJcclxuICAgIFtmaWx0ZXJlZE9wdGlvbnNdPVwiZmlsdGVyZWRPcHRpb25zXCJcclxuICAgIFtmb3JtQ29udHJvbE5hbWVdPVwiZm9ybUNvbnRyb2xOYW1lXCJcclxuICAgIFtsb2FkaW5nXT1cImxvYWRpbmdcIlxyXG4gICAgW3Nob3dDbGVhcl09XCJmYWxzZVwiXHJcbiAgICAob25TZWxlY3Rpb25DaGFuZ2UpPVwib25JbnB1dENoYW5nZSgkZXZlbnQpXCJcclxuICAgIChvblNlbGVjdGlvblZhbHVlKT1cIm9uSW5wdXRDaGFuZ2UoJGV2ZW50KVwiPlxyXG4gIDwva3YtZHJvcGRvd24+XHJcbjwvZGl2PiJdfQ==
28
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24tbWFzdGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tlZXZvLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2t2LWxheW91dC9kcm9wZG93bi1tYXN0ZXIvZHJvcGRvd24tbWFzdGVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tlZXZvLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2t2LWxheW91dC9kcm9wZG93bi1tYXN0ZXIvZHJvcGRvd24tbWFzdGVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxTQUFTLEVBQ1QsS0FBSyxFQUNOLE1BQU0sZUFBZSxDQUFDO0FBSXZCLE9BQU8sRUFBRSxFQUFFLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDMUIsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sMENBQTBDLENBQUM7QUFDOUUsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sK0RBQStELENBQUM7Ozs7OztBQVM5RyxNQUFNLE9BQU8sdUJBQXdCLFNBQVEsNkJBQTZCO0lBS3hFLFlBQ0UsZ0JBQWtDLEVBQ2xDLGFBQTRCO1FBRTVCLEtBQUssQ0FBQyxnQkFBZ0IsRUFBRSxhQUFhLENBQUMsQ0FBQztJQUN6QyxDQUFDO0lBRWtCLE1BQU07UUFDdkIsT0FBTyxFQUFFLENBQUMsSUFBSSxDQUFDLE9BQU8sSUFBSSxFQUFFLENBQUMsQ0FBQztJQUNoQyxDQUFDOzhHQWRVLHVCQUF1QjtrR0FBdkIsdUJBQXVCLDhHQUZ2QixrQkFBa0IsQ0FBQyx1QkFBdUIsQ0FBQyxpRENoQnhELHllQWNNOzsyRkRJTyx1QkFBdUI7a0JBTm5DLFNBQVM7K0JBQ0UsaUJBQWlCLGFBR2hCLGtCQUFrQix5QkFBeUI7aUhBSTdDLGVBQWU7c0JBQXZCLEtBQUs7Z0JBQ0csT0FBTztzQkFBZixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcclxuICBDb21wb25lbnQsXHJcbiAgSW5wdXRcclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbmltcG9ydCB7IERpYWxvZ1NlcnZpY2UgfSBmcm9tICdwcmltZW5nL2R5bmFtaWNkaWFsb2cnO1xyXG5cclxuaW1wb3J0IHsgb2YgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgQ29tcG9uZW50UHJvdmlkZXJzIH0gZnJvbSAnLi4vLi4vLi4vYXBpL2hlbHBlcnMvY29tcG9uZW50LXByb3ZpZGVycyc7XHJcbmltcG9ydCB7IEJhc2VDb21wb25lbnREcm9wRG93bkV4dGVybmFsIH0gZnJvbSAnLi4vLi4vLi4vYXBpL2Jhc2UtY29tcG9uZW50cy9iYXNlLWNvbXBvbmVudC1kcm9wZG93bi1leHRlcm5hbCc7XHJcbmltcG9ydCB7IENvbXBvbmVudFNlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi9hcGkvc2VydmljZXMvY29tcG9uZW50LnNlcnZpY2UnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdkcm9wZG93bi1tYXN0ZXInLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9kcm9wZG93bi1tYXN0ZXIuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2Ryb3Bkb3duLW1hc3Rlci5jb21wb25lbnQuc2NzcyddLFxyXG4gIHByb3ZpZGVyczogQ29tcG9uZW50UHJvdmlkZXJzKERyb3Bkb3duTWFzdGVyQ29tcG9uZW50KSxcclxufSlcclxuZXhwb3J0IGNsYXNzIERyb3Bkb3duTWFzdGVyQ29tcG9uZW50IGV4dGVuZHMgQmFzZUNvbXBvbmVudERyb3BEb3duRXh0ZXJuYWwge1xyXG5cclxuICBASW5wdXQoKSBmb3JtQ29udHJvbE5hbWUhOiBzdHJpbmc7XHJcbiAgQElucHV0KCkgbWFzdGVycyE6IGFueVtdO1xyXG5cclxuICBjb25zdHJ1Y3RvcihcclxuICAgIGNvbXBvbmVudFNlcnZpY2U6IENvbXBvbmVudFNlcnZpY2UsXHJcbiAgICBkaWFsb2dTZXJ2aWNlOiBEaWFsb2dTZXJ2aWNlLFxyXG4gICkge1xyXG4gICAgc3VwZXIoY29tcG9uZW50U2VydmljZSwgZGlhbG9nU2VydmljZSk7XHJcbiAgfVxyXG5cclxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgbGlzdGFyKCkge1xyXG4gICAgcmV0dXJuIG9mKHRoaXMubWFzdGVycyB8fCBbXSk7XHJcbiAgfVxyXG59IiwiPGRpdiBbZm9ybUdyb3VwXT1cImZvcm1Hcm91cFwiPlxyXG4gIDxrdi1kcm9wZG93blxyXG4gICAgY29tcG9uZW50SWQ9XCJpZG1hc3RlclwiXHJcbiAgICBvcHRpb25MYWJlbD1cImlkbWFzdGVybm9tZVwiXHJcbiAgICBvcHRpb25WYWx1ZT1cImlkbWFzdGVyXCJcclxuICAgIFtvcHRpb25zXT1cIm9wdGlvbnNcIlxyXG4gICAgW2ZpbHRlcl09XCJ0cnVlXCJcclxuICAgIFtmaWx0ZXJlZE9wdGlvbnNdPVwiZmlsdGVyZWRPcHRpb25zXCJcclxuICAgIFtmb3JtQ29udHJvbE5hbWVdPVwiZm9ybUNvbnRyb2xOYW1lXCJcclxuICAgIFtsb2FkaW5nXT1cImxvYWRpbmdcIlxyXG4gICAgW3Nob3dDbGVhcl09XCJmYWxzZVwiXHJcbiAgICAob25TZWxlY3Rpb25DaGFuZ2UpPVwib25JbnB1dENoYW5nZSgkZXZlbnQpXCJcclxuICAgIChvblNlbGVjdGlvblZhbHVlKT1cIm9uSW5wdXRDaGFuZ2UoJGV2ZW50KVwiPlxyXG4gIDwva3YtZHJvcGRvd24+XHJcbjwvZGl2PiJdfQ==