@rubeusteam/rb-angular-components
Version:
Adição do componente rb-change-log-dialog
1 lines • 69.3 kB
Source Map (JSON)
{"version":3,"file":"rubeusteam-rb-angular-components.mjs","sources":["../../../projects/rb-angular-components/src/lib/pipes/rb-custom/rb-custom.pipe.ts","../../../projects/rb-angular-components/src/lib/i18n/paginator-ptbr-intl/paginator-ptbr-intl.service.ts","../../../projects/rb-angular-components/src/lib/services/filter/client-filter.service.ts","../../../projects/rb-angular-components/src/lib/components/rb-crud/rb-crud.component.ts","../../../projects/rb-angular-components/src/lib/components/rb-crud/rb-crud.component.html","../../../projects/rb-angular-components/src/lib/directives/rb-dynamic-button/rb-dynamic-button.directive.ts","../../../projects/rb-angular-components/src/lib/components/rb-crud-tool-bar/rb-crud-tool-bar.component.ts","../../../projects/rb-angular-components/src/lib/components/rb-crud-tool-bar/rb-crud-tool-bar.component.html","../../../projects/rb-angular-components/src/lib/components/rb-content-box/rb-content-box.component.ts","../../../projects/rb-angular-components/src/lib/components/rb-content-box/rb-content-box.component.html","../../../projects/rb-angular-components/src/lib/components/rb-dialog/rb-dialog.component.ts","../../../projects/rb-angular-components/src/lib/components/rb-dialog/rb-dialog.component.html","../../../projects/rb-angular-components/src/lib/components/rb-filter-dropdown/rb-filter-dropdown.component.ts","../../../projects/rb-angular-components/src/lib/components/rb-filter-dropdown/rb-filter-dropdown.component.html","../../../projects/rb-angular-components/src/lib/components/rb-filter-panel/rb-filter-panel.component.ts","../../../projects/rb-angular-components/src/lib/components/rb-filter-panel/rb-filter-panel.component.html","../../../projects/rb-angular-components/src/lib/components/rb-copy-confirm-dialog/rb-copy-confirm-dialog.component.ts","../../../projects/rb-angular-components/src/lib/components/rb-copy-confirm-dialog/rb-copy-confirm-dialog.component.html","../../../projects/rb-angular-components/src/lib/components/rb-change-log-dialog/rb-change-log-dialog.component.ts","../../../projects/rb-angular-components/src/lib/components/rb-change-log-dialog/rb-change-log-dialog.component.html","../../../projects/rb-angular-components/src/lib/pipes/is-array.pipe.ts","../../../projects/rb-angular-components/src/lib/interfaces/rb-crud.interface.ts","../../../projects/rb-angular-components/src/public-api.ts","../../../projects/rb-angular-components/src/rubeusteam-rb-angular-components.ts"],"sourcesContent":["import { Pipe, PipeTransform } from '@angular/core';\n\n@Pipe({\n name: 'rbCustomPipe',\n standalone: true\n})\nexport class RbCustomPipe implements PipeTransform {\n\n transform(value: any, type: string): any {\n switch (type) {\n case 'date':\n return this.dateTransform(value);\n case 'datetime':\n return this.dateTimeTransform(value);\n case 'currency':\n return this.currencyTransform(value);\n case 'cpf':\n return this.cpfTransform(value);\n case 'cnpj':\n return this.cnpjTransform(value);\n case 'phone':\n return this.phoneTransform(value);\n case 'cep':\n return this.cepTransform(value);\n case 'mask':\n return this.maskTransform(value);\n case 'relativeTime':\n return this.relativeTimeTransform(value);\n case 'lastModifiedBy':\n return this.lastModifiedTransform(value);\n default:\n return value;\n }\n }\n\n dateTransform(value: any, format?: string): any {\n if (!value || typeof value !== 'string') return '';\n const isoString = value.includes(' ')\n ? value.replace(' ', 'T')\n : `${value}T00:00:00`;\n const date = new Date(isoString);\n if (isNaN(date.getTime())) return '';\n return date.toLocaleDateString('pt-BR', {\n timeZone: 'America/Sao_Paulo'\n });\n }\n\n private dateTimeTransform(value: any): string {\n if (!value || typeof value !== 'string') return '';\n\n const isoString = value.includes(' ')\n ? value.replace(' ', 'T')\n : `${value}T00:00:00`;\n const date = new Date(isoString);\n \n if (isNaN(date.getTime())) return '';\n\n const datePart = new Intl.DateTimeFormat('pt-BR', {\n day: '2-digit',\n month: '2-digit',\n year: 'numeric',\n timeZone: 'America/Sao_Paulo'\n }).format(date);\n\n const timePart = new Intl.DateTimeFormat('pt-BR', {\n hour: '2-digit',\n minute: '2-digit',\n hour12: false,\n timeZone: 'America/Sao_Paulo'\n }).format(date);\n\n return `${datePart} às ${timePart}`;\n }\n\n\n currencyTransform(value: any): any {\n if (!value) return '';\n return new Intl.NumberFormat('pt-BR', { style: 'currency', currency: 'BRL' }).format(value);\n }\n\n cpfTransform(value: any): any {\n if (!value) return '';\n return value.replace(/(\\d{3})(\\d{3})(\\d{3})(\\d{2})/, \"$1.$2.$3-$4\");\n }\n\n cnpjTransform(value: any): any {\n if (!value) return '';\n return value.replace(/(\\d{2})(\\d{3})(\\d{3})(\\d{4})(\\d{2})/, \"$1.$2.$3/$4-$5\");\n }\n\n phoneTransform(value: any): any {\n if (!value) return '';\n return value.replace(/(\\d{2})(\\d{5})(\\d{4})/, \"($1) $2-$3\");\n }\n\n cepTransform(value: any): any {\n if (!value) return '';\n return value.replace(/(\\d{5})(\\d{3})/, \"$1-$2\");\n }\n\n maskTransform(value: any): any {\n if (!value) return '';\n return '*'.repeat(value.toString().length);\n }\n\n relativeTimeTransform(value: any): any {\n if (!value) return '';\n const date = new Date(value);\n const now = new Date();\n const diff = Math.floor((now.getTime() - date.getTime()) / 1000);\n\n switch (true) {\n case diff < 60:\n return `${diff} segundos atrás`;\n case diff < 3600:\n return `${Math.floor(diff / 60)} minutos atrás`;\n case diff < 86400:\n return `${Math.floor(diff / 3600)} horas atrás`;\n case diff < 2592000:\n return `${Math.floor(diff / 86400)} dias atrás`;\n case diff < 31536000:\n return `${Math.floor(diff / 2592000)} meses atrás`;\n default:\n return `${Math.floor(diff / 31536000)} anos atrás`;\n }\n }\n\n lastModifiedTransform(value: { date: string; author: string }): string {\n if (!value || !value.date) return '';\n const formattedDate = new Intl.DateTimeFormat('pt-BR', {\n dateStyle: 'short',\n // timeStyle: 'short',\n timeZone: 'America/Sao_Paulo'\n }).format(new Date(value.date));\n if(!value.author) {\n return `${formattedDate}`;\n }\n return `${formattedDate} por ${value.author}`;\n }\n\n}\n","import { Injectable } from '@angular/core';\nimport { MatPaginatorIntl } from '@angular/material/paginator';\n\n@Injectable({\n providedIn: 'root'\n})\nexport class PaginatorPtbrIntlService extends MatPaginatorIntl{\n override itemsPerPageLabel = 'Itens por página:';\n override nextPageLabel = 'Próxima';\n override previousPageLabel = 'Anterior';\n override firstPageLabel = 'Primeira página';\n override lastPageLabel = 'Última página';\n\n override getRangeLabel = (page: number, pageSize: number, length: number) => {\n if (length === 0 || pageSize === 0) {\n return `Página 0 de 0`;\n }\n\n const totalPages = Math.ceil(length / pageSize);\n const currentPage = page + 1;\n\n return `Página ${currentPage} de ${totalPages}`;\n };\n\n // override getRangeLabel = (page: number, pageSize: number, length: number) => {\n // if (length === 0 || pageSize === 0) {\n // return `Página 0 de 0`;\n // }\n\n // const totalPages = Math.ceil(length / pageSize);\n // const currentPage = page + 1;\n\n // const startIndex = page * pageSize + 1;\n // const endIndex = Math.min((page + 1) * pageSize, length);\n\n // return `Página ${currentPage} de ${totalPages} (${startIndex} a ${endIndex} de ${length})`;\n // };\n\n}\n","import { Injectable, signal, Signal } from '@angular/core';\n\n@Injectable({\n providedIn: 'root'\n})\nexport class ClientFilterService {\n\n private searchText = signal<string>('');\n\n setSearchText(text: string): void {\n this.searchText.set(this.normalizeText(text));\n }\n\n public normalizeText(text: string): string {\n return text\n .normalize('NFD')\n .replace(/[\\u0300-\\u036f]/g, '')\n .toLowerCase()\n .trim();\n }\n\n getSearchText(): Signal<string> {\n return this.searchText;\n }\n}\n","import { Component, Input, Output, EventEmitter, AfterViewInit, OnChanges, ViewChild, effect, Signal, ElementRef, Renderer2 } from '@angular/core';\nimport { MatTableDataSource } from '@angular/material/table';\nimport { MatInputModule } from '@angular/material/input';\nimport { MatPaginatorModule, MatPaginator } from '@angular/material/paginator';\nimport { MatSortModule, MatSort } from '@angular/material/sort';\nimport { CommonModule } from '@angular/common';\nimport { MatTableModule } from '@angular/material/table';\nimport { MatMenuModule } from '@angular/material/menu';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatButtonModule } from '@angular/material/button';\nimport { RbCustomPipe } from '../../pipes/rb-custom/rb-custom.pipe';\n// import { IsArrayPipe } from '../../pipes/is-array.pipe';\nimport { MatPaginatorIntl } from '@angular/material/paginator';\nimport { PaginatorPtbrIntlService } from '../../i18n/paginator-ptbr-intl/paginator-ptbr-intl.service';\nimport { ClientFilterService } from '../../services/filter/client-filter.service';\nimport { CrudColumn, CrudActionEvent } from '../../interfaces/rb-crud.interface';\nimport { ButtonSettings, RbEncapsulatedButton } from '../../interfaces/button.interface';\n\n@Component({\n selector: 'rb-crud',\n templateUrl: './rb-crud.component.html',\n styleUrl: './rb-crud.component.scss',\n standalone: true,\n imports: [\n CommonModule,\n MatTableModule,\n MatMenuModule,\n MatInputModule,\n MatPaginatorModule,\n MatSortModule,\n MatIconModule,\n MatButtonModule,\n RbCustomPipe,\n // IsArrayPipe,\n ],\n providers: [\n { provide: MatPaginatorIntl, useClass: PaginatorPtbrIntlService }\n ]\n})\nexport class RbCrudComponent implements AfterViewInit, OnChanges {\n @Input() columns: CrudColumn[] = [];\n @Input() data: any[] = [];\n @Input() actionsMenu: RbEncapsulatedButton[] = [];\n @Input() pagination: boolean = true;\n @Input() pageSize: number = 10;\n @Input() infiniteScroll: boolean = false;\n @Input() textLineBreakable: boolean = false;\n\n\n @Output() actionClick = new EventEmitter<CrudActionEvent>();\n // @Output() filterChange = new EventEmitter<any>();\n @Output() pageChange = new EventEmitter<number>();\n\n @ViewChild(MatPaginator) paginator!: MatPaginator;\n @ViewChild(MatSort) sort!: MatSort;\n @ViewChild('rbTableContainer', { static: true }) rbTableContainer!: ElementRef;\n\n displayedColumns: string[] = [];\n dataSource = new MatTableDataSource<any>(this.data);\n filterText: Signal<string>;\n isOverflowing = false;\n\n renderingProgressive = false;\n private readonly THRESHOLD = 200;\n\n constructor(\n private clientFilterService: ClientFilterService,\n private renderer: Renderer2\n ) {\n this.filterText = this.clientFilterService.getSearchText();\n effect(() => {\n this.applyFilter();\n });\n }\n\n ngAfterViewInit() {\n this.dataSource.paginator = this.paginator;\n this.dataSource.sort = this.sort;\n this.defineSortRule();\n this.checkOverflow();\n window.addEventListener('resize', () => this.checkOverflow());\n }\n\n checkOverflow() {\n const el = this.rbTableContainer.nativeElement;\n const isOverflowing = el.scrollWidth > el.clientWidth;\n this.isOverflowing = isOverflowing;\n if (isOverflowing) {\n this.renderer.addClass(el, 'is-overflowing');\n } else {\n this.renderer.removeClass(el, 'is-overflowing');\n }\n }\n\n ngOnChanges(): void {\n this.displayedColumns = this.columns.map(col => col.key);\n if (this.actionsMenu.length) {\n this.displayedColumns.push('actions');\n }\n this.renderingControl();\n }\n\n renderingControl(): void {\n if (this.data.length > this.THRESHOLD) {\n this.renderingProgressive = true;\n this.renderFirstPage();\n\n setTimeout(() => {\n this.loadFullData();\n }, 100);\n } else {\n this.dataSource.data = this.data;\n this.renderingProgressive = false;\n }\n }\n\n renderFirstPage(): void {\n const firstPage = this.data.slice(0, this.pageSize);\n this.dataSource = new MatTableDataSource(firstPage);\n this.dataSource.paginator = this.paginator;\n this.dataSource.sort = this.sort;\n this.defineSortRule();\n }\n\n loadFullData(): void {\n this.dataSource = new MatTableDataSource(this.data);\n this.dataSource.paginator = this.paginator;\n this.dataSource.sort = this.sort;\n this.defineSortRule();\n this.renderingProgressive = false;\n }\n\n defineSortRule() {\n this.dataSource.sortingDataAccessor = (item, property) => {\n if (item[property]?.date) {\n return new Date(item[property]?.date || 0).getTime();\n }\n return item[property];\n };\n }\n\n onActionClick(action: ButtonSettings, row: any): void {\n this.actionClick.emit({ action: action.action, row });\n }\n\n onClickCell(action: string, row: any): void {\n this.actionClick.emit({ action: action, row });\n }\n\n // applyFilter() {\n // this.dataSource.filter = this.filterText().trim().toLowerCase().normalize('NFD').replace(/[\\u0300-\\u036f]/g, '');\n // }\n\n applyFilter() {\n this.dataSource.filterPredicate = (data: any, filter: string): boolean => {\n const accumulator = (currentTerm: string, key: string): string => {\n const value = data[key];\n return currentTerm + ' ' + (typeof value === 'string' ? this.clientFilterService.normalizeText(value) : '');\n };\n\n const dataStr = Object.keys(data).reduce(accumulator, '').trim();\n return dataStr.includes(this.clientFilterService.normalizeText(filter));\n };\n\n this.dataSource.filter = this.filterText();\n }\n\n}\n","<div class=\"rb-crud-container\">\n <div #rbTableContainer class=\"rb-table-container\">\n <table mat-table [dataSource]=\"dataSource\" matSort class=\"rb-table\">\n <!-- Colunas Dinâmicas -->\n @for (column of columns; track column.key) {\n <ng-container [matColumnDef]=\"column.key\">\n\n @if(column.sortable === false) {\n <th mat-header-cell *matHeaderCellDef>\n {{ column.label }}\n </th>\n } @else {\n <th mat-header-cell *matHeaderCellDef mat-sort-header>\n {{ column.label }}\n </th>\n }\n <td mat-cell *matCellDef=\"let row\"\n [class.rb-clickable-cell]=\"column.action\"\n [class.rb-break-line-cell]=\"textLineBreakable\"\n (click)=\"column.action ? onClickCell(column.action, row) : null\"\n title=\"{{ column.pipe ? (row[column.key] | rbCustomPipe:column.pipe) : row[column.key] }}\">\n <!-- Terminar de implementar quando for decidido como ficará quando a informação for em array de objetos.\n Não deixar como primeira condição, para evitar processamento desnecessário no pipe isArray\n @if (column.objCol?.label && (row[column.key] | isArray) && row[column.key].length){\n @for (item of row[column.key]; track $index) {\n <span>{{ item[column.objCol?.label || 'label'] }}</span>\n }\n } @else if -->\n @if (column.pipe) {\n {{ row[column.key] | rbCustomPipe:column.pipe }}\n } @else {\n {{ row[column.key] }}\n }\n </td>\n </ng-container>\n }\n\n <!-- Coluna de Ações -->\n @if (actionsMenu.length) {\n <ng-container matColumnDef=\"actions\" stickyEnd class=\"sticky-column\">\n <th mat-header-cell *matHeaderCellDef> Ações </th>\n <td mat-cell *matCellDef=\"let row\" class=\"rb-crud-actions-col\">\n <button mat-icon-button [matMenuTriggerFor]=\"menu\">\n <mat-icon>{{ 'more_vert' }}</mat-icon>\n </button>\n <mat-menu #menu=\"matMenu\" panelClass=\"rb-menu-crud\">\n @for (action of actionsMenu; track action.label) {\n <button mat-menu-item\n (click)=\"onActionClick(action, row)\"\n title=\"{{action.label}}\"\n class=\"{{action.color}}\"\n [attr.aria-label]=\"action.label\">\n @if (action.icon) {\n <mat-icon>{{ action.icon }}</mat-icon>\n }\n {{ action.label }}\n </button>\n }\n </mat-menu>\n </td>\n </ng-container>\n }\n\n <!-- Cabeçalho e Corpo da Tabela -->\n <thead>\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\n </thead>\n <tbody>\n <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\"></tr>\n </tbody>\n </table>\n </div>\n\n @if (dataSource.data.length === 0) {\n <div class=\"empty-message\">\n Nenhum dado disponível no momento.\n </div>\n }\n</div>\n\n<!-- Paginação -->\n@if (pagination) {\n <mat-paginator #paginator\n class=\"rb-paginator\"\n [pageSize]=\"pageSize\"\n (page)=\"pageChange.emit($event.pageIndex)\"\n [showFirstLastButtons]=\"true\"\n [pageSizeOptions]=\"[10,25,50,100]\"\n aria-label=\"Selecione a página\">\n </mat-paginator>\n}\n","import { Directive, Input, ElementRef, Renderer2, OnChanges, SimpleChanges } from '@angular/core';\n\n@Directive({\n selector: '[rbDynamicButton]'\n})\nexport class RbDynamicButtonDirective implements OnChanges {\n @Input('rbDynamicButton') set buttonType(value: string | null) {\n const validTypes = ['float', 'confirm', 'cancel', 'menuTrigger'] as const;\n this._buttonType = validTypes.includes(value as any) ? (value as any) : null;\n }\n private _buttonType: 'float' | 'confirm' | 'cancel' | 'menuTrigger' | null = null;\n\n buttonTypes: Record<string, { directive: string; classes: string[] }> = {\n float: {\n directive: 'mat-raised-button',\n classes: ['mdc-button--raised', 'mat-mdc-raised-button']\n },\n confirm: {\n directive: 'mat-flat-button',\n classes: ['mdc-button--unelevated', 'mat-mdc-unelevated-button']\n },\n cancel: {\n directive: 'mat-stroked-button',\n classes: ['mdc-button--outlined', 'mat-mdc-outlined-button']\n },\n menuTrigger: {\n directive: 'mat-icon-button',\n classes: ['mdc-icon-button', 'mat-mdc-icon-button']\n }\n };\n\n constructor(private el: ElementRef, private renderer: Renderer2) {\n }\n\n ngOnChanges(changes: SimpleChanges): void {\n if (changes['buttonType']?.currentValue) {\n this.renderButtons(this._buttonType || '');\n }\n }\n\n private renderButtons(key: string) {\n if (key?.trim() && typeof this.buttonTypes[key] === 'object') {\n this.renderer.setAttribute(this.el.nativeElement, this.buttonTypes[key].directive, '');\n this.buttonTypes[key].classes.forEach(cls => this.renderer.addClass(this.el.nativeElement, cls));\n }\n }\n\n}\n\n","import { Component, Input, Output, signal, EventEmitter } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatButtonModule } from '@angular/material/button';\nimport { ClientFilterService } from '../../services/filter/client-filter.service';\nimport { RbDynamicButtonDirective } from '../../directives/rb-dynamic-button/rb-dynamic-button.directive';\nimport { ButtonSettings, ButtonActionEvent, RbEncapsulatedButton } from '../../interfaces/button.interface';\n\n@Component({\n selector: 'rb-crud-tool-bar',\n standalone: true,\n imports: [\n CommonModule,\n MatFormFieldModule,\n MatInputModule,\n MatIconModule,\n MatButtonModule,\n RbDynamicButtonDirective,\n ],\n templateUrl: './rb-crud-tool-bar.component.html',\n styleUrl: './rb-crud-tool-bar.component.scss'\n})\nexport class RbCrudToolBarComponent {\n @Input() searchPlaceholder: string = 'Digite para pesquisar...';\n @Input() buttonSettings: RbEncapsulatedButton[] = [];\n @Input() iconButton: string = 'add';\n @Input() titleButton: string = 'Adicionar';\n @Input() leftButtonSettings: RbEncapsulatedButton[] = [];\n @Output() buttonClick = new EventEmitter<ButtonActionEvent>();\n\n searchText = signal<string>('');\n\n constructor(private clientFilterService: ClientFilterService) {\n }\n\n onSearchChange(event: Event) {\n const value = (event.target as HTMLInputElement).value;\n this.searchText.set(value);\n this.clientFilterService.setSearchText(value);\n }\n\n onClickButton(action: ButtonSettings) {\n this.buttonClick.emit(action);\n }\n\n}\n","<div class=\"rb-crud-tool-bar-container\">\n <div class=\"rb-flex-line-space-between\">\n <div class=\"rb-flex-align-items-center\">\n @for (btn of buttonSettings; track btn.label) {\n <button mat-button\n title=\"{{btn.label}}\"\n class=\"{{btn.color}}\"\n color=\"{{btn.color}}\"\n [attr.aria-label]=\"btn.label\"\n [rbDynamicButton]=\"btn.directive || null\"\n (click)=\"onClickButton(btn)\">\n @if (btn.icon) {\n <mat-icon>{{ btn.icon }}</mat-icon>\n }\n {{ btn.label }}\n </button>\n }\n </div>\n\n <div class=\"rb-search-box rb-flex-align-items-center\">\n <mat-form-field class=\"rb-search-field\">\n <mat-label>Pesquisar</mat-label>\n <input\n matInput\n [value]=\"searchText()\"\n (input)=\"onSearchChange($event)\"\n placeholder={{searchPlaceholder}}\n />\n <mat-icon matPrefix>search</mat-icon>\n </mat-form-field>\n @for (btn of leftButtonSettings; track btn.label) {\n <button mat-button\n title=\"{{btn.label}}\"\n class=\"{{btn.color}}\"\n color=\"{{btn.color}}\"\n [attr.aria-label]=\"btn.label\"\n [rbDynamicButton]=\"btn.directive || null\"\n (click)=\"onClickButton(btn)\">\n @if (btn.icon) {\n <mat-icon>{{ btn.icon }}</mat-icon>\n }\n {{ btn.label }}\n </button>\n }\n </div>\n </div>\n</div>\n\n","import { Component } from '@angular/core';\n\n@Component({\n selector: 'rb-content-box',\n imports: [],\n templateUrl: './rb-content-box.component.html',\n styleUrl: './rb-content-box.component.scss'\n})\nexport class RbContentBoxComponent {\n\n}\n","<div class=\"rb-content-box\">\n <ng-content></ng-content>\n</div>\n","import { Component, inject } from '@angular/core';\nimport { MatDialogModule, MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatIconModule } from '@angular/material/icon';\nimport { RbDynamicButtonDirective } from '../../directives/rb-dynamic-button/rb-dynamic-button.directive';\nimport { RbDialog } from '../../interfaces/rb-dialog.interface';\n\n@Component({\n selector: 'rb-dialog',\n imports: [MatDialogModule, MatButtonModule, MatIconModule, RbDynamicButtonDirective],\n templateUrl: './rb-dialog.component.html',\n styleUrl: './rb-dialog.component.scss'\n})\nexport class RbDialogComponent {\n readonly data = inject<RbDialog>(MAT_DIALOG_DATA);\n readonly dialogRef = inject(MatDialogRef<RbDialogComponent>);\n\n onClickButton(action: string) {\n console.log('action', action);\n this.dialogRef.close(action);\n }\n\n}\n","<div class=\"rb-dialog\">\n <!-- Cabeçalho -->\n <div class=\"rb-dialog-header\">\n <h2>{{data.title}}</h2>\n <button mat-icon-button mat-dialog-close aria-label=\"Fechar diálogo\">\n <mat-icon>close</mat-icon>\n </button>\n </div>\n\n <!-- Conteúdo -->\n <mat-dialog-content class=\"rb-dialog-content\" >\n @if (data.isMultipleContent) {\n @for (item of data.multipleContent; track $index) {\n @if (item.subtitle) {\n <h3 class=\"rb-font-heading rb-h5\">{{item.subtitle}}</h3>\n }\n @if (item.paragraph) {\n <p class=\"rb-font-body rb-large\">{{item.paragraph}}</p>\n }\n }\n } @else {\n <h3 class=\"rb-font-heading rb-h5\">{{data.subtitle}}</h3>\n <p class=\"rb-font-body rb-large\">{{data.content}}</p>\n }\n </mat-dialog-content>\n\n <!-- Ações -->\n @if (data.buttons?.length) {\n <mat-dialog-actions class=\"rb-dialog-actions\" [align]=\"data.actionsAlign || 'end'\">\n @for (button of data.buttons; track $index) {\n <button mat-button\n title=\"{{button.label}}\"\n class=\"{{button.color}}\"\n [color]=\"button.color\"\n [attr.aria-label]=\"button.label\"\n [rbDynamicButton]=\"button.directive || null\"\n (click)=\"onClickButton(button.action)\">\n @if (button.icon && button.iconPosition === 'start') {\n <mat-icon>{{button.icon}}</mat-icon>\n }\n {{button.label}}\n @if (button.icon && button.iconPosition === 'end') {\n <mat-icon>{{button.icon}}</mat-icon>\n }\n </button>\n }\n </mat-dialog-actions>\n }\n</div>\n","import { Component, TemplateRef, ViewChild, ViewContainerRef, Input, signal } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { OverlayModule, OverlayRef, Overlay } from '@angular/cdk/overlay';\nimport { PortalModule, TemplatePortal } from '@angular/cdk/portal';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatInputModule } from '@angular/material/input';\nimport { ClientFilterService } from '../../services/filter/client-filter.service';\nimport { FilterOption } from '../../interfaces/rb-filter.interface';\n\n\n@Component({\n selector: 'rb-filter-dropdown',\n imports: [CommonModule, OverlayModule, PortalModule, MatIconModule, MatInputModule],\n templateUrl: './rb-filter-dropdown.component.html',\n styleUrl: './rb-filter-dropdown.component.scss',\n standalone: true,\n})\nexport class RbFilterDropdownComponent {\n @Input() parentSelectorId: string = '#parentDropdownSelector';\n @Input() options: FilterOption[] = [];\n\n @ViewChild('filterMenu') filterMenu!: TemplateRef<any>;\n private overlayRef: OverlayRef | null = null;\n trackByFn = (index: number, item: string) => index;\n\n searchText = signal<string>('');\n\n constructor(\n private overlay: Overlay,\n private clientFilterService: ClientFilterService,\n private viewContainerRef: ViewContainerRef\n ) {}\n\n\n onSearchChange(event: Event) {\n const value = (event.target as HTMLInputElement).value;\n this.searchText.set(value);\n this.clientFilterService.setSearchText(value);\n }\n\n public openMenu() {\n if (this.overlayRef) {\n this.closeMenu();\n return;\n }\n\n const positionStrategy = this.overlay.position()\n .flexibleConnectedTo(\n document.querySelector(this.parentSelectorId || 'button')!\n )\n .withPositions([\n {\n originX: 'start',\n originY: 'bottom',\n overlayX: 'start',\n overlayY: 'top',\n },\n ]);\n\n this.overlayRef = this.overlay.create({\n positionStrategy,\n hasBackdrop: true,\n backdropClass: 'cdk-overlay-transparent-backdrop',\n scrollStrategy: this.overlay.scrollStrategies.close(),\n });\n\n const portal = new TemplatePortal(this.filterMenu, this.viewContainerRef);\n this.overlayRef.attach(portal);\n\n this.overlayRef.backdropClick().subscribe(() => this.closeMenu());\n }\n\n closeMenu() {\n this.overlayRef?.dispose();\n this.overlayRef = null;\n }\n\n onSelectItem(item: FilterOption) {\n console.log('Selected item:', item);\n // this.filterItems = this.options.filter((item) => item.includes(this.searchText()));\n // this.clientFilterService.setFilterItems(this.filterItems);\n }\n\n}\n","<ng-template #filterMenu>\n <div class=\"rb-filter-dropdown\">\n <div class=\"rb-filter-dropdown-header\">\n <h5>Adicionar Filtro</h5>\n <button mat-icon-button aria-label=\"Fechar diálogo\" (click)=\"closeMenu()\">\n <mat-icon>close</mat-icon>\n </button>\n </div>\n <div class=\"rb-filter-dropdown-body\">\n <div class=\"rb-filter-seach-bar\">\n <mat-form-field class=\"rb-search-field\">\n <mat-label>Pesquisar</mat-label>\n <input\n matInput\n [value]=\"searchText()\"\n (input)=\"onSearchChange($event)\"\n placeholder=\"Pesquisar\"\n />\n <mat-icon matPrefix>search</mat-icon>\n </mat-form-field>\n </div>\n <div class=\"rb-filter-dropdown-body-items\">\n <pre>{{options | json}}</pre>\n @if (options && options.length) {\n @for (item of options; track trackByFn) {\n <div\n class=\"rb-filter-dropdown-item\"\n (click)=\"onSelectItem(item)\"\n >\n <!-- <mat-checkbox\n [checked]=\"isSelected(item)\"\n (change)=\"onSelectItem(item, $event)\"\n >\n {{ item.label }}\n </mat-checkbox> -->\n </div>\n }\n } @else {\n <div class=\"rb-filter-dropdown-item\">\n Nenhum item encontrado\n <!-- <mat-checkbox disabled>\n <span class=\"rb-filter-dropdown-item-disabled\">\n Nenhum item encontrado\n </span>\n </mat-checkbox> -->\n </div>\n }\n </div>\n\n <!-- <div class=\"rb-filter-dropdown-body-items\">\n <div\n *ngFor=\"let item of filterItems; trackBy: trackByFn\"\n class=\"rb-filter-dropdown-item\"\n (click)=\"onSelectItem(item)\"\n >\n <mat-checkbox\n [checked]=\"isSelected(item)\"\n (change)=\"onSelectItem(item, $event)\"\n >\n {{ item.label }}\n </mat-checkbox>\n </div>\n <div\n *ngIf=\"!filterItems?.length\"\n class=\"rb-filter-dropdown-item\">\n <mat-checkbox disabled>\n <span class=\"rb-filter-dropdown-item-disabled\">\n Nenhum item encontrado\n </span>\n </mat-checkbox>\n </div>\n </div> -->\n </div>\n </div>\n</ng-template>\n","import { Component, ViewChild, inject } from '@angular/core';\nimport { MatDialogModule, MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatIconModule } from '@angular/material/icon';\nimport { RbFilterDropdownComponent } from '../rb-filter-dropdown/rb-filter-dropdown.component';\nimport { RbDynamicButtonDirective } from '../../directives/rb-dynamic-button/rb-dynamic-button.directive';\nimport { FilterPannelData } from '../../interfaces/rb-filter.interface';\n\n@Component({\n selector: 'rb-rb-filter-panel',\n imports: [MatDialogModule, MatButtonModule, MatIconModule, RbFilterDropdownComponent, RbDynamicButtonDirective],\n templateUrl: './rb-filter-panel.component.html',\n styleUrl: './rb-filter-panel.component.scss'\n})\nexport class RbFilterPanelComponent {\n @ViewChild(RbFilterDropdownComponent) dropdown!: RbFilterDropdownComponent;\n data = inject<FilterPannelData>(MAT_DIALOG_DATA);\n\n constructor() {}\n\n applyFilter() {\n console.log('applyFilter');\n }\n\n openMenu(): void {\n this.dropdown.openMenu();\n }\n}\n","<div class=\"rb-dialog\">\n <!-- Cabeçalho -->\n <div class=\"rb-dialog-header\">\n <h2>Filtro</h2>\n <button mat-icon-button mat-dialog-close aria-label=\"Fechar diálogo\">\n <mat-icon>close</mat-icon>\n </button>\n </div>\n\n <!-- Conteúdo -->\n <mat-dialog-content class=\"rb-dialog-content\" >\n <div class=\"rb-row rb-row rb-flex-row rb-align-items-start rb-justify-content-start\">\n <button mat-button id=\"parentDropdownSelector\"\n title=\"Filtrar\"\n class=\"primary\"\n aria-label=\"Filtrar\"\n [rbDynamicButton]=\"null\"\n (click)=\"openMenu()\">\n <mat-icon>add</mat-icon>\n Adicionar nova condição\n </button>\n <rb-filter-dropdown\n [parentSelectorId]=\"'#parentDropdownSelector'\"\n [options]=\"data.filterOptions\"></rb-filter-dropdown>\n\n </div>\n </mat-dialog-content>\n\n <!-- Ações -->\n <mat-dialog-actions class=\"rb-dialog-actions\" align=\"end\">\n <button mat-button\n title=\"Filtrar\"\n class=\"primary\"\n aria-label=\"Filtrar\"\n [rbDynamicButton]=\"'confirm'\"\n (click)=\"applyFilter()\">\n Filtrar\n </button>\n </mat-dialog-actions>\n</div>\n","import { Component, inject } from '@angular/core';\nimport { MatDialogModule, MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatInputModule } from '@angular/material/input';\nimport { RbDynamicButtonDirective } from '../../directives/rb-dynamic-button/rb-dynamic-button.directive';\nimport { RbDialog } from '../../interfaces/rb-dialog.interface';\nimport { FormBuilder, FormGroup, ReactiveFormsModule, Validators } from '@angular/forms';\n\n@Component({\n selector: 'lib-rb-copy-confirm-dialog',\n imports: [MatDialogModule, MatButtonModule, MatFormFieldModule, ReactiveFormsModule, MatInputModule, MatIconModule, RbDynamicButtonDirective],\n templateUrl: './rb-copy-confirm-dialog.component.html',\n styleUrl: './rb-copy-confirm-dialog.component.scss'\n})\nexport class RbCopyConfirmDialogComponent {\n\n readonly data = inject<RbDialog>(MAT_DIALOG_DATA);\n readonly dialogRef = inject(MatDialogRef<RbCopyConfirmDialogComponent>);\n formGroup: FormGroup;\n\n constructor(private fb: FormBuilder) {\n this.formGroup = this.fb.group({\n fieldValue: [this.data?.fieldValueDafault, Validators.required]\n });\n }\n\n confirm() {\n this.dialogRef.close(this.formGroup.value);\n }\n\n}\n","<div class=\"rb-dialog\">\n <!-- Cabeçalho -->\n <div class=\"rb-dialog-header\">\n <h2>{{data.title}}</h2>\n <button mat-icon-button mat-dialog-close aria-label=\"Fechar diálogo\">\n <mat-icon>close</mat-icon>\n </button>\n </div>\n <form (submit)=\"confirm()\" [formGroup]=\"formGroup\">\n\n <!-- Conteúdo -->\n <mat-dialog-content class=\"rb-dialog-content\">\n <mat-form-field appearance=\"fill\" class=\"rb-form-field width-100\">\n <mat-label>{{data.labelField}}</mat-label>\n <input matInput autofocus\n type=\"text\"\n [attr.aria-label]=\"data.labelField\"\n formControlName=\"fieldValue\"\n required>\n @if (formGroup.controls['fieldValue'].hasError('required')) {\n <mat-error >\n Campo obrigatório\n </mat-error>\n }\n </mat-form-field>\n\n </mat-dialog-content>\n\n <!-- Ações -->\n <mat-dialog-actions class=\"rb-dialog-actions\" [align]=\"data.actionsAlign || 'end'\">\n <button mat-button mat-dialog-close\n title=\"Cancelar\"\n aria-label=\"Cancelar\"\n class=\"secondary\"\n color=\"accent\"\n [attr.aria-label]=\"'Cancelar ação duplicar'\"\n type=\"button\"\n [rbDynamicButton]=\"'cancel'\">\n Cancelar\n </button>\n <button mat-button\n title=\"Duplicar\"\n aria-label=\"Duplicar\"\n class=\"primary\"\n [color]=\"'primary'\"\n [attr.aria-label]=\"'Duplicar ' + data.labelField\"\n [rbDynamicButton]=\"'confirm'\"\n type=\"submit\"\n [disabled]=\"formGroup.invalid\"\n (click)=\"confirm()\">\n Duplicar\n </button>\n </mat-dialog-actions>\n </form>\n</div>\n","import { Component, inject } from '@angular/core';\nimport { MatDialogModule, MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatIconModule } from '@angular/material/icon';\nimport { RbChangeLogDialog } from '../../interfaces/rb-change-log-dialog.interface';\nimport { RbCrudComponent } from '../rb-crud/rb-crud.component';\n\n@Component({\n selector: 'rb-rb-change-log-dialog',\n imports: [MatDialogModule, MatButtonModule, MatIconModule, RbCrudComponent],\n templateUrl: './rb-change-log-dialog.component.html',\n styleUrl: './rb-change-log-dialog.component.scss',\n})\nexport class RbChangeLogDialogComponent {\n readonly data = inject<RbChangeLogDialog>(MAT_DIALOG_DATA);\n readonly dialogRef = inject(MatDialogRef<RbChangeLogDialogComponent>);\n}\n","<div class=\"rb-dialog\">\n <!-- Cabeçalho -->\n <div class=\"rb-dialog-header\">\n <h2>Histórico de alterações</h2>\n <button mat-icon-button mat-dialog-close aria-label=\"Fechar diálogo\">\n <mat-icon>close</mat-icon>\n </button>\n </div>\n\n <!-- Conteúdo -->\n <mat-dialog-content class=\"rb-dialog-content bg-white has-crud\" >\n <rb-crud\n [columns]=\"data.columns\"\n [data]=\"data.dataSource\"\n [pagination]=\"false\"\n [textLineBreakable]=\"true\"\n ></rb-crud>\n </mat-dialog-content>\n</div>\n\n","import { Pipe, PipeTransform } from '@angular/core';\n\n@Pipe({\n name: 'isArray',\n standalone: true\n})\nexport class IsArrayPipe implements PipeTransform {\n\n transform(value: any): boolean {\n return Array.isArray(value);\n }\n\n}\n","export interface CrudColumn {\n key: string;\n label: string;\n sortable?: boolean;\n pipe?: 'date' | 'datetime' | 'currency' | 'cpf' | 'cnpj' | 'phone' | 'cep' | 'mask' | 'relativeTime' | 'lastModifiedBy';\n action?: string;\n objCol?: CrudObjColumn; //Usado quando a informação da coluna é um objeto\n}\nexport interface CrudActionEvent {\n action: string;\n row?: any;\n}\n\nexport interface CrudObjColumn {\n key: string;\n label: string;\n}\n\n// export interface CrudFilter {\n// key: string;\n// label: string;\n// type: 'text' | 'select' | 'date';\n// options?: any[]; // Para selects\n// }\n","/*\n * Public API Surface of rb-angular-components\n */\n\n/* Components */\nexport * from './lib/components/rb-crud/rb-crud.component';\nexport * from './lib/components/rb-crud-tool-bar/rb-crud-tool-bar.component';\nexport * from './lib/components/rb-content-box/rb-content-box.component';\nexport * from './lib/components/rb-dialog/rb-dialog.component';\nexport * from './lib/components/rb-filter-panel/rb-filter-panel.component';\nexport * from './lib/components/rb-filter-dropdown/rb-filter-dropdown.component';\nexport * from './lib/components/rb-copy-confirm-dialog/rb-copy-confirm-dialog.component';\nexport * from './lib/components/rb-change-log-dialog/rb-change-log-dialog.component';\n\n/* Pipes */\nexport * from './lib/pipes/rb-custom/rb-custom.pipe';\nexport * from './lib/pipes/is-array.pipe';\n\n/* Directives */\nexport * from './lib/directives/rb-dynamic-button/rb-dynamic-button.directive';\n\n\n/* Interfaces */\nexport * from './lib/interfaces/rb-crud.interface';\nexport * from './lib/interfaces/button.interface';\nexport * from './lib/interfaces/rb-dialog.interface';\nexport * from './lib/interfaces/rb-filter.interface';\nexport * from './lib/interfaces/rb-change-log-dialog.interface';\n\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":["i1.ClientFilterService","i6","i7","i2","i3","i4","i1","i2.ClientFilterService","i5"],"mappings":"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