keevo-components 2.0.204 → 2.0.206

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.
@@ -0,0 +1,10 @@
1
+ export function createEnumUtils(config) {
2
+ return {
3
+ listar: () => Object.values(config),
4
+ getLabel: (value) => config[value]?.label ?? 'Desconhecido',
5
+ getSeverity: (value) => config[value]?.severity,
6
+ getHexColor: (value) => config[value]?.hexColor,
7
+ isValid: (value) => Object.keys(config).includes(value)
8
+ };
9
+ }
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZV9lbnVtLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2Vldm8tY29tcG9uZW50cy9zcmMvbGliL2FwaS9iYXNlLWNvbXBvbmVudHMvYmFzZV9lbnVtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVVBLE1BQU0sVUFBVSxlQUFlLENBQzdCLE1BQTZCO0lBRTdCLE9BQU87UUFDTCxNQUFNLEVBQUUsR0FBUSxFQUFFLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUM7UUFDeEMsUUFBUSxFQUFFLENBQUMsS0FBaUIsRUFBVSxFQUFFLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxFQUFFLEtBQUssSUFBSSxjQUFjO1FBQy9FLFdBQVcsRUFBRSxDQUFDLEtBQWlCLEVBQWMsRUFBRSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsRUFBRSxRQUFzQjtRQUNyRixXQUFXLEVBQUUsQ0FBQyxLQUFpQixFQUFzQixFQUFFLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxFQUFFLFFBQVE7UUFDL0UsT0FBTyxFQUFFLENBQUMsS0FBYyxFQUF1QixFQUFFLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQyxRQUFRLENBQUMsS0FBZSxDQUFDO0tBQ2hHLENBQUM7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgS3ZTZXZlcml0eSB9IGZyb20gXCIuLi8uLi9jb21wb25lbnRzL2t2LWZpbHRlci1jYXJkcy9rdi1maWx0ZXItY2FyZHMuY29tcG9uZW50XCI7XHJcblxyXG5cclxuZXhwb3J0IHR5cGUgS3ZFbnVtQ29uZmlnPFZhbHVlVHlwZSA9IG51bWJlcj4gPSB7XHJcbiAgdmFsdWU6IFZhbHVlVHlwZTtcclxuICBsYWJlbDogc3RyaW5nO1xyXG4gIHNldmVyaXR5PzogS3ZTZXZlcml0eTtcclxuICBoZXhDb2xvcj86IHN0cmluZztcclxufTtcclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVFbnVtVXRpbHM8VCBleHRlbmRzIFJlY29yZDxzdHJpbmcsIG51bWJlciB8IHN0cmluZz4sIFYgZXh0ZW5kcyBLdkVudW1Db25maWc8bnVtYmVyIHwgc3RyaW5nPj4oXHJcbiAgY29uZmlnOiBSZWNvcmQ8VFtrZXlvZiBUXSwgVj5cclxuKSB7XHJcbiAgcmV0dXJuIHtcclxuICAgIGxpc3RhcjogKCk6IFZbXSA9PiBPYmplY3QudmFsdWVzKGNvbmZpZyksXHJcbiAgICBnZXRMYWJlbDogKHZhbHVlOiBUW2tleW9mIFRdKTogc3RyaW5nID0+IGNvbmZpZ1t2YWx1ZV0/LmxhYmVsID8/ICdEZXNjb25oZWNpZG8nLFxyXG4gICAgZ2V0U2V2ZXJpdHk6ICh2YWx1ZTogVFtrZXlvZiBUXSk6IEt2U2V2ZXJpdHkgPT4gY29uZmlnW3ZhbHVlXT8uc2V2ZXJpdHkgYXMgS3ZTZXZlcml0eSxcclxuICAgIGdldEhleENvbG9yOiAodmFsdWU6IFRba2V5b2YgVF0pOiBzdHJpbmcgfCB1bmRlZmluZWQgPT4gY29uZmlnW3ZhbHVlXT8uaGV4Q29sb3IsXHJcbiAgICBpc1ZhbGlkOiAodmFsdWU6IHVua25vd24pOiB2YWx1ZSBpcyBUW2tleW9mIFRdID0+IE9iamVjdC5rZXlzKGNvbmZpZykuaW5jbHVkZXModmFsdWUgYXMgc3RyaW5nKVxyXG4gIH07XHJcbn1cclxuIl19
@@ -89,4 +89,4 @@ export const mapaSeverityColors = {
89
89
  warning: '#E1963D', // Amarelo
90
90
  danger: '#B91C1C', // Laranja
91
91
  };
92
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-filter-cards.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-filter-cards/kv-filter-cards.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-filter-cards/kv-filter-cards.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgClass, CommonModule } from '@angular/common';\r\nimport { ChangeDetectionStrategy, Component, computed, input, model, output, signal } from '@angular/core';\r\n\r\n@Component({\r\n  selector: 'kv-filter-cards',\r\n  templateUrl: `./kv-filter-cards.component.html`,\r\n  styleUrl: './kv-filter-cards.component.scss',\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class KvFilterCardsComponent {\r\n\r\n  // Lista de cards de filtro, cada um com um ícone e valor específico\r\n  cards = input<KvFilterCardConfig[]>()\r\n\r\n  staticCards = input<boolean>(false);\r\n\r\n  cursorPointer = input<boolean>(true);\r\n\r\n\r\n  selectedCards = model<KvFilterCardConfig[] | number[]>([]);\r\n\r\n  selectedCardsTratado = computed(() => {\r\n    const cardsSelecionados = this.selectedCards();\r\n    const cards = this.cards() ?? [];\r\n\r\n    if (!cardsSelecionados || cardsSelecionados.length === 0) return [];\r\n\r\n    // Se for array de number, converte\r\n    if (typeof cardsSelecionados[0] === 'number') {\r\n      return cards.filter(c => (cardsSelecionados as number[]).includes(c.id));\r\n    }\r\n\r\n    // Já é array de objeto\r\n    return cardsSelecionados as KvFilterCardConfig[];\r\n  });\r\n\r\n\r\n\r\n\r\n  loadingCards = input<boolean>(false);\r\n\r\n  // Define se os cards devem ser exibidos em uma linha ou coluna\r\n  wrapCards = input<boolean>(false);\r\n\r\n  // Define se os cards devem ser centralizados\r\n  alignCardsCenter = input<boolean>(false);\r\n\r\n  onCardClick = output<KvFilterCardConfig>();\r\n\r\n  color = computed(() => (card: KvFilterCardConfig) => {\r\n    const color = mapaSeverityColors[card.severity];\r\n    return color ? color : mapaSeverityColors.tertiary;\r\n  });\r\n\r\n  mixedColor = computed(() => (card: KvFilterCardConfig) => {\r\n    return this.getTransparentMix(this.color()(card))\r\n  });\r\n\r\n\r\n  private getTransparentMix(baseHex: string, opacity: number = 0.3): string {\r\n    const r = parseInt(baseHex.slice(1, 3), 16);\r\n    const g = parseInt(baseHex.slice(3, 5), 16);\r\n    const b = parseInt(baseHex.slice(5, 7), 16);\r\n    return `rgba(${r}, ${g}, ${b}, ${opacity})`;\r\n  }\r\n\r\n\r\n\r\n  handleCardClick(card: KvFilterCardConfig) {\r\n    this.onCardClick.emit(card);\r\n\r\n    this.selectedCards.update((raw) => {\r\n      let selected: KvFilterCardConfig[];\r\n\r\n      // Se vier como number[], converter usando this.cards()\r\n      if (typeof raw[0] === 'number') {\r\n        const allCards = this.cards() ?? [];\r\n        selected = allCards.filter(c => (raw as number[]).includes(c.id));\r\n      } else {\r\n        selected = raw as KvFilterCardConfig[];\r\n      }\r\n\r\n      const exists = selected.some(c => c.id === card.id);\r\n      const updated = exists\r\n        ? selected.filter(c => c.id !== card.id)\r\n        : [...selected, card];\r\n\r\n      return updated;\r\n    });\r\n\r\n  }\r\n\r\n\r\n  verificarSeCardEstaSelecionado(card: KvFilterCardConfig): boolean {\r\n    return this.selectedCardsTratado()?.find(c => c.id === card.id) !== undefined;\r\n  }\r\n\r\n  getColorFillPolygon(card: KvFilterCardConfig): string {\r\n\r\n    if (this.staticCards()) {\r\n      return 'var(--main-color)';\r\n    }\r\n\r\n    if (!this.selectedCardsTratado()?.includes(card)) {\r\n      return 'color-mix(in srgb, var(--mixed-color) 40%, white 60%)';\r\n    } else {\r\n      return 'color-mix(in srgb, var(--mixed-color) 99%, white 1%)';\r\n    }\r\n\r\n  }\r\n\r\n\r\n  // getColorIconPolygon(card: KvFilterCardConfig): string {\r\n  //   if (this.staticCards()) {\r\n  //     return 'white';\r\n  //   }\r\n\r\n  //   if (!this.selectedCardsTratado()?.includes(card)) {\r\n  //     return 'var(--main-color)';\r\n  //   } else {\r\n  //     return 'white';\r\n  //   }\r\n  // }\r\n\r\n}\r\n\r\n\r\nexport type KvSeverity = 'primary' | 'secondary' | 'tertiary' | 'info' | 'warning' | 'danger';\r\n\r\nexport const mapaSeverityColors: Record<KvSeverity, string> = {\r\n  primary: '#0A8765',    // Verde\r\n  secondary: '#0A3A78',  // Azul escuro\r\n  tertiary: '#778599',   // Cinza\r\n  info: '#0091C2',       // Azul claro\r\n  warning: '#E1963D',    // Amarelo\r\n  danger: '#B91C1C',     // Laranja\r\n};\r\n\r\n\r\n\r\nexport type KvFilterCardFormato = 'int' | 'currency' | 'percent' | 'decimal' | 'text' | 'date';\r\nexport type KvFilterCardConfig = {\r\n  id: number;\r\n  severity: KvSeverity;\r\n  titulo: string;\r\n  icon: string;\r\n  valor?: number | string | undefined | null;\r\n  formato?: KvFilterCardFormato;\r\n\r\n}","<div\r\n  id=\"filter-card-container\"\r\n  class=\"flex flex-row w-full justify-content-between\"\r\n>\r\n  <div\r\n    class=\"flex p-fluid formgrid w-full gap-2 overflow-y-hidden\"\r\n    [ngClass]=\"[\r\n      wrapCards() ? 'flex-wrap' : 'flex-nowrap overflow-x-auto',\r\n      alignCardsCenter() ? 'justify-content-center' : 'justify-content-start'\r\n    ]\"\r\n    #filterCardsContainer\r\n  >\r\n    @for (card of cards(); track card.id) {\r\n\r\n    <div\r\n      (click)=\"handleCardClick(card)\"\r\n      [style.--main-color]=\"color()(card)\"\r\n      [style.--mixed-color]=\"mixedColor()(card)\"\r\n      class=\"filter-card\"\r\n      [ngClass]=\"[\r\n        'filter-card-size',\r\n        verificarSeCardEstaSelecionado(card)\r\n          ? 'filter-card-active'\r\n          : 'clickable',\r\n        staticCards() ? 'filter-card-active' : '',\r\n        !staticCards() && !verificarSeCardEstaSelecionado(card)\r\n          ? 'filter-card-hover'\r\n          : '',\r\n        cursorPointer() ? 'cursor-pointer' : ''\r\n      ]\"\r\n    >\r\n      <div class=\"filter-card-content\">\r\n        <div class=\"filter-card-title\">\r\n          <div class=\"flex flex-column\">\r\n            <div\r\n              style=\"font-weight: semibold; font-size: 0.75em\"\r\n              [style.color]=\"color()(card)\"\r\n            >\r\n              {{ card?.titulo }}\r\n            </div>\r\n\r\n            <div class=\"h-1rem\">\r\n              @if(loadingCards()){\r\n\r\n              <span class=\"loading-spinner\"></span>\r\n\r\n              } @else {\r\n\r\n              <span\r\n                class=\"flex align-items-center\"\r\n                [style.color]=\"color()(card)\"\r\n                style=\"font-size: 0.825em; font-weight: 600\"\r\n              >\r\n                {{ card.valor | kvFilterCardsFormatter : card.formato }}\r\n              </span>\r\n\r\n              }\r\n            </div>\r\n          </div>\r\n\r\n          @if (card.icon) {\r\n\r\n          <div class=\"hex-icon-svg\">\r\n            <!-- <svg style=\"overflow: visible\" viewBox=\"0 0 100 100\" class=\"hex-bg\">\r\n              <polygon\r\n                [attr.fill]=\"getColorFillPolygon(card)\"\r\n                points=\"93.3 75,50 100,6.7 75,6.7 25,50 0,93.3 25\"\r\n                stroke=\"var(--main-color)\"\r\n                stroke-width=\"3\"\r\n                stroke-linejoin=\"round\"\r\n                stroke-linecap=\"round\"\r\n                opacity=\"0.8\"\r\n              />\r\n            </svg> -->\r\n\r\n            <div class=\"flex align-items-center justify-content-center p-2 border-round-lg transition-all transition-duration-300\" \r\n                 [style.backgroundColor]=\"getColorFillPolygon(card)\">\r\n              <span\r\n                [style.color]=\"'var(--main-color)'\"\r\n                class=\"material-symbols-outlined icon\"\r\n              >\r\n                {{ card?.icon }}\r\n              </span>\r\n            </div>\r\n\r\n          </div>\r\n\r\n          }\r\n        </div>\r\n      </div>\r\n    </div>\r\n    }\r\n  </div>\r\n</div>\r\n"]}
92
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-filter-cards.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-filter-cards/kv-filter-cards.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-filter-cards/kv-filter-cards.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgClass, CommonModule } from '@angular/common';\r\nimport { ChangeDetectionStrategy, Component, computed, input, model, output, signal } from '@angular/core';\r\n\r\n@Component({\r\n  selector: 'kv-filter-cards',\r\n  templateUrl: `./kv-filter-cards.component.html`,\r\n  styleUrl: './kv-filter-cards.component.scss',\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n})\r\nexport class KvFilterCardsComponent {\r\n\r\n  // Lista de cards de filtro, cada um com um ícone e valor específico\r\n  cards = input<KvFilterCardConfig[]>()\r\n\r\n  staticCards = input<boolean>(false);\r\n\r\n  cursorPointer = input<boolean>(true);\r\n\r\n\r\n  selectedCards = model<KvFilterCardConfig[] | number[]>([]);\r\n\r\n  selectedCardsTratado = computed(() => {\r\n    const cardsSelecionados = this.selectedCards();\r\n    const cards = this.cards() ?? [];\r\n\r\n    if (!cardsSelecionados || cardsSelecionados.length === 0) return [];\r\n\r\n    // Se for array de number, converte\r\n    if (typeof cardsSelecionados[0] === 'number') {\r\n      return cards.filter(c => (cardsSelecionados as number[]).includes(c.id));\r\n    }\r\n\r\n    // Já é array de objeto\r\n    return cardsSelecionados as KvFilterCardConfig[];\r\n  });\r\n\r\n\r\n\r\n\r\n  loadingCards = input<boolean>(false);\r\n\r\n  // Define se os cards devem ser exibidos em uma linha ou coluna\r\n  wrapCards = input<boolean>(false);\r\n\r\n  // Define se os cards devem ser centralizados\r\n  alignCardsCenter = input<boolean>(false);\r\n\r\n  onCardClick = output<KvFilterCardConfig>();\r\n\r\n  color = computed(() => (card: KvFilterCardConfig) => {\r\n    const color = mapaSeverityColors[card.severity];\r\n    return color ? color : mapaSeverityColors.tertiary;\r\n  });\r\n\r\n  mixedColor = computed(() => (card: KvFilterCardConfig) => {\r\n    return this.getTransparentMix(this.color()(card))\r\n  });\r\n\r\n\r\n  private getTransparentMix(baseHex: string, opacity: number = 0.3): string {\r\n    const r = parseInt(baseHex.slice(1, 3), 16);\r\n    const g = parseInt(baseHex.slice(3, 5), 16);\r\n    const b = parseInt(baseHex.slice(5, 7), 16);\r\n    return `rgba(${r}, ${g}, ${b}, ${opacity})`;\r\n  }\r\n\r\n\r\n\r\n  handleCardClick(card: KvFilterCardConfig) {\r\n    this.onCardClick.emit(card);\r\n\r\n    this.selectedCards.update((raw) => {\r\n      let selected: KvFilterCardConfig[];\r\n\r\n      // Se vier como number[], converter usando this.cards()\r\n      if (typeof raw[0] === 'number') {\r\n        const allCards = this.cards() ?? [];\r\n        selected = allCards.filter(c => (raw as number[]).includes(c.id));\r\n      } else {\r\n        selected = raw as KvFilterCardConfig[];\r\n      }\r\n\r\n      const exists = selected.some(c => c.id === card.id);\r\n      const updated = exists\r\n        ? selected.filter(c => c.id !== card.id)\r\n        : [...selected, card];\r\n\r\n      return updated;\r\n    });\r\n\r\n  }\r\n\r\n\r\n  verificarSeCardEstaSelecionado(card: KvFilterCardConfig): boolean {\r\n    return this.selectedCardsTratado()?.find(c => c.id === card.id) !== undefined;\r\n  }\r\n\r\n  getColorFillPolygon(card: KvFilterCardConfig): string {\r\n\r\n    if (this.staticCards()) {\r\n      return 'var(--main-color)';\r\n    }\r\n\r\n    if (!this.selectedCardsTratado()?.includes(card)) {\r\n      return 'color-mix(in srgb, var(--mixed-color) 40%, white 60%)';\r\n    } else {\r\n      return 'color-mix(in srgb, var(--mixed-color) 99%, white 1%)';\r\n    }\r\n\r\n  }\r\n\r\n\r\n  // getColorIconPolygon(card: KvFilterCardConfig): string {\r\n  //   if (this.staticCards()) {\r\n  //     return 'white';\r\n  //   }\r\n\r\n  //   if (!this.selectedCardsTratado()?.includes(card)) {\r\n  //     return 'var(--main-color)';\r\n  //   } else {\r\n  //     return 'white';\r\n  //   }\r\n  // }\r\n\r\n}\r\n\r\n\r\nexport type KvSeverity = 'primary' | 'secondary' | 'tertiary' | 'info' | 'warning' | 'danger';\r\n\r\nexport const mapaSeverityColors: Record<KvSeverity, string> = {\r\n  primary: '#0A8765',    // Verde\r\n  secondary: '#0A3A78',  // Azul escuro\r\n  tertiary: '#778599',   // Cinza\r\n  info: '#0091C2',       // Azul claro\r\n  warning: '#E1963D',    // Amarelo\r\n  danger: '#B91C1C',     // Laranja\r\n};\r\n\r\n\r\n\r\nexport type KvFilterCardFormato = 'int' | 'currency' | 'percent' | 'decimal' | 'text' | 'date';\r\nexport interface KvFilterCardConfig {\r\n  id: number;\r\n  severity: KvSeverity;\r\n  titulo: string;\r\n  icon: string;\r\n  valor?: number | string | undefined | null;\r\n  formato?: KvFilterCardFormato;\r\n\r\n}","<div\r\n  id=\"filter-card-container\"\r\n  class=\"flex flex-row w-full justify-content-between\"\r\n>\r\n  <div\r\n    class=\"flex p-fluid formgrid w-full gap-2 overflow-y-hidden\"\r\n    [ngClass]=\"[\r\n      wrapCards() ? 'flex-wrap' : 'flex-nowrap overflow-x-auto',\r\n      alignCardsCenter() ? 'justify-content-center' : 'justify-content-start'\r\n    ]\"\r\n    #filterCardsContainer\r\n  >\r\n    @for (card of cards(); track card.id) {\r\n\r\n    <div\r\n      (click)=\"handleCardClick(card)\"\r\n      [style.--main-color]=\"color()(card)\"\r\n      [style.--mixed-color]=\"mixedColor()(card)\"\r\n      class=\"filter-card\"\r\n      [ngClass]=\"[\r\n        'filter-card-size',\r\n        verificarSeCardEstaSelecionado(card)\r\n          ? 'filter-card-active'\r\n          : 'clickable',\r\n        staticCards() ? 'filter-card-active' : '',\r\n        !staticCards() && !verificarSeCardEstaSelecionado(card)\r\n          ? 'filter-card-hover'\r\n          : '',\r\n        cursorPointer() ? 'cursor-pointer' : ''\r\n      ]\"\r\n    >\r\n      <div class=\"filter-card-content\">\r\n        <div class=\"filter-card-title\">\r\n          <div class=\"flex flex-column\">\r\n            <div\r\n              style=\"font-weight: semibold; font-size: 0.75em\"\r\n              [style.color]=\"color()(card)\"\r\n            >\r\n              {{ card?.titulo }}\r\n            </div>\r\n\r\n            <div class=\"h-1rem\">\r\n              @if(loadingCards()){\r\n\r\n              <span class=\"loading-spinner\"></span>\r\n\r\n              } @else {\r\n\r\n              <span\r\n                class=\"flex align-items-center\"\r\n                [style.color]=\"color()(card)\"\r\n                style=\"font-size: 0.825em; font-weight: 600\"\r\n              >\r\n                {{ card.valor | kvFilterCardsFormatter : card.formato }}\r\n              </span>\r\n\r\n              }\r\n            </div>\r\n          </div>\r\n\r\n          @if (card.icon) {\r\n\r\n          <div class=\"hex-icon-svg\">\r\n            <!-- <svg style=\"overflow: visible\" viewBox=\"0 0 100 100\" class=\"hex-bg\">\r\n              <polygon\r\n                [attr.fill]=\"getColorFillPolygon(card)\"\r\n                points=\"93.3 75,50 100,6.7 75,6.7 25,50 0,93.3 25\"\r\n                stroke=\"var(--main-color)\"\r\n                stroke-width=\"3\"\r\n                stroke-linejoin=\"round\"\r\n                stroke-linecap=\"round\"\r\n                opacity=\"0.8\"\r\n              />\r\n            </svg> -->\r\n\r\n            <div class=\"flex align-items-center justify-content-center p-2 border-round-lg transition-all transition-duration-300\" \r\n                 [style.backgroundColor]=\"getColorFillPolygon(card)\">\r\n              <span\r\n                [style.color]=\"'var(--main-color)'\"\r\n                class=\"material-symbols-outlined icon\"\r\n              >\r\n                {{ card?.icon }}\r\n              </span>\r\n            </div>\r\n\r\n          </div>\r\n\r\n          }\r\n        </div>\r\n      </div>\r\n    </div>\r\n    }\r\n  </div>\r\n</div>\r\n"]}
@@ -100,7 +100,7 @@ export class KvTableViewerComponent {
100
100
  if (type === 'date')
101
101
  return this.datePipe.transform(value, 'dd/MM/yyyy', 'UTC');
102
102
  if (type === 'datetime')
103
- return this.datePipe.transform(value, 'dd/MM/yyyy hh:mm');
103
+ return this.datePipe.transform(value, 'dd/MM/yyyy HH:mm');
104
104
  if (type === 'dateMonthYear')
105
105
  return this.datePipe.transform(value, 'MM/yyyy');
106
106
  else
@@ -290,4 +290,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
290
290
  type: HostListener,
291
291
  args: ['document:click', ['$event']]
292
292
  }] } });
293
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-table-viewer.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-table-viewer/kv-table-viewer.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-table-viewer/kv-table-viewer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, contentChildren, effect, ElementRef, HostListener, inject, input, OnDestroy, output, Renderer2, signal, TemplateRef, untracked, ViewChild } from '@angular/core';\r\nimport { ButtonModule } from 'primeng/button';\r\nimport { SkeletonModule } from 'primeng/skeleton';\r\nimport { TableModule, TablePageEvent } from 'primeng/table';\r\nimport { KvInputsModule } from \"../kv-inputs/kv-inputs.module\";\r\nimport { KvButtonModule } from \"../kv-button/kv-button.module\";\r\nimport { OverlayPanel, OverlayPanelModule } from 'primeng/overlaypanel';\r\nimport { ActionsLoteFieldComponent } from './components/actions-lote-field/actions-lote-field.component';\r\nimport { KvTagsModule } from \"../kv-tags/kv-tags.module\";\r\nimport { CommonModule, DatePipe } from '@angular/common';\r\nimport { animate, state, style, transition, trigger } from '@angular/animations';\r\nimport { TooltipModule } from 'primeng/tooltip';\r\nimport { MenuItem } from 'primeng/api';\r\nimport { TieredMenuModule } from 'primeng/tieredmenu';\r\nimport { ActionsRowMenuComponent } from './components/actions-row-menu/actions-row-menu.component';\r\nimport { CpfCnpjPipe } from '../../api/pipes/cpfcnpj.pipe';\r\nimport { TelefonePipe } from '../../api/pipes/telefone.pipe';\r\nimport { TemplateDirective } from '../../api/directives/template/template.directive';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { InputTextModule } from 'primeng/inputtext';\r\nimport { BreakpointObserver, Breakpoints } from '@angular/cdk/layout';\r\n\r\ninterface ColumnTableViewer {\r\n  field: string;\r\n  header: string;\r\n  width?: string;\r\n  icon?: (rowData: any) => string;\r\n  tag?: (rowData: any) => { label: string, severity: string, icon: string };\r\n  pipe?: 'cpfcnpj' | 'telefone' | 'money' | 'date' | 'datetime' | 'dateMonthYear' | undefined;\r\n  template?: { name: string };\r\n}\r\n\r\n@Component({\r\n  selector: 'kv-table-viewer',\r\n  standalone: true,\r\n  imports: [InputTextModule, CommonModule, TooltipModule, TableModule, SkeletonModule, ButtonModule, KvInputsModule, KvButtonModule, OverlayPanelModule, ActionsLoteFieldComponent, KvTagsModule, TieredMenuModule, ActionsRowMenuComponent, FormsModule],\r\n  templateUrl: './kv-table-viewer.component.html',\r\n  styleUrl: './kv-table-viewer.component.scss',\r\n  animations: [\r\n    trigger('slideInOut', [\r\n      state('in', style({\r\n        width: '*',\r\n        opacity: 1,\r\n        transform: 'translateX(0)'\r\n      })),\r\n      state('out', style({\r\n        width: '0px',\r\n        opacity: 0,\r\n        transform: 'translateX(100%)'\r\n      })),\r\n      transition('out => in', [\r\n        animate('300ms ease-in-out')\r\n      ]),\r\n      transition('in => out', [\r\n        animate('200ms ease-in-out')\r\n      ])\r\n    ])\r\n  ]\r\n})\r\nexport class KvTableViewerComponent implements OnDestroy {\r\n\r\n  @ViewChild('op') op!: OverlayPanel;\r\n\r\n  cpfCnpjPipe = inject(CpfCnpjPipe);\r\n  telefonePipe = inject(TelefonePipe);\r\n  datePipe = inject(DatePipe);\r\n  breakpointObserver = inject(BreakpointObserver);\r\n  elementRef = inject(ElementRef);\r\n  renderer = inject(Renderer2);\r\n\r\n  columns = input<ColumnTableViewer[]>([]);\r\n\r\n  actionsRow = input<MenuItem[] | []>([]);\r\n  actionsHeader = input<MenuItem[] | undefined>(undefined);\r\n  actionsLote = input<MenuItem[] | undefined>(undefined);\r\n\r\n  data = input<any[]>([]);\r\n  totalRecords = input<number>(0);\r\n  loading = input<boolean>(false);\r\n  rows = input<number>(10);\r\n  rowsPerPageOptions = input<number[]>([10, 25, 50]);\r\n  paginator = input<boolean>(true);\r\n  lazy = input<boolean>(true);\r\n  scrollable = input<boolean>(true);\r\n  pageLinks = input<number>(2);\r\n  currentPageReportTemplate = input<string>('{first} - {last} de {totalRecords}');\r\n  selectionPageOnly = input<boolean>(true);\r\n\r\n\r\n  selectableTable = input<boolean>(true);\r\n  showHeader = input<boolean>(true);\r\n  showHeaderTemplate = input<boolean>(false);\r\n  tableViewerSize = input<string>('col-8');\r\n  searchInput = input<boolean>(true);\r\n  filterButton = input<boolean>(true);\r\n  idName = input<string | undefined>(undefined);\r\n  emptyTableImg = input<string>('https://work-assets.keevo.com.br/img/Nenhum_registro_localizado.png');\r\n  isSelectedPrimaryItem = input<boolean>(false);\r\n\r\n  private overlayElement: HTMLElement | null = null;\r\n\r\n  selectedItems = signal<any[]>([]);\r\n  selectedItem = signal<any>(null);\r\n  first = signal<number>(0);\r\n  searchValue = signal('');\r\n  lastEmittedSort = signal<{ field: string, order: number } | null>(null);\r\n  isMobile = signal(false);\r\n  \r\n\r\n  onPageChange = output<TablePageEvent>();\r\n  onClickRowItem = output<any>();\r\n  onSelectItems = output<any[]>();\r\n  onSearch = output<string>();\r\n  onSort = output<any>();\r\n\r\n  templates = contentChildren(TemplateDirective);\r\n  _templates = input<Record<string, TemplateRef<any>>>({}, { alias: 'templates' });\r\n  getCustomTemplate = computed(() => (templatename: string): TemplateRef<any> | null => {\r\n    const templates = this._templates();\r\n    return templates[templatename];\r\n  });\r\n\r\n  isRowSelected = computed(() => {\r\n    return this.selectedItems()?.length > 0 || this.selectedItem();\r\n  });\r\n\r\n  verifyItemSelecionado = computed(() => (rowData: any) => {\r\n    let isSelected;\r\n\r\n    let idName = this.idName() || 'id';\r\n\r\n    if (this.selectableTable())\r\n      isSelected = this.selectedItems().find((item: any) => item[idName] == rowData[idName]);\r\n    else isSelected = this.selectedItem()?.[idName] == rowData[idName];\r\n\r\n    return isSelected;\r\n  })\r\n\r\n  transformData = computed(() => (type: string, value: any) => {\r\n    if (type === 'cpfcnpj') return this.cpfCnpjPipe.transform(value);\r\n    if (type === 'telefone') return this.telefonePipe.transform(value);\r\n    if (type === 'money') return this.transformMoney(value);\r\n    if (type === 'date') return this.datePipe.transform(value, 'dd/MM/yyyy', 'UTC');\r\n    if (type === 'datetime') return this.datePipe.transform(value, 'dd/MM/yyyy hh:mm');\r\n    if (type === 'dateMonthYear') return this.datePipe.transform(value, 'MM/yyyy');\r\n\r\n    else return value;\r\n  })\r\n\r\n  handleTableSize = computed(() => {\r\n    const selectedItems = this.selectedItems();\r\n    const selectedItem = this.selectedItem();\r\n\r\n    if (selectedItems?.length == 0 && !selectedItem)\r\n      return 'col-12';\r\n    else return this.tableViewerSize();\r\n  })\r\n\r\n  isPopupButton = computed(() => (action: any) => {\r\n    return (action.items && action.items?.length > 0) || false;\r\n  })\r\n\r\n  hasActionsRow = computed(() => {\r\n    return this.actionsRow()?.length > 0;\r\n  })\r\n\r\n  showSelectedItem = computed(() => {\r\n    return this.selectedItems()?.length == 1 || this.selectedItem();\r\n  })\r\n\r\n  hasSelectedItems = computed(() => {\r\n    return this.selectedItems()?.length > 1;\r\n  })\r\n\r\n\r\n  returnColspan = computed(() => {\r\n    return this.columns().length + 1;\r\n  });\r\n\r\n  isEmptyTable = computed(() => {\r\n    return this.data()?.length == 0\r\n  });\r\n\r\n  constructor() {\r\n\r\n    this.breakpointObserver\r\n      .observe([Breakpoints.HandsetPortrait, '(max-width: 768px)'])\r\n      .subscribe(state => this.isMobile.set(state.matches));\r\n\r\n    effect(() => {\r\n      this.onSelectItems.emit(this.selectedItems());\r\n      this.onSearch.emit(this.searchValue());\r\n    });\r\n\r\n    effect(() => {\r\n        const dados = this.data();\r\n        const isSelectedPrimaryItem = this.isSelectedPrimaryItem();\r\n\r\n        if(dados && dados.length > 0 && isSelectedPrimaryItem) {\r\n          untracked(() => this.rowSelect(dados[0]));\r\n        }\r\n    });\r\n  }\r\n\r\n  toggleOverlayPanel(event: Event) {\r\n    event.stopPropagation();\r\n    this.op.toggle(event);\r\n\r\n    setTimeout(() => {\r\n      if(this.op.overlayVisible) {\r\n        this.createOverlay();\r\n      } else {\r\n        this.removeOverlay();\r\n      }\r\n    }, 0);\r\n  }\r\n\r\n  @HostListener('document:click', ['$event'])\r\n  onClickOutside(event: MouseEvent) {\r\n    if (!this.op || !this.op.overlayVisible) {\r\n      return;\r\n    }\r\n\r\n    const targetElement = event.target as HTMLElement;\r\n    \r\n    const filterButton = this.elementRef.nativeElement.querySelector('[label=\"Filtrar\"]');\r\n    if (filterButton && filterButton.contains(targetElement)) {\r\n      return;\r\n    }\r\n\r\n    if (targetElement.closest('.p-overlaypanel')) {\r\n      return;\r\n    }\r\n  }\r\n\r\n  public closeFilter() {\r\n    this.op?.hide();\r\n    this.removeOverlay();\r\n  }\r\n\r\n  public toggleFilter(event?: MouseEvent) {\r\n    if(event) {\r\n      event.stopPropagation();\r\n    }\r\n    this.op?.toggle(event);\r\n  }\r\n\r\n  private createOverlay() {\r\n    if(this.overlayElement) {\r\n      return;\r\n    }\r\n\r\n    this.overlayElement = this.renderer.createElement('div');\r\n    this.renderer.addClass(this.overlayElement, 'filter-overlay');\r\n\r\n    this.renderer.listen(this.overlayElement, 'click', () => {\r\n      this.closeFilter();\r\n    })\r\n\r\n    this.renderer.appendChild(document.body, this.overlayElement);\r\n  }\r\n\r\n  handlePageChange(event: TablePageEvent) {\r\n    this.first.set(event.first);\r\n    this.onPageChange.emit(event);\r\n  }\r\n\r\n  handleSort(event: any) {\r\n    const currentSortState = this.lastEmittedSort();\r\n\r\n    if (currentSortState && currentSortState.field === event.field && currentSortState.order === event.order) {\r\n      return;\r\n    }\r\n\r\n    this.lastEmittedSort.set({ field: event.field, order: event.order });\r\n\r\n    let ordenacao = `${event.field} ${event.order === 1 ? 'ASC' : 'DESC'} `;\r\n    let ordernacaoGroup = { column: event.field, direction: event.order === 1 ? 'ASC' : 'DESC' };\r\n    this.onSort.emit({ ordenacao: ordenacao, ordernacaoGroup: ordernacaoGroup });\r\n  }\r\n\r\n  rowSelect(rowData: any) {\r\n    if (this.selectableTable()) {\r\n      if (this.selectedItems().includes(rowData))\r\n        this.selectedItems.update((items: any[]) => items.filter(item => item !== rowData));\r\n      else this.selectedItems.update((items: any[]) => [...items, rowData]);\r\n\r\n      if (this.selectedItems()?.length === 1)\r\n        this.onClickRowItem.emit(this.selectedItems()[0]);\r\n      else this.onClickRowItem.emit(rowData);\r\n    } else {\r\n      this.selectedItem.set(rowData);\r\n      this.onClickRowItem.emit(rowData);\r\n    }\r\n\r\n  }\r\n\r\n  transformMoney(valor: number): string {\r\n    const formatter = new Intl.NumberFormat('pt-BR', {\r\n      style: 'currency',\r\n      currency: 'BRL',\r\n    });\r\n\r\n    return formatter.format(valor);\r\n  }\r\n\r\n  removeOverlay() {\r\n    if(this.overlayElement) {\r\n      this.renderer.removeChild(document.body, this.overlayElement);\r\n      this.overlayElement = null;\r\n    }\r\n  }\r\n \r\n  ngOnDestroy() {\r\n    this.removeOverlay();\r\n  }\r\n}\r\n","<div\r\n  class=\"h-full flex flex-row p-2 kv-table-viewer overflow-hidden {{\r\n    isEmptyTable() ? 'empty-table' : ''\r\n  }}\"\r\n>\r\n  @if(!this.selectedItem() || !isMobile() && !selectableTable()) {\r\n  <div\r\n    class=\"h-full {{ handleTableSize() }} m-0 p-0 flex flex-column gap-2\"\r\n    [style.transition]=\"'all 0.3s ease-in-out'\"\r\n  >\r\n    @if(showHeaderTemplate()) {\r\n    <div>\r\n      <ng-content select=\"[tableHeaderTemplate]\"> </ng-content>\r\n    </div>\r\n    }\r\n\r\n    <div\r\n      class=\"flex flex-row align-items-center justify-content-between flex-initial\"\r\n    >\r\n      <div class=\"flex flex-row align-items-center gap-2\">\r\n        @if(searchInput()) {\r\n        <input\r\n          style=\"height: 1.875rem\"\r\n          placeholder=\"Pesquisar...\"\r\n          type=\"text\"\r\n          pInputText\r\n          [(ngModel)]=\"searchValue\"\r\n          class=\"text-xs\"\r\n        />\r\n\r\n        } @if(filterButton()) {\r\n        <kv-button\r\n          label=\"Filtrar\"\r\n          icon=\"filter_alt\"\r\n          severity=\"tertiary\"\r\n          (onClick)=\"toggleOverlayPanel($event)\"\r\n        ></kv-button>\r\n        }\r\n\r\n        <p-overlayPanel #op [dismissable]=\"false\">\r\n          <ng-content select=\"[filtro]\"> </ng-content>\r\n        </p-overlayPanel>\r\n      </div>\r\n      <div class=\"flex flex-row gap-2\">\r\n        @if(actionsHeader()) { @for(action of actionsHeader(); track $index) {\r\n        <kv-button\r\n          [icon]=\"action?.icon || ''\"\r\n          [label]=\"action?.label || ''\"\r\n          [severity]=\"action['severity'] || 'tertiary'\"\r\n          (onClick)=\"action?.command($event)\"\r\n          [popupIcon]=\"false\"\r\n          [items]=\"action.items || []\"\r\n          [popup]=\"isPopupButton()(action)\"\r\n        ></kv-button>\r\n        } } @if(selectedItem()) {\r\n        <kv-button\r\n          [pTooltip]=\"'Recolher'\"\r\n          icon=\"reorder\"\r\n          severity=\"tertiary\"\r\n          (onClick)=\"selectedItem.set(null)\"\r\n        ></kv-button>\r\n        }\r\n      </div>\r\n    </div>\r\n\r\n    <div class=\"flex-1 h-full overflow-hidden\">\r\n      <p-table\r\n        [value]=\"data()\"\r\n        [lazy]=\"lazy()\"\r\n        [selectionPageOnly]=\"selectionPageOnly()\"\r\n        [columns]=\"columns()\"\r\n        [paginator]=\"paginator()\"\r\n        [rows]=\"rows()\"\r\n        [totalRecords]=\"totalRecords()\"\r\n        [loading]=\"loading()\"\r\n        [pageLinks]=\"pageLinks()\"\r\n        [first]=\"first()\"\r\n        [scrollable]=\"scrollable()\"\r\n        scrollHeight=\"flex\"\r\n        [showCurrentPageReport]=\"true\"\r\n        [currentPageReportTemplate]=\"currentPageReportTemplate()\"\r\n        (onPage)=\"handlePageChange($event)\"\r\n        (onSort)=\"handleSort($event)\"\r\n        [rowsPerPageOptions]=\"rowsPerPageOptions()\"\r\n        [(selection)]=\"selectedItems\"\r\n        styleClass=\"p-datatable-sm text-xs overflow-y-auto h-full flex flex-column h-full\"\r\n      >\r\n        @if(showHeader()) {\r\n        <ng-template pTemplate=\"header\" let-columns>\r\n          <tr>\r\n            @if(selectableTable()) {\r\n            <th style=\"width: 4rem\"><p-tableHeaderCheckbox /></th>\r\n            } @for (col of columns; track col.field) {\r\n            <th\r\n              [pSortableColumn]=\"col.field\"\r\n              [pSortableColumnDisabled]=\"!col?.sortable\"\r\n              [style]=\"{ width: col.width || 'auto' }\"\r\n            >\r\n              <div class=\"flex flex-row align-items-center gap-1\">\r\n                <span>{{ col.header }}</span>\r\n                @if (col.sortable) {\r\n                <p-sortIcon [field]=\"col.field\" class=\"pb-1\"></p-sortIcon>\r\n                }\r\n              </div>\r\n            </th>\r\n            }\r\n          </tr>\r\n        </ng-template>\r\n        }\r\n\r\n        <ng-template pTemplate=\"body\" let-rowData let-columns=\"columns\">\r\n          <tr\r\n            class=\"cursor-pointer {{\r\n              verifyItemSelecionado()(rowData) && 'bg-gray-100'\r\n            }} hover:bg-gray-200\"\r\n          >\r\n            @if(selectableTable()) {\r\n            <td><p-tableCheckbox [value]=\"rowData\" /></td>\r\n            } @for (col of columns; track col.field) {\r\n            <td (click)=\"rowSelect(rowData)\" style=\"word-break: break-all;\">\r\n              @if(col?.template) {\r\n              <div class=\"flex flex-row gap-2 align-items-center\">\r\n                @if (getCustomTemplate()(col.template.name)) {\r\n                <ng-container\r\n                  [ngTemplateOutlet]=\"getCustomTemplate()(col.template.name)\"\r\n                  [ngTemplateOutletContext]=\"{ $implicit: rowData }\"\r\n                />\r\n                }\r\n              </div>\r\n              } @else if(col?.icon) {\r\n              <span class=\"material-symbols-outlined text-lg\">\r\n                {{ col.icon(rowData) }}\r\n              </span>\r\n              } @else if(col?.tag) {\r\n              <kv-tags [tags]=\"[col.tag(rowData)]\" />\r\n              } @else {\r\n              {{ transformData()(col.pipe, rowData[col.field]) }}\r\n              }\r\n            </td>\r\n            }\r\n          </tr>\r\n        </ng-template>\r\n\r\n        <ng-template pTemplate=\"emptymessage\">\r\n          <tr>\r\n            <td [attr.colspan]=\"returnColspan()\">\r\n              <div\r\n                class=\"w-full h-full flex align-items-center justify-content-center\"\r\n              >\r\n                <img [src]=\"emptyTableImg()\" class=\"h-10rem w-auto\" />\r\n              </div>\r\n            </td>\r\n          </tr>\r\n        </ng-template>\r\n      </p-table>\r\n    </div>\r\n  </div>\r\n\r\n  }\r\n\r\n  <div\r\n    class=\"shadow-2 p-0 m-0 col selected-item-field ml-2 flex flex-column\"\r\n    [@slideInOut]=\"isRowSelected() ? 'i.n' : 'out'\"\r\n    [style.overflow]=\"'hidden'\"\r\n  >\r\n    @if(hasSelectedItems()) {\r\n    <actions-lote-field\r\n      class=\"h-full\"\r\n      [selectedItems]=\"selectedItems()\"\r\n      [actionsLote]=\"actionsLote()\"\r\n    />\r\n    } @else if(showSelectedItem()) {\r\n    <div class=\"bg-gray-100 w-full h-auto p-2 relative\">\r\n      @if(hasActionsRow()) {\r\n      <actions-row-menu [actionsRow]=\"actionsRow()\" />\r\n      }\r\n\r\n      @if(isMobile()) {\r\n        <div class=\"h-2rem w-2rem\">\r\n          <kv-button\r\n            icon=\"arrow_back\"\r\n            severity=\"tertiary\"\r\n            [pTooltip]=\"'Voltar'\"\r\n            (onClick)=\"selectedItem.set(null)\"\r\n          />\r\n        </div>\r\n      }\r\n\r\n      <ng-content select=\"[selectedItemHeader]\"></ng-content>\r\n    </div>\r\n    <div class=\"p-2 overflow-y-auto h-full\">\r\n      <ng-content select=\"[selectedItem]\"></ng-content>\r\n    </div>\r\n    }\r\n\r\n    <!-- @else { Nenhum item selecionado } -->\r\n  </div>\r\n</div>\r\n"]}
293
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-table-viewer.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-table-viewer/kv-table-viewer.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-table-viewer/kv-table-viewer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, contentChildren, effect, ElementRef, HostListener, inject, input, OnDestroy, output, Renderer2, signal, TemplateRef, untracked, ViewChild } from '@angular/core';\r\nimport { ButtonModule } from 'primeng/button';\r\nimport { SkeletonModule } from 'primeng/skeleton';\r\nimport { TableModule, TablePageEvent } from 'primeng/table';\r\nimport { KvInputsModule } from \"../kv-inputs/kv-inputs.module\";\r\nimport { KvButtonModule } from \"../kv-button/kv-button.module\";\r\nimport { OverlayPanel, OverlayPanelModule } from 'primeng/overlaypanel';\r\nimport { ActionsLoteFieldComponent } from './components/actions-lote-field/actions-lote-field.component';\r\nimport { KvTagsModule } from \"../kv-tags/kv-tags.module\";\r\nimport { CommonModule, DatePipe } from '@angular/common';\r\nimport { animate, state, style, transition, trigger } from '@angular/animations';\r\nimport { TooltipModule } from 'primeng/tooltip';\r\nimport { MenuItem } from 'primeng/api';\r\nimport { TieredMenuModule } from 'primeng/tieredmenu';\r\nimport { ActionsRowMenuComponent } from './components/actions-row-menu/actions-row-menu.component';\r\nimport { CpfCnpjPipe } from '../../api/pipes/cpfcnpj.pipe';\r\nimport { TelefonePipe } from '../../api/pipes/telefone.pipe';\r\nimport { TemplateDirective } from '../../api/directives/template/template.directive';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { InputTextModule } from 'primeng/inputtext';\r\nimport { BreakpointObserver, Breakpoints } from '@angular/cdk/layout';\r\n\r\ninterface ColumnTableViewer {\r\n  field: string;\r\n  header: string;\r\n  width?: string;\r\n  icon?: (rowData: any) => string;\r\n  tag?: (rowData: any) => { label: string, severity: string, icon: string };\r\n  pipe?: 'cpfcnpj' | 'telefone' | 'money' | 'date' | 'datetime' | 'dateMonthYear' | undefined;\r\n  template?: { name: string };\r\n}\r\n\r\n@Component({\r\n  selector: 'kv-table-viewer',\r\n  standalone: true,\r\n  imports: [InputTextModule, CommonModule, TooltipModule, TableModule, SkeletonModule, ButtonModule, KvInputsModule, KvButtonModule, OverlayPanelModule, ActionsLoteFieldComponent, KvTagsModule, TieredMenuModule, ActionsRowMenuComponent, FormsModule],\r\n  templateUrl: './kv-table-viewer.component.html',\r\n  styleUrl: './kv-table-viewer.component.scss',\r\n  animations: [\r\n    trigger('slideInOut', [\r\n      state('in', style({\r\n        width: '*',\r\n        opacity: 1,\r\n        transform: 'translateX(0)'\r\n      })),\r\n      state('out', style({\r\n        width: '0px',\r\n        opacity: 0,\r\n        transform: 'translateX(100%)'\r\n      })),\r\n      transition('out => in', [\r\n        animate('300ms ease-in-out')\r\n      ]),\r\n      transition('in => out', [\r\n        animate('200ms ease-in-out')\r\n      ])\r\n    ])\r\n  ]\r\n})\r\nexport class KvTableViewerComponent implements OnDestroy {\r\n\r\n  @ViewChild('op') op!: OverlayPanel;\r\n\r\n  cpfCnpjPipe = inject(CpfCnpjPipe);\r\n  telefonePipe = inject(TelefonePipe);\r\n  datePipe = inject(DatePipe);\r\n  breakpointObserver = inject(BreakpointObserver);\r\n  elementRef = inject(ElementRef);\r\n  renderer = inject(Renderer2);\r\n\r\n  columns = input<ColumnTableViewer[]>([]);\r\n\r\n  actionsRow = input<MenuItem[] | []>([]);\r\n  actionsHeader = input<MenuItem[] | undefined>(undefined);\r\n  actionsLote = input<MenuItem[] | undefined>(undefined);\r\n\r\n  data = input<any[]>([]);\r\n  totalRecords = input<number>(0);\r\n  loading = input<boolean>(false);\r\n  rows = input<number>(10);\r\n  rowsPerPageOptions = input<number[]>([10, 25, 50]);\r\n  paginator = input<boolean>(true);\r\n  lazy = input<boolean>(true);\r\n  scrollable = input<boolean>(true);\r\n  pageLinks = input<number>(2);\r\n  currentPageReportTemplate = input<string>('{first} - {last} de {totalRecords}');\r\n  selectionPageOnly = input<boolean>(true);\r\n\r\n\r\n  selectableTable = input<boolean>(true);\r\n  showHeader = input<boolean>(true);\r\n  showHeaderTemplate = input<boolean>(false);\r\n  tableViewerSize = input<string>('col-8');\r\n  searchInput = input<boolean>(true);\r\n  filterButton = input<boolean>(true);\r\n  idName = input<string | undefined>(undefined);\r\n  emptyTableImg = input<string>('https://work-assets.keevo.com.br/img/Nenhum_registro_localizado.png');\r\n  isSelectedPrimaryItem = input<boolean>(false);\r\n\r\n  private overlayElement: HTMLElement | null = null;\r\n\r\n  selectedItems = signal<any[]>([]);\r\n  selectedItem = signal<any>(null);\r\n  first = signal<number>(0);\r\n  searchValue = signal('');\r\n  lastEmittedSort = signal<{ field: string, order: number } | null>(null);\r\n  isMobile = signal(false);\r\n  \r\n\r\n  onPageChange = output<TablePageEvent>();\r\n  onClickRowItem = output<any>();\r\n  onSelectItems = output<any[]>();\r\n  onSearch = output<string>();\r\n  onSort = output<any>();\r\n\r\n  templates = contentChildren(TemplateDirective);\r\n  _templates = input<Record<string, TemplateRef<any>>>({}, { alias: 'templates' });\r\n  getCustomTemplate = computed(() => (templatename: string): TemplateRef<any> | null => {\r\n    const templates = this._templates();\r\n    return templates[templatename];\r\n  });\r\n\r\n  isRowSelected = computed(() => {\r\n    return this.selectedItems()?.length > 0 || this.selectedItem();\r\n  });\r\n\r\n  verifyItemSelecionado = computed(() => (rowData: any) => {\r\n    let isSelected;\r\n\r\n    let idName = this.idName() || 'id';\r\n\r\n    if (this.selectableTable())\r\n      isSelected = this.selectedItems().find((item: any) => item[idName] == rowData[idName]);\r\n    else isSelected = this.selectedItem()?.[idName] == rowData[idName];\r\n\r\n    return isSelected;\r\n  })\r\n\r\n  transformData = computed(() => (type: string, value: any) => {\r\n    if (type === 'cpfcnpj') return this.cpfCnpjPipe.transform(value);\r\n    if (type === 'telefone') return this.telefonePipe.transform(value);\r\n    if (type === 'money') return this.transformMoney(value);\r\n    if (type === 'date') return this.datePipe.transform(value, 'dd/MM/yyyy', 'UTC');\r\n    if (type === 'datetime') return this.datePipe.transform(value, 'dd/MM/yyyy HH:mm');\r\n    if (type === 'dateMonthYear') return this.datePipe.transform(value, 'MM/yyyy');\r\n\r\n    else return value;\r\n  })\r\n\r\n  handleTableSize = computed(() => {\r\n    const selectedItems = this.selectedItems();\r\n    const selectedItem = this.selectedItem();\r\n\r\n    if (selectedItems?.length == 0 && !selectedItem)\r\n      return 'col-12';\r\n    else return this.tableViewerSize();\r\n  })\r\n\r\n  isPopupButton = computed(() => (action: any) => {\r\n    return (action.items && action.items?.length > 0) || false;\r\n  })\r\n\r\n  hasActionsRow = computed(() => {\r\n    return this.actionsRow()?.length > 0;\r\n  })\r\n\r\n  showSelectedItem = computed(() => {\r\n    return this.selectedItems()?.length == 1 || this.selectedItem();\r\n  })\r\n\r\n  hasSelectedItems = computed(() => {\r\n    return this.selectedItems()?.length > 1;\r\n  })\r\n\r\n\r\n  returnColspan = computed(() => {\r\n    return this.columns().length + 1;\r\n  });\r\n\r\n  isEmptyTable = computed(() => {\r\n    return this.data()?.length == 0\r\n  });\r\n\r\n  constructor() {\r\n\r\n    this.breakpointObserver\r\n      .observe([Breakpoints.HandsetPortrait, '(max-width: 768px)'])\r\n      .subscribe(state => this.isMobile.set(state.matches));\r\n\r\n    effect(() => {\r\n      this.onSelectItems.emit(this.selectedItems());\r\n      this.onSearch.emit(this.searchValue());\r\n    });\r\n\r\n    effect(() => {\r\n        const dados = this.data();\r\n        const isSelectedPrimaryItem = this.isSelectedPrimaryItem();\r\n\r\n        if(dados && dados.length > 0 && isSelectedPrimaryItem) {\r\n          untracked(() => this.rowSelect(dados[0]));\r\n        }\r\n    });\r\n  }\r\n\r\n  toggleOverlayPanel(event: Event) {\r\n    event.stopPropagation();\r\n    this.op.toggle(event);\r\n\r\n    setTimeout(() => {\r\n      if(this.op.overlayVisible) {\r\n        this.createOverlay();\r\n      } else {\r\n        this.removeOverlay();\r\n      }\r\n    }, 0);\r\n  }\r\n\r\n  @HostListener('document:click', ['$event'])\r\n  onClickOutside(event: MouseEvent) {\r\n    if (!this.op || !this.op.overlayVisible) {\r\n      return;\r\n    }\r\n\r\n    const targetElement = event.target as HTMLElement;\r\n    \r\n    const filterButton = this.elementRef.nativeElement.querySelector('[label=\"Filtrar\"]');\r\n    if (filterButton && filterButton.contains(targetElement)) {\r\n      return;\r\n    }\r\n\r\n    if (targetElement.closest('.p-overlaypanel')) {\r\n      return;\r\n    }\r\n  }\r\n\r\n  public closeFilter() {\r\n    this.op?.hide();\r\n    this.removeOverlay();\r\n  }\r\n\r\n  public toggleFilter(event?: MouseEvent) {\r\n    if(event) {\r\n      event.stopPropagation();\r\n    }\r\n    this.op?.toggle(event);\r\n  }\r\n\r\n  private createOverlay() {\r\n    if(this.overlayElement) {\r\n      return;\r\n    }\r\n\r\n    this.overlayElement = this.renderer.createElement('div');\r\n    this.renderer.addClass(this.overlayElement, 'filter-overlay');\r\n\r\n    this.renderer.listen(this.overlayElement, 'click', () => {\r\n      this.closeFilter();\r\n    })\r\n\r\n    this.renderer.appendChild(document.body, this.overlayElement);\r\n  }\r\n\r\n  handlePageChange(event: TablePageEvent) {\r\n    this.first.set(event.first);\r\n    this.onPageChange.emit(event);\r\n  }\r\n\r\n  handleSort(event: any) {\r\n    const currentSortState = this.lastEmittedSort();\r\n\r\n    if (currentSortState && currentSortState.field === event.field && currentSortState.order === event.order) {\r\n      return;\r\n    }\r\n\r\n    this.lastEmittedSort.set({ field: event.field, order: event.order });\r\n\r\n    let ordenacao = `${event.field} ${event.order === 1 ? 'ASC' : 'DESC'} `;\r\n    let ordernacaoGroup = { column: event.field, direction: event.order === 1 ? 'ASC' : 'DESC' };\r\n    this.onSort.emit({ ordenacao: ordenacao, ordernacaoGroup: ordernacaoGroup });\r\n  }\r\n\r\n  rowSelect(rowData: any) {\r\n    if (this.selectableTable()) {\r\n      if (this.selectedItems().includes(rowData))\r\n        this.selectedItems.update((items: any[]) => items.filter(item => item !== rowData));\r\n      else this.selectedItems.update((items: any[]) => [...items, rowData]);\r\n\r\n      if (this.selectedItems()?.length === 1)\r\n        this.onClickRowItem.emit(this.selectedItems()[0]);\r\n      else this.onClickRowItem.emit(rowData);\r\n    } else {\r\n      this.selectedItem.set(rowData);\r\n      this.onClickRowItem.emit(rowData);\r\n    }\r\n\r\n  }\r\n\r\n  transformMoney(valor: number): string {\r\n    const formatter = new Intl.NumberFormat('pt-BR', {\r\n      style: 'currency',\r\n      currency: 'BRL',\r\n    });\r\n\r\n    return formatter.format(valor);\r\n  }\r\n\r\n  removeOverlay() {\r\n    if(this.overlayElement) {\r\n      this.renderer.removeChild(document.body, this.overlayElement);\r\n      this.overlayElement = null;\r\n    }\r\n  }\r\n \r\n  ngOnDestroy() {\r\n    this.removeOverlay();\r\n  }\r\n}\r\n","<div\r\n  class=\"h-full flex flex-row p-2 kv-table-viewer overflow-hidden {{\r\n    isEmptyTable() ? 'empty-table' : ''\r\n  }}\"\r\n>\r\n  @if(!this.selectedItem() || !isMobile() && !selectableTable()) {\r\n  <div\r\n    class=\"h-full {{ handleTableSize() }} m-0 p-0 flex flex-column gap-2\"\r\n    [style.transition]=\"'all 0.3s ease-in-out'\"\r\n  >\r\n    @if(showHeaderTemplate()) {\r\n    <div>\r\n      <ng-content select=\"[tableHeaderTemplate]\"> </ng-content>\r\n    </div>\r\n    }\r\n\r\n    <div\r\n      class=\"flex flex-row align-items-center justify-content-between flex-initial\"\r\n    >\r\n      <div class=\"flex flex-row align-items-center gap-2\">\r\n        @if(searchInput()) {\r\n        <input\r\n          style=\"height: 1.875rem\"\r\n          placeholder=\"Pesquisar...\"\r\n          type=\"text\"\r\n          pInputText\r\n          [(ngModel)]=\"searchValue\"\r\n          class=\"text-xs\"\r\n        />\r\n\r\n        } @if(filterButton()) {\r\n        <kv-button\r\n          label=\"Filtrar\"\r\n          icon=\"filter_alt\"\r\n          severity=\"tertiary\"\r\n          (onClick)=\"toggleOverlayPanel($event)\"\r\n        ></kv-button>\r\n        }\r\n\r\n        <p-overlayPanel #op [dismissable]=\"false\">\r\n          <ng-content select=\"[filtro]\"> </ng-content>\r\n        </p-overlayPanel>\r\n      </div>\r\n      <div class=\"flex flex-row gap-2\">\r\n        @if(actionsHeader()) { @for(action of actionsHeader(); track $index) {\r\n        <kv-button\r\n          [icon]=\"action?.icon || ''\"\r\n          [label]=\"action?.label || ''\"\r\n          [severity]=\"action['severity'] || 'tertiary'\"\r\n          (onClick)=\"action?.command($event)\"\r\n          [popupIcon]=\"false\"\r\n          [items]=\"action.items || []\"\r\n          [popup]=\"isPopupButton()(action)\"\r\n        ></kv-button>\r\n        } } @if(selectedItem()) {\r\n        <kv-button\r\n          [pTooltip]=\"'Recolher'\"\r\n          icon=\"reorder\"\r\n          severity=\"tertiary\"\r\n          (onClick)=\"selectedItem.set(null)\"\r\n        ></kv-button>\r\n        }\r\n      </div>\r\n    </div>\r\n\r\n    <div class=\"flex-1 h-full overflow-hidden\">\r\n      <p-table\r\n        [value]=\"data()\"\r\n        [lazy]=\"lazy()\"\r\n        [selectionPageOnly]=\"selectionPageOnly()\"\r\n        [columns]=\"columns()\"\r\n        [paginator]=\"paginator()\"\r\n        [rows]=\"rows()\"\r\n        [totalRecords]=\"totalRecords()\"\r\n        [loading]=\"loading()\"\r\n        [pageLinks]=\"pageLinks()\"\r\n        [first]=\"first()\"\r\n        [scrollable]=\"scrollable()\"\r\n        scrollHeight=\"flex\"\r\n        [showCurrentPageReport]=\"true\"\r\n        [currentPageReportTemplate]=\"currentPageReportTemplate()\"\r\n        (onPage)=\"handlePageChange($event)\"\r\n        (onSort)=\"handleSort($event)\"\r\n        [rowsPerPageOptions]=\"rowsPerPageOptions()\"\r\n        [(selection)]=\"selectedItems\"\r\n        styleClass=\"p-datatable-sm text-xs overflow-y-auto h-full flex flex-column h-full\"\r\n      >\r\n        @if(showHeader()) {\r\n        <ng-template pTemplate=\"header\" let-columns>\r\n          <tr>\r\n            @if(selectableTable()) {\r\n            <th style=\"width: 4rem\"><p-tableHeaderCheckbox /></th>\r\n            } @for (col of columns; track col.field) {\r\n            <th\r\n              [pSortableColumn]=\"col.field\"\r\n              [pSortableColumnDisabled]=\"!col?.sortable\"\r\n              [style]=\"{ width: col.width || 'auto' }\"\r\n            >\r\n              <div class=\"flex flex-row align-items-center gap-1\">\r\n                <span>{{ col.header }}</span>\r\n                @if (col.sortable) {\r\n                <p-sortIcon [field]=\"col.field\" class=\"pb-1\"></p-sortIcon>\r\n                }\r\n              </div>\r\n            </th>\r\n            }\r\n          </tr>\r\n        </ng-template>\r\n        }\r\n\r\n        <ng-template pTemplate=\"body\" let-rowData let-columns=\"columns\">\r\n          <tr\r\n            class=\"cursor-pointer {{\r\n              verifyItemSelecionado()(rowData) && 'bg-gray-100'\r\n            }} hover:bg-gray-200\"\r\n          >\r\n            @if(selectableTable()) {\r\n            <td><p-tableCheckbox [value]=\"rowData\" /></td>\r\n            } @for (col of columns; track col.field) {\r\n            <td (click)=\"rowSelect(rowData)\" style=\"word-break: break-all;\">\r\n              @if(col?.template) {\r\n              <div class=\"flex flex-row gap-2 align-items-center\">\r\n                @if (getCustomTemplate()(col.template.name)) {\r\n                <ng-container\r\n                  [ngTemplateOutlet]=\"getCustomTemplate()(col.template.name)\"\r\n                  [ngTemplateOutletContext]=\"{ $implicit: rowData }\"\r\n                />\r\n                }\r\n              </div>\r\n              } @else if(col?.icon) {\r\n              <span class=\"material-symbols-outlined text-lg\">\r\n                {{ col.icon(rowData) }}\r\n              </span>\r\n              } @else if(col?.tag) {\r\n              <kv-tags [tags]=\"[col.tag(rowData)]\" />\r\n              } @else {\r\n              {{ transformData()(col.pipe, rowData[col.field]) }}\r\n              }\r\n            </td>\r\n            }\r\n          </tr>\r\n        </ng-template>\r\n\r\n        <ng-template pTemplate=\"emptymessage\">\r\n          <tr>\r\n            <td [attr.colspan]=\"returnColspan()\">\r\n              <div\r\n                class=\"w-full h-full flex align-items-center justify-content-center\"\r\n              >\r\n                <img [src]=\"emptyTableImg()\" class=\"h-10rem w-auto\" />\r\n              </div>\r\n            </td>\r\n          </tr>\r\n        </ng-template>\r\n      </p-table>\r\n    </div>\r\n  </div>\r\n\r\n  }\r\n\r\n  <div\r\n    class=\"shadow-2 p-0 m-0 col selected-item-field ml-2 flex flex-column\"\r\n    [@slideInOut]=\"isRowSelected() ? 'i.n' : 'out'\"\r\n    [style.overflow]=\"'hidden'\"\r\n  >\r\n    @if(hasSelectedItems()) {\r\n    <actions-lote-field\r\n      class=\"h-full\"\r\n      [selectedItems]=\"selectedItems()\"\r\n      [actionsLote]=\"actionsLote()\"\r\n    />\r\n    } @else if(showSelectedItem()) {\r\n    <div class=\"bg-gray-100 w-full h-auto p-2 relative\">\r\n      @if(hasActionsRow()) {\r\n      <actions-row-menu [actionsRow]=\"actionsRow()\" />\r\n      }\r\n\r\n      @if(isMobile()) {\r\n        <div class=\"h-2rem w-2rem\">\r\n          <kv-button\r\n            icon=\"arrow_back\"\r\n            severity=\"tertiary\"\r\n            [pTooltip]=\"'Voltar'\"\r\n            (onClick)=\"selectedItem.set(null)\"\r\n          />\r\n        </div>\r\n      }\r\n\r\n      <ng-content select=\"[selectedItemHeader]\"></ng-content>\r\n    </div>\r\n    <div class=\"p-2 overflow-y-auto h-full\">\r\n      <ng-content select=\"[selectedItem]\"></ng-content>\r\n    </div>\r\n    }\r\n\r\n    <!-- @else { Nenhum item selecionado } -->\r\n  </div>\r\n</div>\r\n"]}