keevo-components 2.0.258 → 2.0.260

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,205 @@
1
+ import { Component, Input, Output, EventEmitter, ViewChild, input, computed } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { ButtonModule } from 'primeng/button';
4
+ import { KvProgressBarModule } from '../kv-progress-bar/kv-progress-bar.module';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "../../api/services/notification.service";
7
+ import * as i2 from "@angular/common";
8
+ import * as i3 from "primeng/button";
9
+ export class KvFileUploadNewComponent {
10
+ // No topo da classe
11
+ constructor(notificationService) {
12
+ this.notificationService = notificationService;
13
+ this.widthComponent = '400px';
14
+ this.heightComponent = 'auto';
15
+ this.validFileTypes = ['image/', 'application/pdf', 'text/html', 'text/xml', 'application/xml', 'text/plain'];
16
+ this.tamanhoMaximoPermitido = '';
17
+ this.includeOfficeTypes = false; // Propriedade para controlar os tipos de Office
18
+ this.maxSizeFile = input(10);
19
+ this.fileEmit = new EventEmitter();
20
+ this.removeFileEmit = new EventEmitter();
21
+ // returnMbSize = computed(() => (bytes: any) => {
22
+ // if (bytes === null || bytes === undefined) {
23
+ // return '0 MB';
24
+ // }
25
+ // const mbSize = bytes / (1024 * 1024);
26
+ // return this.formatBytes(mbSize, 2);
27
+ // });
28
+ this.progressValue = computed(() => (bytes) => {
29
+ if (bytes === null || bytes === undefined) {
30
+ return 0;
31
+ }
32
+ const mbSize = bytes / (1024 * 1024);
33
+ let progressValue = (Number(mbSize) / this.maxSizeFile()) * 100;
34
+ // Limita o valor do progresso entre 0 e 100
35
+ return Math.min(Math.max(progressValue, 0), 100);
36
+ });
37
+ this.returnProgressLabel = computed(() => (bytes) => {
38
+ if (bytes === null || bytes === undefined) {
39
+ return '0 MB';
40
+ }
41
+ const mbSize = bytes / (1024 * 1024);
42
+ // let progressValue = (Number(mbSize) / this.maxSizeFile()) * 100;
43
+ // this.progressValue.set(progressValue);
44
+ // this.progressValue.set((mbSize / this.maxSizeFile())*100);
45
+ return `${mbSize.toFixed(2)}/${this.maxSizeFile()} MB`;
46
+ });
47
+ }
48
+ // Método para disparar o clique sem erro de propriedade
49
+ triggerClick() {
50
+ if (!this.formGroup.get(this.formControlName)?.value) {
51
+ this.fileInput.nativeElement.click();
52
+ }
53
+ }
54
+ onFileSelected(event) {
55
+ let validTypes = [...this.validFileTypes];
56
+ if (this.includeOfficeTypes) {
57
+ validTypes.push('application/msword', // .doc
58
+ 'application/vnd.openxmlformats-officedocument.wordprocessingml.document', // .docx
59
+ 'application/vnd.ms-powerpoint', // .ppt
60
+ 'application/vnd.openxmlformats-officedocument.presentationml.presentation' // .pptx
61
+ );
62
+ }
63
+ if (event.target.files.length == 0)
64
+ return;
65
+ const isValidFileType = validTypes.some(type => event.target.files[0].type.startsWith(type) ||
66
+ (type === 'application/xml' && event.target.files[0].type === 'application/xml') ||
67
+ (type === 'text/xml' && event.target.files[0].type === 'text/xml'));
68
+ if (!isValidFileType) {
69
+ this.notificationService.toastError('Tipo de arquivo inválido');
70
+ this.formGroup.controls[this.formControlName].setValue(null);
71
+ event.target.value = '';
72
+ return;
73
+ }
74
+ this.formGroup.controls[this.formControlName].setValue(event.target.files[0]);
75
+ this.fileEmit.emit(event.target.files[0]);
76
+ }
77
+ deleteFile() {
78
+ this.formGroup.controls[this.formControlName].setValue(null);
79
+ this.fileInput.nativeElement.value = '';
80
+ this.removeFileEmit.emit();
81
+ }
82
+ formatBytes(bytes, decimals = 2) {
83
+ if (!bytes) {
84
+ return "0 Bytes";
85
+ }
86
+ const k = 1024;
87
+ const dm = decimals <= 0 ? 0 : decimals;
88
+ const sizes = ["Bytes", "KB", "MB", "GB", "TB", "PB", "EB", "ZB", "YB"];
89
+ const i = Math.floor(Math.log(bytes) / Math.log(k));
90
+ return parseFloat((bytes / Math.pow(k, i)).toFixed(dm)) + " " + sizes[i];
91
+ }
92
+ addDragOverClass(event) {
93
+ const container = event.target;
94
+ container.classList.add('dragover');
95
+ }
96
+ removeDragOverClass(event) {
97
+ const container = event.target;
98
+ container.classList.remove('dragover');
99
+ }
100
+ handleFile(file) {
101
+ if (this.includeOfficeTypes) {
102
+ let validTypes = [...this.validFileTypes];
103
+ validTypes.push('application/msword', // .doc
104
+ 'application/vnd.openxmlformats-officedocument.wordprocessingml.document', // .docx
105
+ 'application/vnd.ms-powerpoint', // .ppt
106
+ 'application/vnd.openxmlformats-officedocument.presentationml.presentation' // .pptx
107
+ );
108
+ }
109
+ const isValidFileType = this.validFileTypes.some(type => file.type.startsWith(type) ||
110
+ file.type === 'application/xml' ||
111
+ file.type === 'text/xml');
112
+ if (!isValidFileType) {
113
+ this.notificationService.toastError('Tipo de arquivo inválido');
114
+ this.formGroup.controls[this.formControlName].setValue(null);
115
+ return;
116
+ }
117
+ this.formGroup.controls[this.formControlName].setValue(file);
118
+ const reader = new FileReader();
119
+ if (file.type.startsWith('image/')) {
120
+ reader.readAsDataURL(file);
121
+ }
122
+ else if (file.type === 'application/xml' || file.type === 'text/xml') {
123
+ reader.readAsText(file);
124
+ }
125
+ else {
126
+ reader.readAsArrayBuffer(file);
127
+ }
128
+ this.fileEmit.emit(file);
129
+ }
130
+ onDragOver(event) {
131
+ event.preventDefault();
132
+ event.stopPropagation();
133
+ this.addDragOverClass(event);
134
+ }
135
+ onDragLeave(event) {
136
+ event.preventDefault();
137
+ event.stopPropagation();
138
+ this.removeDragOverClass(event);
139
+ }
140
+ onDrop(event) {
141
+ event.preventDefault();
142
+ event.stopPropagation();
143
+ this.removeDragOverClass(event);
144
+ if (event.dataTransfer && event.dataTransfer.files.length > 0) {
145
+ this.handleFile(event.dataTransfer.files[0]);
146
+ }
147
+ }
148
+ setAccept() {
149
+ let types = '';
150
+ this.validFileTypes.forEach(type => {
151
+ if (type.includes('image'))
152
+ types += '.jpg, .png, .bmp, ';
153
+ if (type.includes('html'))
154
+ types += '.html, ';
155
+ if (type.includes('pdf'))
156
+ types += '.pdf, ';
157
+ if (type.includes('xml'))
158
+ types += '.xml, ';
159
+ if (type.includes('plain'))
160
+ types += '.txt, ';
161
+ });
162
+ // Adiciona tipos de arquivos do Office se includeOfficeTypes for true
163
+ if (this.includeOfficeTypes) {
164
+ types += '.doc, .docx, .ppt, .pptx, ';
165
+ }
166
+ return types.slice(0, -2); // Remove a última vírgula e espaço
167
+ }
168
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvFileUploadNewComponent, deps: [{ token: i1.NotificationService }], target: i0.ɵɵFactoryTarget.Component }); }
169
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.8", type: KvFileUploadNewComponent, isStandalone: true, selector: "kv-file-upload-new", inputs: { formGroup: { classPropertyName: "formGroup", publicName: "formGroup", isSignal: false, isRequired: false, transformFunction: null }, formControlName: { classPropertyName: "formControlName", publicName: "formControlName", isSignal: false, isRequired: false, transformFunction: null }, widthComponent: { classPropertyName: "widthComponent", publicName: "widthComponent", isSignal: false, isRequired: false, transformFunction: null }, heightComponent: { classPropertyName: "heightComponent", publicName: "heightComponent", isSignal: false, isRequired: false, transformFunction: null }, description: { classPropertyName: "description", publicName: "description", isSignal: false, isRequired: false, transformFunction: null }, validFileTypes: { classPropertyName: "validFileTypes", publicName: "validFileTypes", isSignal: false, isRequired: false, transformFunction: null }, tamanhoMaximoPermitido: { classPropertyName: "tamanhoMaximoPermitido", publicName: "tamanhoMaximoPermitido", isSignal: false, isRequired: false, transformFunction: null }, includeOfficeTypes: { classPropertyName: "includeOfficeTypes", publicName: "includeOfficeTypes", isSignal: false, isRequired: false, transformFunction: null }, maxSizeFile: { classPropertyName: "maxSizeFile", publicName: "maxSizeFile", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { fileEmit: "fileEmit", removeFileEmit: "removeFileEmit" }, viewQueries: [{ propertyName: "fileInput", first: true, predicate: ["fileInput"], descendants: true }, { propertyName: "inputUpload", first: true, predicate: ["inputUpload"], descendants: true }], ngImport: i0, template: "<div\r\n *ngIf=\"formGroup\"\r\n class=\"file-upload-container w-full\"\r\n [ngClass]=\"{\r\n 'invalid-border':\r\n formGroup.get(formControlName)?.invalid &&\r\n formGroup.get(formControlName)?.touched,\r\n 'has-file': formGroup.get(formControlName)?.value,\r\n }\"\r\n (dragover)=\"onDragOver($event)\"\r\n (dragleave)=\"onDragLeave($event)\"\r\n (drop)=\"onDrop($event)\"\r\n (click)=\"triggerClick()\"\r\n [style.width]=\"widthComponent\"\r\n>\r\n <input\r\n type=\"file\"\r\n #fileInput\r\n (change)=\"onFileSelected($event)\"\r\n [accept]=\"setAccept()\"\r\n hidden\r\n />\r\n\r\n <div *ngIf=\"!formGroup.get(formControlName)?.value\" class=\"dropzone-content\">\r\n <div class=\"cloud-icon-wrapper\">\r\n <span class=\"material-symbols-outlined\">cloud_upload</span>\r\n </div>\r\n <div class=\"text-center\">\r\n <p class=\"main-text\">\r\n <span class=\"blue-text\">Clique para selecionar</span> ou arraste aqui\r\n </p>\r\n <p class=\"sub-text\">PDF, Imagens (max. {{ maxSizeFile() }}MB)</p>\r\n </div>\r\n </div>\r\n\r\n <div\r\n *ngIf=\"formGroup.get(formControlName)?.value as file\"\r\n class=\"selected-file-card\"\r\n >\r\n <div class=\"card-header\">\r\n <div class=\"file-info\">\r\n <span class=\"material-symbols-outlined file-icon\">description</span>\r\n <span class=\"file-name\" [title]=\"file.name\">{{ file.name }}</span>\r\n </div>\r\n <button\r\n pButton\r\n icon=\"pi pi-times\"\r\n class=\"p-button-rounded p-button-text p-button-danger close-btn\"\r\n (click)=\"deleteFile(); $event.stopPropagation()\"\r\n ></button>\r\n </div>\r\n\r\n <div class=\"card-footer\">\r\n <div class=\"progress-container\">\r\n <div\r\n class=\"progress-bar\"\r\n [style.width.%]=\"progressValue()(file.size)\"\r\n [class.limit-exceeded]=\"progressValue()(file.size) >= 100\"\r\n ></div>\r\n </div>\r\n <div class=\"flex justify-content-between align-items-center mt-1\">\r\n <small class=\"error-text\" *ngIf=\"progressValue()(file.size) >= 100\"\r\n >Limite excedido</small\r\n >\r\n <span class=\"file-size-label ml-auto\">{{\r\n formatBytes(file.size)\r\n }}</span>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<p\r\n *ngIf=\"\r\n formGroup.get(formControlName)?.invalid &&\r\n formGroup.get(formControlName)?.touched\r\n \"\r\n class=\"error-message\"\r\n>\r\n Campo obrigat\u00F3rio\r\n</p>\r\n", styles: [".file-upload-container{border:2px dashed #cbd5e1;border-radius:1.25rem;background-color:#f8fafc;min-height:160px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease-in-out;position:relative}.file-upload-container:hover,.file-upload-container.dragover{border-color:#3b82f6;background-color:#eff6ff}.file-upload-container.has-file{cursor:default;background-color:#f1f5f9;padding:0;border-style:solid}.selected-file-card{background:#fff;border-radius:1.25rem;padding:1.5rem;width:100%;height:100%;min-height:160px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;display:flex;flex-direction:column;justify-content:center;gap:1rem;animation:fadeIn .3s ease-out;box-sizing:border-box}.selected-file-card .card-header{display:flex;justify-content:space-between;align-items:center}.selected-file-card .card-header .file-info{display:flex;align-items:center;gap:.75rem;overflow:hidden}.selected-file-card .card-header .file-info .file-icon{color:#64748b;font-size:24px}.selected-file-card .card-header .file-info .file-name{font-size:1rem;font-weight:500;color:#334155;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.selected-file-card .card-header .close-btn{width:32px!important;height:32px!important;padding:0!important}.selected-file-card .card-header .close-btn ::ng-deep .p-button-icon{font-size:1rem}.selected-file-card .card-footer .progress-container{height:8px;background:#e2e8f0;border-radius:10px;overflow:hidden}.selected-file-card .card-footer .progress-container .progress-bar{height:100%;background:#3b82f6;transition:width .4s cubic-bezier(.4,0,.2,1)}.selected-file-card .card-footer .progress-container .progress-bar.limit-exceeded{background:#ef4444}.selected-file-card .card-footer .file-size-label{font-size:.85rem;color:#94a3b8;font-weight:500}.selected-file-card .card-footer .error-text{color:#ef4444;font-size:.75rem;font-weight:600}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}::ng-deep .file-upload-container .p-button.p-button-text{background-color:transparent!important;border:none}::ng-deep .file-upload-container .p-button.p-button-text:hover{background-color:#fee2e2!important}.cloud-icon-wrapper{background-color:#e0f2fe;color:#3b82f6;width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto .75rem}.cloud-icon-wrapper span{font-size:24px}.main-text{font-size:.9rem;color:#334155}.main-text .blue-text{color:#3b82f6;font-weight:600}.sub-text{color:#64748b;font-size:.8rem}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: KvProgressBarModule }, { kind: "ngmodule", type: ButtonModule }, { kind: "directive", type: i3.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading", "severity", "raised", "rounded", "text", "outlined", "size", "plain"] }] }); }
170
+ }
171
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvFileUploadNewComponent, decorators: [{
172
+ type: Component,
173
+ args: [{ selector: 'kv-file-upload-new', standalone: true, imports: [
174
+ CommonModule,
175
+ KvProgressBarModule,
176
+ ButtonModule
177
+ ], template: "<div\r\n *ngIf=\"formGroup\"\r\n class=\"file-upload-container w-full\"\r\n [ngClass]=\"{\r\n 'invalid-border':\r\n formGroup.get(formControlName)?.invalid &&\r\n formGroup.get(formControlName)?.touched,\r\n 'has-file': formGroup.get(formControlName)?.value,\r\n }\"\r\n (dragover)=\"onDragOver($event)\"\r\n (dragleave)=\"onDragLeave($event)\"\r\n (drop)=\"onDrop($event)\"\r\n (click)=\"triggerClick()\"\r\n [style.width]=\"widthComponent\"\r\n>\r\n <input\r\n type=\"file\"\r\n #fileInput\r\n (change)=\"onFileSelected($event)\"\r\n [accept]=\"setAccept()\"\r\n hidden\r\n />\r\n\r\n <div *ngIf=\"!formGroup.get(formControlName)?.value\" class=\"dropzone-content\">\r\n <div class=\"cloud-icon-wrapper\">\r\n <span class=\"material-symbols-outlined\">cloud_upload</span>\r\n </div>\r\n <div class=\"text-center\">\r\n <p class=\"main-text\">\r\n <span class=\"blue-text\">Clique para selecionar</span> ou arraste aqui\r\n </p>\r\n <p class=\"sub-text\">PDF, Imagens (max. {{ maxSizeFile() }}MB)</p>\r\n </div>\r\n </div>\r\n\r\n <div\r\n *ngIf=\"formGroup.get(formControlName)?.value as file\"\r\n class=\"selected-file-card\"\r\n >\r\n <div class=\"card-header\">\r\n <div class=\"file-info\">\r\n <span class=\"material-symbols-outlined file-icon\">description</span>\r\n <span class=\"file-name\" [title]=\"file.name\">{{ file.name }}</span>\r\n </div>\r\n <button\r\n pButton\r\n icon=\"pi pi-times\"\r\n class=\"p-button-rounded p-button-text p-button-danger close-btn\"\r\n (click)=\"deleteFile(); $event.stopPropagation()\"\r\n ></button>\r\n </div>\r\n\r\n <div class=\"card-footer\">\r\n <div class=\"progress-container\">\r\n <div\r\n class=\"progress-bar\"\r\n [style.width.%]=\"progressValue()(file.size)\"\r\n [class.limit-exceeded]=\"progressValue()(file.size) >= 100\"\r\n ></div>\r\n </div>\r\n <div class=\"flex justify-content-between align-items-center mt-1\">\r\n <small class=\"error-text\" *ngIf=\"progressValue()(file.size) >= 100\"\r\n >Limite excedido</small\r\n >\r\n <span class=\"file-size-label ml-auto\">{{\r\n formatBytes(file.size)\r\n }}</span>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<p\r\n *ngIf=\"\r\n formGroup.get(formControlName)?.invalid &&\r\n formGroup.get(formControlName)?.touched\r\n \"\r\n class=\"error-message\"\r\n>\r\n Campo obrigat\u00F3rio\r\n</p>\r\n", styles: [".file-upload-container{border:2px dashed #cbd5e1;border-radius:1.25rem;background-color:#f8fafc;min-height:160px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease-in-out;position:relative}.file-upload-container:hover,.file-upload-container.dragover{border-color:#3b82f6;background-color:#eff6ff}.file-upload-container.has-file{cursor:default;background-color:#f1f5f9;padding:0;border-style:solid}.selected-file-card{background:#fff;border-radius:1.25rem;padding:1.5rem;width:100%;height:100%;min-height:160px;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;display:flex;flex-direction:column;justify-content:center;gap:1rem;animation:fadeIn .3s ease-out;box-sizing:border-box}.selected-file-card .card-header{display:flex;justify-content:space-between;align-items:center}.selected-file-card .card-header .file-info{display:flex;align-items:center;gap:.75rem;overflow:hidden}.selected-file-card .card-header .file-info .file-icon{color:#64748b;font-size:24px}.selected-file-card .card-header .file-info .file-name{font-size:1rem;font-weight:500;color:#334155;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.selected-file-card .card-header .close-btn{width:32px!important;height:32px!important;padding:0!important}.selected-file-card .card-header .close-btn ::ng-deep .p-button-icon{font-size:1rem}.selected-file-card .card-footer .progress-container{height:8px;background:#e2e8f0;border-radius:10px;overflow:hidden}.selected-file-card .card-footer .progress-container .progress-bar{height:100%;background:#3b82f6;transition:width .4s cubic-bezier(.4,0,.2,1)}.selected-file-card .card-footer .progress-container .progress-bar.limit-exceeded{background:#ef4444}.selected-file-card .card-footer .file-size-label{font-size:.85rem;color:#94a3b8;font-weight:500}.selected-file-card .card-footer .error-text{color:#ef4444;font-size:.75rem;font-weight:600}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}::ng-deep .file-upload-container .p-button.p-button-text{background-color:transparent!important;border:none}::ng-deep .file-upload-container .p-button.p-button-text:hover{background-color:#fee2e2!important}.cloud-icon-wrapper{background-color:#e0f2fe;color:#3b82f6;width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto .75rem}.cloud-icon-wrapper span{font-size:24px}.main-text{font-size:.9rem;color:#334155}.main-text .blue-text{color:#3b82f6;font-weight:600}.sub-text{color:#64748b;font-size:.8rem}\n"] }]
178
+ }], ctorParameters: () => [{ type: i1.NotificationService }], propDecorators: { formGroup: [{
179
+ type: Input
180
+ }], formControlName: [{
181
+ type: Input
182
+ }], widthComponent: [{
183
+ type: Input
184
+ }], heightComponent: [{
185
+ type: Input
186
+ }], description: [{
187
+ type: Input
188
+ }], validFileTypes: [{
189
+ type: Input
190
+ }], tamanhoMaximoPermitido: [{
191
+ type: Input
192
+ }], includeOfficeTypes: [{
193
+ type: Input
194
+ }], fileEmit: [{
195
+ type: Output
196
+ }], removeFileEmit: [{
197
+ type: Output
198
+ }], fileInput: [{
199
+ type: ViewChild,
200
+ args: ['fileInput']
201
+ }], inputUpload: [{
202
+ type: ViewChild,
203
+ args: ['inputUpload']
204
+ }] } });
205
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-file-upload-new.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-file-upload-new/kv-file-upload-new.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-file-upload-new/kv-file-upload-new.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, ViewChild, ElementRef, input, computed, signal } from '@angular/core';\r\nimport { FormGroup } from '@angular/forms';\r\nimport { NotificationService } from '../../api/services/notification.service';\r\nimport { CommonModule } from '@angular/common';\r\nimport { ButtonModule } from 'primeng/button';\r\nimport { KvProgressBarModule } from '../kv-progress-bar/kv-progress-bar.module';\r\n\r\n@Component({\r\n  selector: 'kv-file-upload-new',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    KvProgressBarModule, \r\n    ButtonModule\r\n  ],\r\n  templateUrl: './kv-file-upload-new.component.html',\r\n  styleUrl: './kv-file-upload-new.component.scss'\r\n})\r\nexport class KvFileUploadNewComponent {\r\n  @Input() formGroup!: FormGroup;\r\n  @Input() formControlName!: string;\r\n  @Input() widthComponent: string = '400px';\r\n  @Input() heightComponent: string = 'auto';\r\n  @Input() description!: string;\r\n  @Input() validFileTypes: string[] = ['image/', 'application/pdf', 'text/html', 'text/xml', 'application/xml', 'text/plain'];\r\n  @Input() tamanhoMaximoPermitido: string = '';\r\n  @Input() includeOfficeTypes: boolean = false; // Propriedade para controlar os tipos de Office\r\n\r\n  maxSizeFile = input<number>(10)\r\n\r\n  @Output() fileEmit: EventEmitter<any> = new EventEmitter();\r\n  @Output() removeFileEmit: EventEmitter<any> = new EventEmitter();\r\n\r\n  @ViewChild('fileInput') fileInput!: ElementRef<HTMLInputElement>;\r\n  @ViewChild('inputUpload') inputUpload!: ElementRef;\r\n  // No topo da classe\r\n\r\n  constructor(private notificationService: NotificationService) { }\r\n\r\n  // Método para disparar o clique sem erro de propriedade\r\n  triggerClick() {\r\n    if (!this.formGroup.get(this.formControlName)?.value) {\r\n      this.fileInput.nativeElement.click();\r\n    }\r\n  }\r\n\r\n  onFileSelected(event: any): void {\r\n    let validTypes = [...this.validFileTypes];\r\n\r\n    if (this.includeOfficeTypes) {\r\n\r\n      validTypes.push(\r\n        'application/msword', // .doc\r\n        'application/vnd.openxmlformats-officedocument.wordprocessingml.document', // .docx\r\n        'application/vnd.ms-powerpoint', // .ppt\r\n        'application/vnd.openxmlformats-officedocument.presentationml.presentation' // .pptx\r\n      );\r\n    }\r\n\r\n    if (event.target.files.length == 0) return;\r\n\r\n    const isValidFileType = validTypes.some(type => event.target.files[0].type.startsWith(type) ||\r\n      (type === 'application/xml' && event.target.files[0].type === 'application/xml') ||\r\n      (type === 'text/xml' && event.target.files[0].type === 'text/xml')\r\n    );\r\n\r\n    if (!isValidFileType) {\r\n      this.notificationService.toastError('Tipo de arquivo inválido');\r\n      this.formGroup.controls[this.formControlName].setValue(null);\r\n\r\n      event.target.value = '';\r\n\r\n      return;\r\n    }\r\n\r\n    this.formGroup.controls[this.formControlName].setValue(event.target.files[0]);\r\n    this.fileEmit.emit(event.target.files[0]);\r\n  }\r\n\r\n  deleteFile() {\r\n    this.formGroup.controls[this.formControlName].setValue(null);\r\n    this.fileInput.nativeElement.value = '';\r\n    this.removeFileEmit.emit();\r\n  }\r\n\r\n  // returnMbSize = computed(() => (bytes: any) => {\r\n  //   if (bytes === null || bytes === undefined) {\r\n  //     return '0 MB';\r\n  //   }\r\n\r\n  //   const mbSize = bytes / (1024 * 1024);\r\n\r\n  //   return this.formatBytes(mbSize, 2);\r\n  // });\r\n\r\n  progressValue = computed(() => (bytes: any) => {\r\n    if (bytes === null || bytes === undefined) {\r\n      return 0;\r\n    }\r\n\r\n    const mbSize = bytes / (1024 * 1024);\r\n    let progressValue = (Number(mbSize) / this.maxSizeFile()) * 100;\r\n\r\n    // Limita o valor do progresso entre 0 e 100\r\n    return Math.min(Math.max(progressValue, 0), 100);\r\n  });\r\n\r\n  returnProgressLabel = computed(() => (bytes: any) => {\r\n    if (bytes === null || bytes === undefined) {\r\n      return '0 MB';\r\n    }\r\n\r\n    const mbSize = bytes / (1024 * 1024);\r\n    // let progressValue = (Number(mbSize) / this.maxSizeFile()) * 100;\r\n    // this.progressValue.set(progressValue);\r\n    // this.progressValue.set((mbSize / this.maxSizeFile())*100);\r\n    return `${mbSize.toFixed(2)}/${this.maxSizeFile()} MB`;\r\n  })\r\n\r\n  formatBytes(bytes: any, decimals = 2) {\r\n    if (!bytes) {\r\n      return \"0 Bytes\";\r\n    }\r\n    const k = 1024;\r\n    const dm = decimals <= 0 ? 0 : decimals;\r\n    const sizes = [\"Bytes\", \"KB\", \"MB\", \"GB\", \"TB\", \"PB\", \"EB\", \"ZB\", \"YB\"];\r\n    const i = Math.floor(Math.log(bytes) / Math.log(k));\r\n    return parseFloat((bytes / Math.pow(k, i)).toFixed(dm)) + \" \" + sizes[i];\r\n  }\r\n\r\n  addDragOverClass(event: DragEvent) {\r\n    const container = event.target as HTMLElement;\r\n    container.classList.add('dragover');\r\n  }\r\n\r\n  removeDragOverClass(event: DragEvent) {\r\n    const container = event.target as HTMLElement;\r\n    container.classList.remove('dragover');\r\n  }\r\n\r\n  handleFile(file: File) {\r\n\r\n    if (this.includeOfficeTypes) {\r\n      let validTypes = [...this.validFileTypes];\r\n\r\n      validTypes.push(\r\n        'application/msword', // .doc\r\n        'application/vnd.openxmlformats-officedocument.wordprocessingml.document', // .docx\r\n        'application/vnd.ms-powerpoint', // .ppt\r\n        'application/vnd.openxmlformats-officedocument.presentationml.presentation' // .pptx\r\n      );\r\n    }\r\n\r\n    const isValidFileType = this.validFileTypes.some(type =>\r\n      file.type.startsWith(type) ||\r\n      file.type === 'application/xml' ||\r\n      file.type === 'text/xml'\r\n    );\r\n\r\n    if (!isValidFileType) {\r\n      this.notificationService.toastError('Tipo de arquivo inválido');\r\n      this.formGroup.controls[this.formControlName].setValue(null);\r\n      return;\r\n    }\r\n\r\n    this.formGroup.controls[this.formControlName].setValue(file);\r\n\r\n    const reader = new FileReader();\r\n\r\n    if (file.type.startsWith('image/')) {\r\n      reader.readAsDataURL(file);\r\n    } else if (file.type === 'application/xml' || file.type === 'text/xml') {\r\n      reader.readAsText(file);\r\n    } else {\r\n      reader.readAsArrayBuffer(file);\r\n    }\r\n\r\n    this.fileEmit.emit(file);\r\n  }\r\n\r\n  onDragOver(event: DragEvent) {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.addDragOverClass(event);\r\n  }\r\n\r\n  onDragLeave(event: DragEvent) {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.removeDragOverClass(event);\r\n  }\r\n\r\n  onDrop(event: DragEvent) {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.removeDragOverClass(event);\r\n\r\n    if (event.dataTransfer && event.dataTransfer.files.length > 0) {\r\n      this.handleFile(event.dataTransfer.files[0]);\r\n    }\r\n  }\r\n\r\n  setAccept(): string {\r\n    let types = ''\r\n\r\n    this.validFileTypes.forEach(type => {\r\n      if (type.includes('image')) types += '.jpg, .png, .bmp, ';\r\n      if (type.includes('html')) types += '.html, ';\r\n      if (type.includes('pdf')) types += '.pdf, ';\r\n      if (type.includes('xml')) types += '.xml, ';\r\n      if (type.includes('plain')) types += '.txt, ';\r\n    });\r\n\r\n    // Adiciona tipos de arquivos do Office se includeOfficeTypes for true\r\n    if (this.includeOfficeTypes) {\r\n      types += '.doc, .docx, .ppt, .pptx, ';\r\n    }\r\n\r\n    return types.slice(0, -2); // Remove a última vírgula e espaço\r\n  }\r\n}\r\n","<div\r\n  *ngIf=\"formGroup\"\r\n  class=\"file-upload-container w-full\"\r\n  [ngClass]=\"{\r\n    'invalid-border':\r\n      formGroup.get(formControlName)?.invalid &&\r\n      formGroup.get(formControlName)?.touched,\r\n    'has-file': formGroup.get(formControlName)?.value,\r\n  }\"\r\n  (dragover)=\"onDragOver($event)\"\r\n  (dragleave)=\"onDragLeave($event)\"\r\n  (drop)=\"onDrop($event)\"\r\n  (click)=\"triggerClick()\"\r\n  [style.width]=\"widthComponent\"\r\n>\r\n  <input\r\n    type=\"file\"\r\n    #fileInput\r\n    (change)=\"onFileSelected($event)\"\r\n    [accept]=\"setAccept()\"\r\n    hidden\r\n  />\r\n\r\n  <div *ngIf=\"!formGroup.get(formControlName)?.value\" class=\"dropzone-content\">\r\n    <div class=\"cloud-icon-wrapper\">\r\n      <span class=\"material-symbols-outlined\">cloud_upload</span>\r\n    </div>\r\n    <div class=\"text-center\">\r\n      <p class=\"main-text\">\r\n        <span class=\"blue-text\">Clique para selecionar</span> ou arraste aqui\r\n      </p>\r\n      <p class=\"sub-text\">PDF, Imagens (max. {{ maxSizeFile() }}MB)</p>\r\n    </div>\r\n  </div>\r\n\r\n  <div\r\n    *ngIf=\"formGroup.get(formControlName)?.value as file\"\r\n    class=\"selected-file-card\"\r\n  >\r\n    <div class=\"card-header\">\r\n      <div class=\"file-info\">\r\n        <span class=\"material-symbols-outlined file-icon\">description</span>\r\n        <span class=\"file-name\" [title]=\"file.name\">{{ file.name }}</span>\r\n      </div>\r\n      <button\r\n        pButton\r\n        icon=\"pi pi-times\"\r\n        class=\"p-button-rounded p-button-text p-button-danger close-btn\"\r\n        (click)=\"deleteFile(); $event.stopPropagation()\"\r\n      ></button>\r\n    </div>\r\n\r\n    <div class=\"card-footer\">\r\n      <div class=\"progress-container\">\r\n        <div\r\n          class=\"progress-bar\"\r\n          [style.width.%]=\"progressValue()(file.size)\"\r\n          [class.limit-exceeded]=\"progressValue()(file.size) >= 100\"\r\n        ></div>\r\n      </div>\r\n      <div class=\"flex justify-content-between align-items-center mt-1\">\r\n        <small class=\"error-text\" *ngIf=\"progressValue()(file.size) >= 100\"\r\n          >Limite excedido</small\r\n        >\r\n        <span class=\"file-size-label ml-auto\">{{\r\n          formatBytes(file.size)\r\n        }}</span>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n<p\r\n  *ngIf=\"\r\n    formGroup.get(formControlName)?.invalid &&\r\n    formGroup.get(formControlName)?.touched\r\n  \"\r\n  class=\"error-message\"\r\n>\r\n  Campo obrigatório\r\n</p>\r\n"]}
@@ -22,10 +22,10 @@ export class KvIconComponent {
22
22
  this.size = input('medium');
23
23
  }
24
24
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvIconComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
25
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: KvIconComponent, selector: "kv-icon", inputs: { icon: { classPropertyName: "icon", publicName: "icon", isSignal: true, isRequired: true, transformFunction: null }, shape: { classPropertyName: "shape", publicName: "shape", isSignal: true, isRequired: true, transformFunction: null }, severity: { classPropertyName: "severity", publicName: "severity", isSignal: true, isRequired: true, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "<div class=\"main-container\">\n\n <div class=\"shape-icon {{ size() }} {{ shape() }} {{ severity() }}\">\n\n @if(icon()) {\n <span class=\"material-symbols-outlined text-white\">\n {{ icon() }}\n </span>\n }\n \n </div>\n \n</div>", styles: ["@import\"https://fonts.googleapis.com/css2?family=Inter:wght@100..900&display=swap\";@import\"https://fonts.googleapis.com/css2?family=Inter:wght@100;200;300;400;500;600;700;800;900&display=swap\";@import\"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@24,400,0,0\";::ng-deep :root{--kv-color-system: 10,58,120;--kv-color-system-cta: 76, 175, 80;--kv-color-text: 0, 0, 0;--kv-color-text-inv: 255, 255, 165;--kv-background-system: 248,250,253;--kv-background-card: 255,255,255;--kv-primary-color: 41, 185, 45;--kv-secondary-color: 0, 37, 66;--kv-tertiary-color: 165, 165, 165;--kv-danger-color: 220, 53, 69;--kv-success-color: 75, 181, 67;--kv-info-color: 58, 170, 208;--kv-warn-color: 241, 90, 36;--kv-contrast-color: 33, 37, 41}::ng-deep .padrao{--kv-color-system: 10,58,120;--kv-color-system-cta: 76, 175, 80;--kv-color-text: 0, 0, 0;--kv-background-system: 248,250,253;--kv-background-card: 255,255,255}::ng-deep .theme-keevocenter{--kv-color-system: 88,25,153;--kv-color-system-cta: 0, 116, 217;--kv-color-text: 0, 0, 0;--kv-color-text-inv: 255, 255, 165;--kv-background-system: 248,250,253;--kv-background-card: 255,255,255}::ng-deep .theme-holos{--kv-color-system: 241,90,36;--kv-color-system-cta: 224, 168, 35;--kv-color-text: 0, 0, 0;--kv-color-text-inv: 255, 255, 165;--kv-background-system: 240,240,240;--kv-background-card: 2255,255,255}.system-color{color:rgb(var(--kv-color-system),1)}.bg-system-100{background:rgb(var(--kv-color-system),1)}.bg-system-75{background:rgb(var(--kv-color-system),.75)}.bg-system-50{background:rgb(var(--kv-color-system),.5)}.bg-system-25{background:rgb(var(--kv-color-system),.25)}.material-symbols-outlined{font-family:Material Symbols Outlined!important}*{font-family:Inter,Inter var,sans-serif!important}::ng-deep .p-accordion,::ng-deep .p-accordion-header,::ng-deep .p-accordion-content,::ng-deep .p-badge,::ng-deep .p-overlay-badge,::ng-deep .p-breadcrumb,::ng-deep .p-breadcrumb-item,::ng-deep .p-breadcrumb-link,::ng-deep .p-button,::ng-deep .p-calendar,::ng-deep .p-card,::ng-deep .p-card-title,::ng-deep .p-card-subtitle,::ng-deep .p-card-content,::ng-deep .p-checkbox,::ng-deep .p-chip,::ng-deep .p-confirm-dialog,::ng-deep .p-confirm-dialog-message,::ng-deep .p-contextmenu,::ng-deep .p-contextmenu-item,::ng-deep .p-dataview,::ng-deep .p-dataview-content,::ng-deep .p-dialog,::ng-deep .p-dialog-title,::ng-deep .p-dialog-content,::ng-deep .p-dropdown,::ng-deep .p-dropdown-label,::ng-deep .p-dropdown-item,::ng-deep .p-dynamic-dialog,::ng-deep .p-dynamic-dialog-title,::ng-deep .p-dynamic-dialog-content,::ng-deep .p-editor,::ng-deep .p-fieldset,::ng-deep .p-fieldset-legend,::ng-deep .p-fieldset-content,::ng-deep .p-fileupload,::ng-deep .p-inputmask,::ng-deep .p-inputnumber,::ng-deep .p-inputtextarea,::ng-deep .p-inputtext,::ng-deep .p-menu,::ng-deep .p-menuitem,::ng-deep .p-menuitem-text,::ng-deep .p-message,::ng-deep .p-messages,::ng-deep .p-multiselect,::ng-deep .p-multiselect-label,::ng-deep .p-multiselect-item,::ng-deep .p-panelmenu,::ng-deep .p-panelmenu-header,::ng-deep .p-panelmenu-content,::ng-deep .p-panel,::ng-deep .p-panel-header,::ng-deep .p-panel-content,::ng-deep .p-password,::ng-deep .p-picklist,::ng-deep .p-progressbar,::ng-deep .p-radiobutton,::ng-deep .p-rating,::ng-deep .p-sidebar,::ng-deep .p-splitbutton,::ng-deep .p-steps,::ng-deep .p-step,::ng-deep .p-table,::ng-deep .p-datatable,::ng-deep .p-tabview,::ng-deep .p-tabpanel,::ng-deep .p-tag,::ng-deep .p-toast,::ng-deep .p-toolbar,::ng-deep .p-tooltip,::ng-deep .p-tree,::ng-deep .p-treetable,::ng-deep .p-selectbutton,::ng-deep .p-stepper,::ng-deep .p-inputgroup,::ng-deep .p-inputgroup-addon,::ng-deep .p-text{font-family:Inter,Inter var,sans-serif!important}::ng-deep .p-icon,svg{height:.6rem}:host ::ng-deep .inputs{height:1.875rem}:host ::ng-deep .inputs,.p-inputtext,.p-inputtextarea{font-size:.875rem}::ng-deep .p-dialog .p-dialog-header{color:rgb(var(--kv-color-text))!important;background:linear-gradient(0deg,#00000005 .44%,#0000 49.5%),#fff!important;display:flex!important;flex-wrap:wrap;word-wrap:break-word;border-bottom:1px solid rgb(var(--kv-color-text),.15)}::ng-deep .p-dialog{min-width:320px}::ng-deep *::-webkit-scrollbar{width:5px}::ng-deep *::-webkit-scrollbar-thumb{background-color:#00000080}::ng-deep *::-webkit-scrollbar-track{background-color:#dededebf}::ng-deep .p-dialog-content{overflow-x:hidden}::ng-deep .p-dialog-footer{display:flex;justify-content:flex-end;padding:10px;gap:10px}::ng-deep .p-tooltip{font-size:.825rem!important}::ng-deep svg.p-icon{width:.65rem;height:.65rem}::ng-deep .p-checkbox .p-checkbox-box.p-highlight{border-color:#004172;background:#004172}::ng-deep .p-checkbox .p-checkbox-box.p-highlight:hover{background-color:#002542}::ng-deep .p-checkbox .p-checkbox-box.p-highlight:active{background-color:#002542}::ng-deep .p-checkbox .p-checkbox-box.p-highlight:disabled{background-color:#002542;opacity:.4;cursor:auto}input{height:1.75rem}::ng-deep .p-checkbox .p-checkbox-box{width:1.125rem;height:1.125rem;border:1.5px solid #d1d5db}::ng-deep p-tablecheckbox p-tableheadercheckbox .p-checkbox{display:flex!important;align-items:center!important;justify-content:right}::ng-deep .p-checkbox{display:flex!important;align-items:center!important;justify-content:center}::ng-deep .p-checkbox-label{font-size:.875rem}:host *{padding:0;margin:0;box-sizing:border-box}.main-container{height:auto}.shape-icon{position:relative;display:flex;justify-content:center;align-items:center;container-type:inline-size;container-name:shape-container}.shape-icon.small{width:1.9rem;height:1.9rem}.shape-icon.medium{width:2.2rem;height:2.2rem}.shape-icon.large{width:2.6rem;height:2.6rem}.shape-icon.system{background-color:rgba(var(--kv-color-system),1)}.shape-icon.success{background-color:rgba(var(--kv-success-color),1)}.shape-icon.info{background-color:rgba(var(--kv-info-color),.4)}.shape-icon.warning{background-color:rgba(var(--kv-warn-color),1)}.shape-icon.danger{background-color:rgba(var(--kv-danger-color),1)}.shape-icon.contrast{background-color:rgba(var(--kv-contrast-color),1)}.shape-icon.circle{border-radius:50%}.shape-icon.square{border-radius:20%}.shape-icon.hexagon{clip-path:polygon(50% 0%,95.5% 27.67%,95.5% 70.1%,50% 100%,4.5% 70.1%,4.5% 27.67%)}.shape-icon .material-symbols-outlined{font-size:70cqi!important}\n"] }); }
25
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: KvIconComponent, selector: "kv-icon", inputs: { icon: { classPropertyName: "icon", publicName: "icon", isSignal: true, isRequired: true, transformFunction: null }, shape: { classPropertyName: "shape", publicName: "shape", isSignal: true, isRequired: true, transformFunction: null }, severity: { classPropertyName: "severity", publicName: "severity", isSignal: true, isRequired: true, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "<div class=\"main-container\">\r\n\r\n <div class=\"shape-icon {{ size() }} {{ shape() }} {{ severity() }}\">\r\n\r\n @if(icon()) {\r\n <span class=\"material-symbols-outlined text-white\">\r\n {{ icon() }}\r\n </span>\r\n }\r\n \r\n </div>\r\n \r\n</div>", styles: ["@import\"https://fonts.googleapis.com/css2?family=Inter:wght@100..900&display=swap\";@import\"https://fonts.googleapis.com/css2?family=Inter:wght@100;200;300;400;500;600;700;800;900&display=swap\";@import\"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@24,400,0,0\";::ng-deep :root{--kv-color-system: 10,58,120;--kv-color-system-cta: 76, 175, 80;--kv-color-text: 0, 0, 0;--kv-color-text-inv: 255, 255, 165;--kv-background-system: 248,250,253;--kv-background-card: 255,255,255;--kv-primary-color: 41, 185, 45;--kv-secondary-color: 0, 37, 66;--kv-tertiary-color: 165, 165, 165;--kv-danger-color: 220, 53, 69;--kv-success-color: 75, 181, 67;--kv-info-color: 58, 170, 208;--kv-warn-color: 241, 90, 36;--kv-contrast-color: 33, 37, 41}::ng-deep .padrao{--kv-color-system: 10,58,120;--kv-color-system-cta: 76, 175, 80;--kv-color-text: 0, 0, 0;--kv-background-system: 248,250,253;--kv-background-card: 255,255,255}::ng-deep .theme-keevocenter{--kv-color-system: 88,25,153;--kv-color-system-cta: 0, 116, 217;--kv-color-text: 0, 0, 0;--kv-color-text-inv: 255, 255, 165;--kv-background-system: 248,250,253;--kv-background-card: 255,255,255}::ng-deep .theme-holos{--kv-color-system: 241,90,36;--kv-color-system-cta: 224, 168, 35;--kv-color-text: 0, 0, 0;--kv-color-text-inv: 255, 255, 165;--kv-background-system: 240,240,240;--kv-background-card: 2255,255,255}.system-color{color:rgb(var(--kv-color-system),1)}.bg-system-100{background:rgb(var(--kv-color-system),1)}.bg-system-75{background:rgb(var(--kv-color-system),.75)}.bg-system-50{background:rgb(var(--kv-color-system),.5)}.bg-system-25{background:rgb(var(--kv-color-system),.25)}.material-symbols-outlined{font-family:Material Symbols Outlined!important}*{font-family:Inter,Inter var,sans-serif!important}::ng-deep .p-accordion,::ng-deep .p-accordion-header,::ng-deep .p-accordion-content,::ng-deep .p-badge,::ng-deep .p-overlay-badge,::ng-deep .p-breadcrumb,::ng-deep .p-breadcrumb-item,::ng-deep .p-breadcrumb-link,::ng-deep .p-button,::ng-deep .p-calendar,::ng-deep .p-card,::ng-deep .p-card-title,::ng-deep .p-card-subtitle,::ng-deep .p-card-content,::ng-deep .p-checkbox,::ng-deep .p-chip,::ng-deep .p-confirm-dialog,::ng-deep .p-confirm-dialog-message,::ng-deep .p-contextmenu,::ng-deep .p-contextmenu-item,::ng-deep .p-dataview,::ng-deep .p-dataview-content,::ng-deep .p-dialog,::ng-deep .p-dialog-title,::ng-deep .p-dialog-content,::ng-deep .p-dropdown,::ng-deep .p-dropdown-label,::ng-deep .p-dropdown-item,::ng-deep .p-dynamic-dialog,::ng-deep .p-dynamic-dialog-title,::ng-deep .p-dynamic-dialog-content,::ng-deep .p-editor,::ng-deep .p-fieldset,::ng-deep .p-fieldset-legend,::ng-deep .p-fieldset-content,::ng-deep .p-fileupload,::ng-deep .p-inputmask,::ng-deep .p-inputnumber,::ng-deep .p-inputtextarea,::ng-deep .p-inputtext,::ng-deep .p-menu,::ng-deep .p-menuitem,::ng-deep .p-menuitem-text,::ng-deep .p-message,::ng-deep .p-messages,::ng-deep .p-multiselect,::ng-deep .p-multiselect-label,::ng-deep .p-multiselect-item,::ng-deep .p-panelmenu,::ng-deep .p-panelmenu-header,::ng-deep .p-panelmenu-content,::ng-deep .p-panel,::ng-deep .p-panel-header,::ng-deep .p-panel-content,::ng-deep .p-password,::ng-deep .p-picklist,::ng-deep .p-progressbar,::ng-deep .p-radiobutton,::ng-deep .p-rating,::ng-deep .p-sidebar,::ng-deep .p-splitbutton,::ng-deep .p-steps,::ng-deep .p-step,::ng-deep .p-table,::ng-deep .p-datatable,::ng-deep .p-tabview,::ng-deep .p-tabpanel,::ng-deep .p-tag,::ng-deep .p-toast,::ng-deep .p-toolbar,::ng-deep .p-tooltip,::ng-deep .p-tree,::ng-deep .p-treetable,::ng-deep .p-selectbutton,::ng-deep .p-stepper,::ng-deep .p-inputgroup,::ng-deep .p-inputgroup-addon,::ng-deep .p-text{font-family:Inter,Inter var,sans-serif!important}::ng-deep .p-icon,svg{height:.6rem}:host ::ng-deep .inputs{height:1.875rem}:host ::ng-deep .inputs,.p-inputtext,.p-inputtextarea{font-size:.875rem}::ng-deep .p-dialog .p-dialog-header{color:rgb(var(--kv-color-text))!important;background:linear-gradient(0deg,#00000005 .44%,#0000 49.5%),#fff!important;display:flex!important;flex-wrap:wrap;word-wrap:break-word;border-bottom:1px solid rgb(var(--kv-color-text),.15)}::ng-deep .p-dialog{min-width:320px}::ng-deep *::-webkit-scrollbar{width:5px}::ng-deep *::-webkit-scrollbar-thumb{background-color:#00000080}::ng-deep *::-webkit-scrollbar-track{background-color:#dededebf}::ng-deep .p-dialog-content{overflow-x:hidden}::ng-deep .p-dialog-footer{display:flex;justify-content:flex-end;padding:10px;gap:10px}::ng-deep .p-tooltip{font-size:.825rem!important}::ng-deep svg.p-icon{width:.65rem;height:.65rem}::ng-deep .p-checkbox .p-checkbox-box.p-highlight{border-color:#004172;background:#004172}::ng-deep .p-checkbox .p-checkbox-box.p-highlight:hover{background-color:#002542}::ng-deep .p-checkbox .p-checkbox-box.p-highlight:active{background-color:#002542}::ng-deep .p-checkbox .p-checkbox-box.p-highlight:disabled{background-color:#002542;opacity:.4;cursor:auto}input{height:1.75rem}::ng-deep .p-checkbox .p-checkbox-box{width:1.125rem;height:1.125rem;border:1.5px solid #d1d5db}::ng-deep p-tablecheckbox p-tableheadercheckbox .p-checkbox{display:flex!important;align-items:center!important;justify-content:right}::ng-deep .p-checkbox{display:flex!important;align-items:center!important;justify-content:center}::ng-deep .p-checkbox-label{font-size:.875rem}:host *{padding:0;margin:0;box-sizing:border-box}.main-container{height:auto}.shape-icon{position:relative;display:flex;justify-content:center;align-items:center;container-type:inline-size;container-name:shape-container}.shape-icon.small{width:1.9rem;height:1.9rem}.shape-icon.medium{width:2.2rem;height:2.2rem}.shape-icon.large{width:2.6rem;height:2.6rem}.shape-icon.system{background-color:rgba(var(--kv-color-system),1)}.shape-icon.success{background-color:rgba(var(--kv-success-color),1)}.shape-icon.info{background-color:rgba(var(--kv-info-color),.4)}.shape-icon.warning{background-color:rgba(var(--kv-warn-color),1)}.shape-icon.danger{background-color:rgba(var(--kv-danger-color),1)}.shape-icon.contrast{background-color:rgba(var(--kv-contrast-color),1)}.shape-icon.circle{border-radius:50%}.shape-icon.square{border-radius:20%}.shape-icon.hexagon{clip-path:polygon(50% 0%,95.5% 27.67%,95.5% 70.1%,50% 100%,4.5% 70.1%,4.5% 27.67%)}.shape-icon .material-symbols-outlined{font-size:70cqi!important}\n"] }); }
26
26
  }
27
27
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvIconComponent, decorators: [{
28
28
  type: Component,
29
- args: [{ selector: 'kv-icon', template: "<div class=\"main-container\">\n\n <div class=\"shape-icon {{ size() }} {{ shape() }} {{ severity() }}\">\n\n @if(icon()) {\n <span class=\"material-symbols-outlined text-white\">\n {{ icon() }}\n </span>\n }\n \n </div>\n \n</div>", styles: ["@import\"https://fonts.googleapis.com/css2?family=Inter:wght@100..900&display=swap\";@import\"https://fonts.googleapis.com/css2?family=Inter:wght@100;200;300;400;500;600;700;800;900&display=swap\";@import\"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@24,400,0,0\";::ng-deep :root{--kv-color-system: 10,58,120;--kv-color-system-cta: 76, 175, 80;--kv-color-text: 0, 0, 0;--kv-color-text-inv: 255, 255, 165;--kv-background-system: 248,250,253;--kv-background-card: 255,255,255;--kv-primary-color: 41, 185, 45;--kv-secondary-color: 0, 37, 66;--kv-tertiary-color: 165, 165, 165;--kv-danger-color: 220, 53, 69;--kv-success-color: 75, 181, 67;--kv-info-color: 58, 170, 208;--kv-warn-color: 241, 90, 36;--kv-contrast-color: 33, 37, 41}::ng-deep .padrao{--kv-color-system: 10,58,120;--kv-color-system-cta: 76, 175, 80;--kv-color-text: 0, 0, 0;--kv-background-system: 248,250,253;--kv-background-card: 255,255,255}::ng-deep .theme-keevocenter{--kv-color-system: 88,25,153;--kv-color-system-cta: 0, 116, 217;--kv-color-text: 0, 0, 0;--kv-color-text-inv: 255, 255, 165;--kv-background-system: 248,250,253;--kv-background-card: 255,255,255}::ng-deep .theme-holos{--kv-color-system: 241,90,36;--kv-color-system-cta: 224, 168, 35;--kv-color-text: 0, 0, 0;--kv-color-text-inv: 255, 255, 165;--kv-background-system: 240,240,240;--kv-background-card: 2255,255,255}.system-color{color:rgb(var(--kv-color-system),1)}.bg-system-100{background:rgb(var(--kv-color-system),1)}.bg-system-75{background:rgb(var(--kv-color-system),.75)}.bg-system-50{background:rgb(var(--kv-color-system),.5)}.bg-system-25{background:rgb(var(--kv-color-system),.25)}.material-symbols-outlined{font-family:Material Symbols Outlined!important}*{font-family:Inter,Inter var,sans-serif!important}::ng-deep .p-accordion,::ng-deep .p-accordion-header,::ng-deep .p-accordion-content,::ng-deep .p-badge,::ng-deep .p-overlay-badge,::ng-deep .p-breadcrumb,::ng-deep .p-breadcrumb-item,::ng-deep .p-breadcrumb-link,::ng-deep .p-button,::ng-deep .p-calendar,::ng-deep .p-card,::ng-deep .p-card-title,::ng-deep .p-card-subtitle,::ng-deep .p-card-content,::ng-deep .p-checkbox,::ng-deep .p-chip,::ng-deep .p-confirm-dialog,::ng-deep .p-confirm-dialog-message,::ng-deep .p-contextmenu,::ng-deep .p-contextmenu-item,::ng-deep .p-dataview,::ng-deep .p-dataview-content,::ng-deep .p-dialog,::ng-deep .p-dialog-title,::ng-deep .p-dialog-content,::ng-deep .p-dropdown,::ng-deep .p-dropdown-label,::ng-deep .p-dropdown-item,::ng-deep .p-dynamic-dialog,::ng-deep .p-dynamic-dialog-title,::ng-deep .p-dynamic-dialog-content,::ng-deep .p-editor,::ng-deep .p-fieldset,::ng-deep .p-fieldset-legend,::ng-deep .p-fieldset-content,::ng-deep .p-fileupload,::ng-deep .p-inputmask,::ng-deep .p-inputnumber,::ng-deep .p-inputtextarea,::ng-deep .p-inputtext,::ng-deep .p-menu,::ng-deep .p-menuitem,::ng-deep .p-menuitem-text,::ng-deep .p-message,::ng-deep .p-messages,::ng-deep .p-multiselect,::ng-deep .p-multiselect-label,::ng-deep .p-multiselect-item,::ng-deep .p-panelmenu,::ng-deep .p-panelmenu-header,::ng-deep .p-panelmenu-content,::ng-deep .p-panel,::ng-deep .p-panel-header,::ng-deep .p-panel-content,::ng-deep .p-password,::ng-deep .p-picklist,::ng-deep .p-progressbar,::ng-deep .p-radiobutton,::ng-deep .p-rating,::ng-deep .p-sidebar,::ng-deep .p-splitbutton,::ng-deep .p-steps,::ng-deep .p-step,::ng-deep .p-table,::ng-deep .p-datatable,::ng-deep .p-tabview,::ng-deep .p-tabpanel,::ng-deep .p-tag,::ng-deep .p-toast,::ng-deep .p-toolbar,::ng-deep .p-tooltip,::ng-deep .p-tree,::ng-deep .p-treetable,::ng-deep .p-selectbutton,::ng-deep .p-stepper,::ng-deep .p-inputgroup,::ng-deep .p-inputgroup-addon,::ng-deep .p-text{font-family:Inter,Inter var,sans-serif!important}::ng-deep .p-icon,svg{height:.6rem}:host ::ng-deep .inputs{height:1.875rem}:host ::ng-deep .inputs,.p-inputtext,.p-inputtextarea{font-size:.875rem}::ng-deep .p-dialog .p-dialog-header{color:rgb(var(--kv-color-text))!important;background:linear-gradient(0deg,#00000005 .44%,#0000 49.5%),#fff!important;display:flex!important;flex-wrap:wrap;word-wrap:break-word;border-bottom:1px solid rgb(var(--kv-color-text),.15)}::ng-deep .p-dialog{min-width:320px}::ng-deep *::-webkit-scrollbar{width:5px}::ng-deep *::-webkit-scrollbar-thumb{background-color:#00000080}::ng-deep *::-webkit-scrollbar-track{background-color:#dededebf}::ng-deep .p-dialog-content{overflow-x:hidden}::ng-deep .p-dialog-footer{display:flex;justify-content:flex-end;padding:10px;gap:10px}::ng-deep .p-tooltip{font-size:.825rem!important}::ng-deep svg.p-icon{width:.65rem;height:.65rem}::ng-deep .p-checkbox .p-checkbox-box.p-highlight{border-color:#004172;background:#004172}::ng-deep .p-checkbox .p-checkbox-box.p-highlight:hover{background-color:#002542}::ng-deep .p-checkbox .p-checkbox-box.p-highlight:active{background-color:#002542}::ng-deep .p-checkbox .p-checkbox-box.p-highlight:disabled{background-color:#002542;opacity:.4;cursor:auto}input{height:1.75rem}::ng-deep .p-checkbox .p-checkbox-box{width:1.125rem;height:1.125rem;border:1.5px solid #d1d5db}::ng-deep p-tablecheckbox p-tableheadercheckbox .p-checkbox{display:flex!important;align-items:center!important;justify-content:right}::ng-deep .p-checkbox{display:flex!important;align-items:center!important;justify-content:center}::ng-deep .p-checkbox-label{font-size:.875rem}:host *{padding:0;margin:0;box-sizing:border-box}.main-container{height:auto}.shape-icon{position:relative;display:flex;justify-content:center;align-items:center;container-type:inline-size;container-name:shape-container}.shape-icon.small{width:1.9rem;height:1.9rem}.shape-icon.medium{width:2.2rem;height:2.2rem}.shape-icon.large{width:2.6rem;height:2.6rem}.shape-icon.system{background-color:rgba(var(--kv-color-system),1)}.shape-icon.success{background-color:rgba(var(--kv-success-color),1)}.shape-icon.info{background-color:rgba(var(--kv-info-color),.4)}.shape-icon.warning{background-color:rgba(var(--kv-warn-color),1)}.shape-icon.danger{background-color:rgba(var(--kv-danger-color),1)}.shape-icon.contrast{background-color:rgba(var(--kv-contrast-color),1)}.shape-icon.circle{border-radius:50%}.shape-icon.square{border-radius:20%}.shape-icon.hexagon{clip-path:polygon(50% 0%,95.5% 27.67%,95.5% 70.1%,50% 100%,4.5% 70.1%,4.5% 27.67%)}.shape-icon .material-symbols-outlined{font-size:70cqi!important}\n"] }]
29
+ args: [{ selector: 'kv-icon', template: "<div class=\"main-container\">\r\n\r\n <div class=\"shape-icon {{ size() }} {{ shape() }} {{ severity() }}\">\r\n\r\n @if(icon()) {\r\n <span class=\"material-symbols-outlined text-white\">\r\n {{ icon() }}\r\n </span>\r\n }\r\n \r\n </div>\r\n \r\n</div>", styles: ["@import\"https://fonts.googleapis.com/css2?family=Inter:wght@100..900&display=swap\";@import\"https://fonts.googleapis.com/css2?family=Inter:wght@100;200;300;400;500;600;700;800;900&display=swap\";@import\"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@24,400,0,0\";::ng-deep :root{--kv-color-system: 10,58,120;--kv-color-system-cta: 76, 175, 80;--kv-color-text: 0, 0, 0;--kv-color-text-inv: 255, 255, 165;--kv-background-system: 248,250,253;--kv-background-card: 255,255,255;--kv-primary-color: 41, 185, 45;--kv-secondary-color: 0, 37, 66;--kv-tertiary-color: 165, 165, 165;--kv-danger-color: 220, 53, 69;--kv-success-color: 75, 181, 67;--kv-info-color: 58, 170, 208;--kv-warn-color: 241, 90, 36;--kv-contrast-color: 33, 37, 41}::ng-deep .padrao{--kv-color-system: 10,58,120;--kv-color-system-cta: 76, 175, 80;--kv-color-text: 0, 0, 0;--kv-background-system: 248,250,253;--kv-background-card: 255,255,255}::ng-deep .theme-keevocenter{--kv-color-system: 88,25,153;--kv-color-system-cta: 0, 116, 217;--kv-color-text: 0, 0, 0;--kv-color-text-inv: 255, 255, 165;--kv-background-system: 248,250,253;--kv-background-card: 255,255,255}::ng-deep .theme-holos{--kv-color-system: 241,90,36;--kv-color-system-cta: 224, 168, 35;--kv-color-text: 0, 0, 0;--kv-color-text-inv: 255, 255, 165;--kv-background-system: 240,240,240;--kv-background-card: 2255,255,255}.system-color{color:rgb(var(--kv-color-system),1)}.bg-system-100{background:rgb(var(--kv-color-system),1)}.bg-system-75{background:rgb(var(--kv-color-system),.75)}.bg-system-50{background:rgb(var(--kv-color-system),.5)}.bg-system-25{background:rgb(var(--kv-color-system),.25)}.material-symbols-outlined{font-family:Material Symbols Outlined!important}*{font-family:Inter,Inter var,sans-serif!important}::ng-deep .p-accordion,::ng-deep .p-accordion-header,::ng-deep .p-accordion-content,::ng-deep .p-badge,::ng-deep .p-overlay-badge,::ng-deep .p-breadcrumb,::ng-deep .p-breadcrumb-item,::ng-deep .p-breadcrumb-link,::ng-deep .p-button,::ng-deep .p-calendar,::ng-deep .p-card,::ng-deep .p-card-title,::ng-deep .p-card-subtitle,::ng-deep .p-card-content,::ng-deep .p-checkbox,::ng-deep .p-chip,::ng-deep .p-confirm-dialog,::ng-deep .p-confirm-dialog-message,::ng-deep .p-contextmenu,::ng-deep .p-contextmenu-item,::ng-deep .p-dataview,::ng-deep .p-dataview-content,::ng-deep .p-dialog,::ng-deep .p-dialog-title,::ng-deep .p-dialog-content,::ng-deep .p-dropdown,::ng-deep .p-dropdown-label,::ng-deep .p-dropdown-item,::ng-deep .p-dynamic-dialog,::ng-deep .p-dynamic-dialog-title,::ng-deep .p-dynamic-dialog-content,::ng-deep .p-editor,::ng-deep .p-fieldset,::ng-deep .p-fieldset-legend,::ng-deep .p-fieldset-content,::ng-deep .p-fileupload,::ng-deep .p-inputmask,::ng-deep .p-inputnumber,::ng-deep .p-inputtextarea,::ng-deep .p-inputtext,::ng-deep .p-menu,::ng-deep .p-menuitem,::ng-deep .p-menuitem-text,::ng-deep .p-message,::ng-deep .p-messages,::ng-deep .p-multiselect,::ng-deep .p-multiselect-label,::ng-deep .p-multiselect-item,::ng-deep .p-panelmenu,::ng-deep .p-panelmenu-header,::ng-deep .p-panelmenu-content,::ng-deep .p-panel,::ng-deep .p-panel-header,::ng-deep .p-panel-content,::ng-deep .p-password,::ng-deep .p-picklist,::ng-deep .p-progressbar,::ng-deep .p-radiobutton,::ng-deep .p-rating,::ng-deep .p-sidebar,::ng-deep .p-splitbutton,::ng-deep .p-steps,::ng-deep .p-step,::ng-deep .p-table,::ng-deep .p-datatable,::ng-deep .p-tabview,::ng-deep .p-tabpanel,::ng-deep .p-tag,::ng-deep .p-toast,::ng-deep .p-toolbar,::ng-deep .p-tooltip,::ng-deep .p-tree,::ng-deep .p-treetable,::ng-deep .p-selectbutton,::ng-deep .p-stepper,::ng-deep .p-inputgroup,::ng-deep .p-inputgroup-addon,::ng-deep .p-text{font-family:Inter,Inter var,sans-serif!important}::ng-deep .p-icon,svg{height:.6rem}:host ::ng-deep .inputs{height:1.875rem}:host ::ng-deep .inputs,.p-inputtext,.p-inputtextarea{font-size:.875rem}::ng-deep .p-dialog .p-dialog-header{color:rgb(var(--kv-color-text))!important;background:linear-gradient(0deg,#00000005 .44%,#0000 49.5%),#fff!important;display:flex!important;flex-wrap:wrap;word-wrap:break-word;border-bottom:1px solid rgb(var(--kv-color-text),.15)}::ng-deep .p-dialog{min-width:320px}::ng-deep *::-webkit-scrollbar{width:5px}::ng-deep *::-webkit-scrollbar-thumb{background-color:#00000080}::ng-deep *::-webkit-scrollbar-track{background-color:#dededebf}::ng-deep .p-dialog-content{overflow-x:hidden}::ng-deep .p-dialog-footer{display:flex;justify-content:flex-end;padding:10px;gap:10px}::ng-deep .p-tooltip{font-size:.825rem!important}::ng-deep svg.p-icon{width:.65rem;height:.65rem}::ng-deep .p-checkbox .p-checkbox-box.p-highlight{border-color:#004172;background:#004172}::ng-deep .p-checkbox .p-checkbox-box.p-highlight:hover{background-color:#002542}::ng-deep .p-checkbox .p-checkbox-box.p-highlight:active{background-color:#002542}::ng-deep .p-checkbox .p-checkbox-box.p-highlight:disabled{background-color:#002542;opacity:.4;cursor:auto}input{height:1.75rem}::ng-deep .p-checkbox .p-checkbox-box{width:1.125rem;height:1.125rem;border:1.5px solid #d1d5db}::ng-deep p-tablecheckbox p-tableheadercheckbox .p-checkbox{display:flex!important;align-items:center!important;justify-content:right}::ng-deep .p-checkbox{display:flex!important;align-items:center!important;justify-content:center}::ng-deep .p-checkbox-label{font-size:.875rem}:host *{padding:0;margin:0;box-sizing:border-box}.main-container{height:auto}.shape-icon{position:relative;display:flex;justify-content:center;align-items:center;container-type:inline-size;container-name:shape-container}.shape-icon.small{width:1.9rem;height:1.9rem}.shape-icon.medium{width:2.2rem;height:2.2rem}.shape-icon.large{width:2.6rem;height:2.6rem}.shape-icon.system{background-color:rgba(var(--kv-color-system),1)}.shape-icon.success{background-color:rgba(var(--kv-success-color),1)}.shape-icon.info{background-color:rgba(var(--kv-info-color),.4)}.shape-icon.warning{background-color:rgba(var(--kv-warn-color),1)}.shape-icon.danger{background-color:rgba(var(--kv-danger-color),1)}.shape-icon.contrast{background-color:rgba(var(--kv-contrast-color),1)}.shape-icon.circle{border-radius:50%}.shape-icon.square{border-radius:20%}.shape-icon.hexagon{clip-path:polygon(50% 0%,95.5% 27.67%,95.5% 70.1%,50% 100%,4.5% 70.1%,4.5% 27.67%)}.shape-icon .material-symbols-outlined{font-size:70cqi!important}\n"] }]
30
30
  }] });
31
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia3YtaWNvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9rZWV2by1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9rdi1pY29uL2t2LWljb24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2Vldm8tY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMva3YtaWNvbi9rdi1pY29uLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFVLE1BQU0sZUFBZSxDQUFDOztBQUl6RDs7Ozs7Ozs7Ozs7OztHQWFHO0FBTUgsTUFBTSxPQUFPLGVBQWU7SUFMNUI7UUFPRSxTQUFJLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBVSxDQUFDO1FBQ2hDLFVBQUssR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFtQyxDQUFDO1FBQzFELGFBQVEsR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFxRSxDQUFDO1FBQy9GLFNBQUksR0FBRyxLQUFLLENBQStCLFFBQVEsQ0FBQyxDQUFDO0tBRXREOzhHQVBZLGVBQWU7a0dBQWYsZUFBZSwyaEJDdkI1QixvUUFZTTs7MkZEV08sZUFBZTtrQkFMM0IsU0FBUzsrQkFDRSxTQUFTIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBpbnB1dCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBzZXZlcml0eUNvbG9yQWN0aXZlIH0gZnJvbSAnLi4vLi4vYXBpL2hlbHBlcnMvc2V2ZXJpdHktY29sb3InO1xuaW1wb3J0ICogYXMgSWNvbk1vZGVscyBmcm9tICcuL2t2LWljb24ubW9kZWwnO1xuXG4vKipcbiAqIENvbXBvbmVudGUgcGFyYSBleGliacOnw6NvIGRlIMOtY29uZXMgbmEgYXBsaWNhw6fDo28uXG4gKiBcbiAqIE8gY29tcG9uZW50ZSBga3YtaWNvbmAgcGVybWl0ZSByZW5kZXJpemFyIMOtY29uZXMgYmFzZWFkb3Mgbm8gbW9kZWxvIGZvcm5lY2lkby5cbiAqIFxuICogQGV4YW1wbGVcbiAqIGBgYGh0bWxcbiAqIDxrdi1pY29uIFtpY29uXT1cIidpbmZvJ1wiIFtzZXZlcml0eV09XCInc3lzdGVtJ1wiIFtzaGFwZV09XCInY2lyY2xlJ1wiPjwva3YtaWNvbj5cbiAqIGBgYFxuICogXG4gKiBAaW5wdXQgaWNvbiAtIERlZmluZSBvIMOtY29uZSBhIHNlciBleGliaWRvLlxuICogQGlucHV0IHNoYXBlIC0gRGVmaW5lIGEgZm9ybWEgZG8gw61jb25lIChvcMOnw7VlczogJ2NpcmNsZScsICdoZXhhZ29uJywgJ3NxdWFyZScpLlxuICogQGlucHV0IHNldmVyaXR5IC0gRGVmaW5lIGEgc2V2ZXJpZGFkZSBkbyDDrWNvbmUgKG9ww6fDtWVzOiAnc3lzdGVtJywgJ3dhcm5pbmcnLCAnZGFuZ2VyJywgJ3N1Y2Nlc3MnKS5cbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAna3YtaWNvbicsXG4gIHRlbXBsYXRlVXJsOiAnLi9rdi1pY29uLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4va3YtaWNvbi5jb21wb25lbnQuc2NzcyddXG59KVxuZXhwb3J0IGNsYXNzIEt2SWNvbkNvbXBvbmVudCB7XG5cbiAgaWNvbiA9IGlucHV0LnJlcXVpcmVkPHN0cmluZz4oKTtcbiAgc2hhcGUgPSBpbnB1dC5yZXF1aXJlZDwnY2lyY2xlJyB8ICdoZXhhZ29uJyB8ICdzcXVhcmUnPigpO1xuICBzZXZlcml0eSA9IGlucHV0LnJlcXVpcmVkPCdzeXN0ZW0nIHwgJ3dhcm5pbmcnIHwgJ2RhbmdlcicgfCAnc3VjY2VzcycgfCAnY29udHJhc3QnIHwgJ2luZm8nPigpO1xuICBzaXplID0gaW5wdXQ8J3NtYWxsJyB8ICdtZWRpdW0nIHwgJ2xhcmdlJz4oJ21lZGl1bScpO1xuXG59XG4iLCI8ZGl2IGNsYXNzPVwibWFpbi1jb250YWluZXJcIj5cblxuICA8ZGl2IGNsYXNzPVwic2hhcGUtaWNvbiB7eyBzaXplKCkgfX0ge3sgc2hhcGUoKSB9fSB7eyBzZXZlcml0eSgpIH19XCI+XG5cbiAgICBAaWYoaWNvbigpKSB7XG4gICAgICA8c3BhbiBjbGFzcz1cIm1hdGVyaWFsLXN5bWJvbHMtb3V0bGluZWQgdGV4dC13aGl0ZVwiPlxuICAgICAgICB7eyBpY29uKCkgfX1cbiAgICAgIDwvc3Bhbj5cbiAgICB9XG4gIFxuICA8L2Rpdj5cbiAgXG48L2Rpdj4iXX0=
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia3YtaWNvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9rZWV2by1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9rdi1pY29uL2t2LWljb24uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2Vldm8tY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMva3YtaWNvbi9rdi1pY29uLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFVLE1BQU0sZUFBZSxDQUFDOztBQUl6RDs7Ozs7Ozs7Ozs7OztHQWFHO0FBTUgsTUFBTSxPQUFPLGVBQWU7SUFMNUI7UUFPRSxTQUFJLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBVSxDQUFDO1FBQ2hDLFVBQUssR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFtQyxDQUFDO1FBQzFELGFBQVEsR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFxRSxDQUFDO1FBQy9GLFNBQUksR0FBRyxLQUFLLENBQStCLFFBQVEsQ0FBQyxDQUFDO0tBRXREOzhHQVBZLGVBQWU7a0dBQWYsZUFBZSwyaEJDdkI1Qiw0UkFZTTs7MkZEV08sZUFBZTtrQkFMM0IsU0FBUzsrQkFDRSxTQUFTIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBpbnB1dCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IHNldmVyaXR5Q29sb3JBY3RpdmUgfSBmcm9tICcuLi8uLi9hcGkvaGVscGVycy9zZXZlcml0eS1jb2xvcic7XHJcbmltcG9ydCAqIGFzIEljb25Nb2RlbHMgZnJvbSAnLi9rdi1pY29uLm1vZGVsJztcclxuXHJcbi8qKlxyXG4gKiBDb21wb25lbnRlIHBhcmEgZXhpYmnDp8OjbyBkZSDDrWNvbmVzIG5hIGFwbGljYcOnw6NvLlxyXG4gKiBcclxuICogTyBjb21wb25lbnRlIGBrdi1pY29uYCBwZXJtaXRlIHJlbmRlcml6YXIgw61jb25lcyBiYXNlYWRvcyBubyBtb2RlbG8gZm9ybmVjaWRvLlxyXG4gKiBcclxuICogQGV4YW1wbGVcclxuICogYGBgaHRtbFxyXG4gKiA8a3YtaWNvbiBbaWNvbl09XCInaW5mbydcIiBbc2V2ZXJpdHldPVwiJ3N5c3RlbSdcIiBbc2hhcGVdPVwiJ2NpcmNsZSdcIj48L2t2LWljb24+XHJcbiAqIGBgYFxyXG4gKiBcclxuICogQGlucHV0IGljb24gLSBEZWZpbmUgbyDDrWNvbmUgYSBzZXIgZXhpYmlkby5cclxuICogQGlucHV0IHNoYXBlIC0gRGVmaW5lIGEgZm9ybWEgZG8gw61jb25lIChvcMOnw7VlczogJ2NpcmNsZScsICdoZXhhZ29uJywgJ3NxdWFyZScpLlxyXG4gKiBAaW5wdXQgc2V2ZXJpdHkgLSBEZWZpbmUgYSBzZXZlcmlkYWRlIGRvIMOtY29uZSAob3DDp8O1ZXM6ICdzeXN0ZW0nLCAnd2FybmluZycsICdkYW5nZXInLCAnc3VjY2VzcycpLlxyXG4gKi9cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdrdi1pY29uJyxcclxuICB0ZW1wbGF0ZVVybDogJy4va3YtaWNvbi5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4va3YtaWNvbi5jb21wb25lbnQuc2NzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBLdkljb25Db21wb25lbnQge1xyXG5cclxuICBpY29uID0gaW5wdXQucmVxdWlyZWQ8c3RyaW5nPigpO1xyXG4gIHNoYXBlID0gaW5wdXQucmVxdWlyZWQ8J2NpcmNsZScgfCAnaGV4YWdvbicgfCAnc3F1YXJlJz4oKTtcclxuICBzZXZlcml0eSA9IGlucHV0LnJlcXVpcmVkPCdzeXN0ZW0nIHwgJ3dhcm5pbmcnIHwgJ2RhbmdlcicgfCAnc3VjY2VzcycgfCAnY29udHJhc3QnIHwgJ2luZm8nPigpO1xyXG4gIHNpemUgPSBpbnB1dDwnc21hbGwnIHwgJ21lZGl1bScgfCAnbGFyZ2UnPignbWVkaXVtJyk7XHJcblxyXG59XHJcbiIsIjxkaXYgY2xhc3M9XCJtYWluLWNvbnRhaW5lclwiPlxyXG5cclxuICA8ZGl2IGNsYXNzPVwic2hhcGUtaWNvbiB7eyBzaXplKCkgfX0ge3sgc2hhcGUoKSB9fSB7eyBzZXZlcml0eSgpIH19XCI+XHJcblxyXG4gICAgQGlmKGljb24oKSkge1xyXG4gICAgICA8c3BhbiBjbGFzcz1cIm1hdGVyaWFsLXN5bWJvbHMtb3V0bGluZWQgdGV4dC13aGl0ZVwiPlxyXG4gICAgICAgIHt7IGljb24oKSB9fVxyXG4gICAgICA8L3NwYW4+XHJcbiAgICB9XHJcbiAgXHJcbiAgPC9kaXY+XHJcbiAgXHJcbjwvZGl2PiJdfQ==
@@ -48,10 +48,10 @@ export class KvChipsComponent {
48
48
  this.selectionChange.emit(val);
49
49
  }
50
50
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvChipsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
51
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: KvChipsComponent, isStandalone: true, selector: "kv-chips", inputs: { options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: true, transformFunction: null }, multiple: { classPropertyName: "multiple", publicName: "multiple", isSignal: true, isRequired: false, transformFunction: null }, selection: { classPropertyName: "selection", publicName: "selection", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { selection: "selectionChange", selectionChange: "selectionChange" }, ngImport: i0, template: "<div class=\"chip-container\">\r\n @for (option of options(); track option.value) {\r\n <button\r\n type=\"button\"\r\n class=\"chip\"\r\n [class.selected]=\"isActive(option)\"\r\n (click)=\"toggle(option)\"\r\n >\r\n {{ option.label }}\r\n </button>\r\n }\r\n</div>\r\n", styles: [".chip-container{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.chip{all:unset;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center;padding:.25rem 1rem;background-color:#f8fafc;border:1px solid #cbd5e1;border-radius:999px;color:#64748b;font-family:inherit;font-size:.875rem;font-weight:500;white-space:nowrap;cursor:pointer;transition:all .2s ease-in-out;-webkit-user-select:none;user-select:none}.chip:hover{border-color:#abbbce;color:#4f5b6d}.chip.selected{background-color:#e0f2fe;border-color:#0ea5e9;color:#0b83b9}.chip:focus-visible{outline:2px solid #0ea5e9;outline-offset:2px}\n"] }); }
51
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: KvChipsComponent, isStandalone: true, selector: "kv-chips", inputs: { options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: true, transformFunction: null }, multiple: { classPropertyName: "multiple", publicName: "multiple", isSignal: true, isRequired: false, transformFunction: null }, selection: { classPropertyName: "selection", publicName: "selection", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { selection: "selectionChange", selectionChange: "selectionChange" }, ngImport: i0, template: "<div class=\"chip-container\">\r\n @for (option of options(); track option.value) {\r\n <button\r\n type=\"button\"\r\n class=\"chip\"\r\n [class.selected]=\"isActive(option)\"\r\n (click)=\"toggle(option)\"\r\n >\r\n {{ option.label }}\r\n </button>\r\n }\r\n</div>\r\n", styles: [".chip-container{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.chip{all:unset;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center;padding:.25rem 1rem;background-color:#f8fafc;border:1px solid #cbd5e1;border-radius:.5rem;color:#64748b;font-family:inherit;font-size:.875rem;font-weight:500;white-space:nowrap;cursor:pointer;transition:all .2s ease-in-out;-webkit-user-select:none;user-select:none}.chip:hover{border-color:#abbbce;color:#4f5b6d}.chip.selected{background-color:#e0f2fe;border-color:#3b82f6;color:#0b63f3}.chip:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}\n"] }); }
52
52
  }
53
53
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvChipsComponent, decorators: [{
54
54
  type: Component,
55
- args: [{ selector: 'kv-chips', standalone: true, imports: [], template: "<div class=\"chip-container\">\r\n @for (option of options(); track option.value) {\r\n <button\r\n type=\"button\"\r\n class=\"chip\"\r\n [class.selected]=\"isActive(option)\"\r\n (click)=\"toggle(option)\"\r\n >\r\n {{ option.label }}\r\n </button>\r\n }\r\n</div>\r\n", styles: [".chip-container{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.chip{all:unset;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center;padding:.25rem 1rem;background-color:#f8fafc;border:1px solid #cbd5e1;border-radius:999px;color:#64748b;font-family:inherit;font-size:.875rem;font-weight:500;white-space:nowrap;cursor:pointer;transition:all .2s ease-in-out;-webkit-user-select:none;user-select:none}.chip:hover{border-color:#abbbce;color:#4f5b6d}.chip.selected{background-color:#e0f2fe;border-color:#0ea5e9;color:#0b83b9}.chip:focus-visible{outline:2px solid #0ea5e9;outline-offset:2px}\n"] }]
55
+ args: [{ selector: 'kv-chips', standalone: true, imports: [], template: "<div class=\"chip-container\">\r\n @for (option of options(); track option.value) {\r\n <button\r\n type=\"button\"\r\n class=\"chip\"\r\n [class.selected]=\"isActive(option)\"\r\n (click)=\"toggle(option)\"\r\n >\r\n {{ option.label }}\r\n </button>\r\n }\r\n</div>\r\n", styles: [".chip-container{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.chip{all:unset;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center;padding:.25rem 1rem;background-color:#f8fafc;border:1px solid #cbd5e1;border-radius:.5rem;color:#64748b;font-family:inherit;font-size:.875rem;font-weight:500;white-space:nowrap;cursor:pointer;transition:all .2s ease-in-out;-webkit-user-select:none;user-select:none}.chip:hover{border-color:#abbbce;color:#4f5b6d}.chip.selected{background-color:#e0f2fe;border-color:#3b82f6;color:#0b63f3}.chip:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}\n"] }]
56
56
  }] });
57
57
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia3YtY2hpcHMuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2Vldm8tY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMva3YtaW5wdXRzL2t2LWNoaXBzL2t2LWNoaXBzLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tlZXZvLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2t2LWlucHV0cy9rdi1jaGlwcy9rdi1jaGlwcy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQWNoRSxNQUFNLE9BQU8sZ0JBQWdCO0lBUDdCO1FBUUUsZ0VBQWdFO1FBQ2hFLFlBQU8sR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFnQixDQUFDO1FBRXpDLGlFQUFpRTtRQUNqRSxhQUFRLEdBQUcsS0FBSyxDQUFVLEtBQUssQ0FBQyxDQUFDO1FBRWpDLGdEQUFnRDtRQUNoRCxrRUFBa0U7UUFDbEUsY0FBUyxHQUFHLEtBQUssQ0FBTSxJQUFJLENBQUMsQ0FBQztRQUU3Qiw2QkFBNkI7UUFDN0Isb0JBQWUsR0FBRyxNQUFNLEVBQU8sQ0FBQztLQXdDakM7SUF0Q0MsTUFBTSxDQUFDLE1BQWtCO1FBQ3ZCLE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUNoQyxNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7UUFDakMsTUFBTSxLQUFLLEdBQUcsTUFBTSxDQUFDLEtBQUssQ0FBQztRQUUzQixJQUFJLE9BQU8sRUFBRSxDQUFDO1lBQ1osdUNBQXVDO1lBQ3ZDLElBQUksUUFBUSxHQUFVLEtBQUssQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO1lBRWpFLElBQUksUUFBUSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDO2dCQUM3QixRQUFRLEdBQUcsUUFBUSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsS0FBSyxLQUFLLENBQUMsQ0FBQyxDQUFDLFNBQVM7WUFDekQsQ0FBQztpQkFBTSxDQUFDO2dCQUNOLFFBQVEsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxXQUFXO1lBQ25DLENBQUM7WUFDRCxJQUFJLENBQUMsZUFBZSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBRWpDLENBQUM7YUFBTSxDQUFDO1lBQ04sNENBQTRDO1lBQzVDLDRFQUE0RTtZQUM1RSxJQUFJLE9BQU8sS0FBSyxLQUFLLEVBQUUsQ0FBQztnQkFDdEIsSUFBSSxDQUFDLGVBQWUsQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUM5QixDQUFDO1FBQ0gsQ0FBQztJQUNILENBQUM7SUFFRCxtREFBbUQ7SUFDbkQsUUFBUSxDQUFDLE1BQWtCO1FBQ3pCLE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQztRQUNqQyxJQUFJLElBQUksQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUFDO1lBQ3BCLE9BQU8sS0FBSyxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsSUFBSSxPQUFPLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNsRSxDQUFDO1FBQ0QsT0FBTyxPQUFPLEtBQUssTUFBTSxDQUFDLEtBQUssQ0FBQztJQUNsQyxDQUFDO0lBRU8sZUFBZSxDQUFDLEdBQVE7UUFDOUIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDeEIsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDakMsQ0FBQzs4R0FuRFUsZ0JBQWdCO2tHQUFoQixnQkFBZ0IsaWlCQ2Q3QixvVEFZQTs7MkZERWEsZ0JBQWdCO2tCQVA1QixTQUFTOytCQUNFLFVBQVUsY0FDUixJQUFJLFdBQ1AsRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgaW5wdXQsIG1vZGVsLCBvdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgQ2hpcE9wdGlvbiB7XHJcbiAgbGFiZWw6IHN0cmluZztcclxuICB2YWx1ZTogYW55O1xyXG59XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2t2LWNoaXBzJyxcclxuICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gIGltcG9ydHM6IFtdLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9rdi1jaGlwcy5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmw6ICcuL2t2LWNoaXBzLmNvbXBvbmVudC5zY3NzJ1xyXG59KVxyXG5leHBvcnQgY2xhc3MgS3ZDaGlwc0NvbXBvbmVudCB7XHJcbiAgLy8gUmVjZWJlIGFzIG9ww6fDtWVzIChleDogW3tsYWJlbDogJ1BvciBmaWxpYWwnLCB2YWx1ZTogMX0sIC4uLl0pXHJcbiAgb3B0aW9ucyA9IGlucHV0LnJlcXVpcmVkPENoaXBPcHRpb25bXT4oKTtcclxuXHJcbiAgLy8gRGVmaW5lIHNlIGFjZWl0YSBtw7psdGlwbG9zIG91IGFwZW5hcyB1bSAocGFkcsOjbzogZmFsc2Uvc2luZ2xlKVxyXG4gIG11bHRpcGxlID0gaW5wdXQ8Ym9vbGVhbj4oZmFsc2UpO1xyXG5cclxuICAvLyBPIHZhbG9yIHNlbGVjaW9uYWRvIChwb2RlIHNlciDDum5pY28gb3UgYXJyYXkpXHJcbiAgLy8gVXNhbW9zICdtb2RlbCcgcGFyYSB0d28td2F5IGJpbmRpbmcgZsOhY2lsIFsoc2VsZWN0aW9uKV09XCJ2YWxvclwiXHJcbiAgc2VsZWN0aW9uID0gbW9kZWw8YW55PihudWxsKTtcclxuXHJcbiAgLy8gRXZlbnRvIG9wY2lvbmFsIGRlIG11ZGFuw6dhXHJcbiAgc2VsZWN0aW9uQ2hhbmdlID0gb3V0cHV0PGFueT4oKTtcclxuXHJcbiAgdG9nZ2xlKG9wdGlvbjogQ2hpcE9wdGlvbikge1xyXG4gICAgY29uc3QgaXNNdWx0aSA9IHRoaXMubXVsdGlwbGUoKTtcclxuICAgIGNvbnN0IGN1cnJlbnQgPSB0aGlzLnNlbGVjdGlvbigpO1xyXG4gICAgY29uc3QgdmFsdWUgPSBvcHRpb24udmFsdWU7XHJcblxyXG4gICAgaWYgKGlzTXVsdGkpIHtcclxuICAgICAgLy8gTMOzZ2ljYSBwYXJhIE3Dumx0aXBsYSBTZWxlw6fDo28gKEFycmF5KVxyXG4gICAgICBsZXQgbmV3VmFsdWU6IGFueVtdID0gQXJyYXkuaXNBcnJheShjdXJyZW50KSA/IFsuLi5jdXJyZW50XSA6IFtdO1xyXG5cclxuICAgICAgaWYgKG5ld1ZhbHVlLmluY2x1ZGVzKHZhbHVlKSkge1xyXG4gICAgICAgIG5ld1ZhbHVlID0gbmV3VmFsdWUuZmlsdGVyKHYgPT4gdiAhPT0gdmFsdWUpOyAvLyBSZW1vdmVcclxuICAgICAgfSBlbHNlIHtcclxuICAgICAgICBuZXdWYWx1ZS5wdXNoKHZhbHVlKTsgLy8gQWRpY2lvbmFcclxuICAgICAgfVxyXG4gICAgICB0aGlzLnVwZGF0ZVNlbGVjdGlvbihuZXdWYWx1ZSk7XHJcblxyXG4gICAgfSBlbHNlIHtcclxuICAgICAgLy8gTMOzZ2ljYSBwYXJhIFNlbGXDp8OjbyDDmm5pY2EgKFZhbG9yIHNpbXBsZXMpXHJcbiAgICAgIC8vIFNlIGNsaWNhciBubyBtZXNtbywgbsOjbyBmYXogbmFkYSAob3UgcG9kZXJpYSBkZXNtYXJjYXIsIGRlcGVuZGUgZGEgcmVncmEpXHJcbiAgICAgIGlmIChjdXJyZW50ICE9PSB2YWx1ZSkge1xyXG4gICAgICAgIHRoaXMudXBkYXRlU2VsZWN0aW9uKHZhbHVlKTtcclxuICAgICAgfVxyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgLy8gVmVyaWZpY2Egc2UgZXN0w6EgYXRpdm8gcGFyYSBhcGxpY2FyIGEgY2xhc3NlIENTU1xyXG4gIGlzQWN0aXZlKG9wdGlvbjogQ2hpcE9wdGlvbik6IGJvb2xlYW4ge1xyXG4gICAgY29uc3QgY3VycmVudCA9IHRoaXMuc2VsZWN0aW9uKCk7XHJcbiAgICBpZiAodGhpcy5tdWx0aXBsZSgpKSB7XHJcbiAgICAgIHJldHVybiBBcnJheS5pc0FycmF5KGN1cnJlbnQpICYmIGN1cnJlbnQuaW5jbHVkZXMob3B0aW9uLnZhbHVlKTtcclxuICAgIH1cclxuICAgIHJldHVybiBjdXJyZW50ID09PSBvcHRpb24udmFsdWU7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIHVwZGF0ZVNlbGVjdGlvbih2YWw6IGFueSkge1xyXG4gICAgdGhpcy5zZWxlY3Rpb24uc2V0KHZhbCk7XHJcbiAgICB0aGlzLnNlbGVjdGlvbkNoYW5nZS5lbWl0KHZhbCk7XHJcbiAgfVxyXG59XHJcbiIsIjxkaXYgY2xhc3M9XCJjaGlwLWNvbnRhaW5lclwiPlxyXG4gIEBmb3IgKG9wdGlvbiBvZiBvcHRpb25zKCk7IHRyYWNrIG9wdGlvbi52YWx1ZSkge1xyXG4gICAgPGJ1dHRvblxyXG4gICAgICB0eXBlPVwiYnV0dG9uXCJcclxuICAgICAgY2xhc3M9XCJjaGlwXCJcclxuICAgICAgW2NsYXNzLnNlbGVjdGVkXT1cImlzQWN0aXZlKG9wdGlvbilcIlxyXG4gICAgICAoY2xpY2spPVwidG9nZ2xlKG9wdGlvbilcIlxyXG4gICAgPlxyXG4gICAgICB7eyBvcHRpb24ubGFiZWwgfX1cclxuICAgIDwvYnV0dG9uPlxyXG4gIH1cclxuPC9kaXY+XHJcbiJdfQ==
@@ -97,4 +97,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
97
97
  type: Component,
98
98
  args: [{ standalone: true, selector: 'kv-kanban', imports: [CommonModule, DragDropModule, MenuModule, TooltipModule], template: "<div class=\"flex w-full h-full\">\r\n <div class=\"board-wrapper flex-column lg:flex-row\" cdkDropListGroup>\r\n \r\n @for(config of columnConfigs(); track $index) {\r\n\r\n <div class=\"board-column\" [style.flex]=\"getColumnFlex()\">\r\n \r\n <div class=\"column-header\" [style.backgroundColor]=\"config.corTitulo\">\r\n <span class=\"text-base font-semibold\">{{ config.nome }}</span>\r\n @if(this.showColumnsCounter()) {\r\n <span class=\"column-count-badge px-2 py-1\" [style.color]=\"config.corTitulo\">{{ config.contador | number:'2.0' }}</span>\r\n }\r\n </div>\r\n\r\n <div \r\n class=\"column-content\"\r\n cdkDropList\r\n [id]=\"config.id.toString()\"\r\n [cdkDropListData]=\"getColumnList()(config.id)\"\r\n (cdkDropListDropped)=\"drop($event)\"\r\n (scroll)=\"onScroll($event, config.id)\">\r\n\r\n\r\n @for(item of getColumnList()(config.id); track $index) {\r\n \r\n <div class=\"kanban-card\" cdkDrag [cdkDragDisabled]=\"!enableDrag()\">\r\n\r\n @if(actions().length > 0) {\r\n <span class=\"material-symbols-outlined card-menu-btn text-xl text-black-alpha-50 hover:surface-200 border-round-lg\" (click)=\"openCardMenu($event, item)\">\r\n more_vert\r\n </span>\r\n }\r\n \r\n\r\n @if (item.status && item.status.length > 0) {\r\n <div class=\"card-header mt-1 mr-3 gap-2 overflow-hidden\" \r\n [pTooltip]=\"getStatusTooltip(item.status)\" \r\n tooltipPosition=\"top\">\r\n @for(statusItem of item.status; track $index) {\r\n <span class=\"status-tag font-semibold text-xs border-round-3xl py-1 px-2\" \r\n [style.backgroundColor]=\"statusItem.statusColor\"\r\n [style.color]=\"statusItem.statusLabelColor\">\r\n {{ statusItem.label }}\r\n </span>\r\n }\r\n </div>\r\n }\r\n\r\n <div class=\"card-body overflow-hidden ml-1\">\r\n <p class=\"p-0 m-0 text-sm text-black-alpha-70 font-semibold mb-2 pr-4 white-space-nowrap\" pTooltip=\"{{item.titulo}}\" tooltipPosition=\"top\">\r\n {{ item.titulo }}\r\n </p>\r\n \r\n <ng-container [ngTemplateOutlet]=\"cardTemplate()\" [ngTemplateOutletContext]=\"{ $implicit: item }\"></ng-container>\r\n </div>\r\n\r\n <div *cdkDragPlaceholder class=\"custom-placeholder\"></div>\r\n </div>\r\n }\r\n\r\n </div>\r\n\r\n <div class=\"column-footer text-xs text-black-alpha-80\">\r\n Ver {{ getColumnList()(config.id).length }} de {{ config.contador }}\r\n </div>\r\n\r\n </div>\r\n\r\n }\r\n\r\n </div>\r\n</div>\r\n\r\n<p-menu #sharedMenu [model]=\"currentMenuOptions\" [popup]=\"true\" appendTo=\"body\"></p-menu>", styles: [".board-wrapper{display:flex;flex:1 1 0%;gap:16px;overflow-x:auto;padding:20px;height:100%;min-height:0}.board-column{display:flex;flex-direction:column;background-color:#f0f2f5;border-radius:18px;min-width:280px;overflow:visible;min-height:400px;max-height:600px}@media (min-width: 1024px){.board-column{height:100%;max-height:100%;min-height:0}}.column-header{padding:10px 20px;margin:7px;border-radius:18px;color:#fff;display:flex;justify-content:space-between;align-items:center;font-weight:600;gap:8px}.column-header span:first-child{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.column-header .column-count-badge{background-color:#ffffffe6;border-radius:12px;font-size:.85rem;font-weight:700;flex-shrink:0}.column-content{flex:1 1 0;overflow-y:auto;overflow-x:visible;padding:12px;min-height:0}.column-content::-webkit-scrollbar{width:6px}.column-content::-webkit-scrollbar-thumb{background:#ccc;border-radius:4px}.kanban-card{background:#fff;border-radius:16px;padding:12px;margin-bottom:8px;box-shadow:0 4px 6px #0000001a;cursor:grab;transition:box-shadow .2s;position:relative}.kanban-card:active{cursor:grabbing}.kanban-card:hover{box-shadow:0 4px 8px #0000001a}.kanban-card.cdk-drag-disabled,.kanban-card.cdk-drag-disabled:active{cursor:default}.card-header{display:flex;margin-bottom:8px;flex-wrap:nowrap}.card-header .status-tag{white-space:nowrap;flex-shrink:0}.card-menu-btn{position:absolute;top:12px;right:8px;cursor:pointer;z-index:10;-webkit-user-select:none;user-select:none}.column-footer{padding:10px;text-align:center}.cdk-drag-preview{box-sizing:border-box;border-radius:8px;box-shadow:0 5px 15px #0003;background:#fff}.cdk-drag-placeholder{opacity:0}.cdk-drag-animating{transition:transform .25s cubic-bezier(0,0,.2,1)}.column-content.cdk-drop-list-dragging .kanban-card:not(.cdk-drag-placeholder){transition:transform .25s cubic-bezier(0,0,.2,1)}::ng-deep .p-menu{scale:.8;z-index:1000!important}\n"] }]
99
99
  }] });
100
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-kanban.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-kanban/kv-kanban.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-kanban/kv-kanban.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, input, OnInit, output, TemplateRef, viewChild } from '@angular/core';\nimport { KanbanColumn, KanbanCard, KanbanAction, KanbanColumnConfig, KanbanColumnList } from './kv-kanban-models.model';\nimport { CdkDragDrop, DragDropModule, moveItemInArray, transferArrayItem } from '@angular/cdk/drag-drop';\nimport { CommonModule } from '@angular/common';\nimport { MenuModule, Menu } from 'primeng/menu';\nimport { MenuItem } from 'primeng/api';\nimport { TooltipModule } from 'primeng/tooltip';\n\n@Component({\n  standalone: true,\n  selector: 'kv-kanban',\n  templateUrl: './kv-kanban.component.html',\n  styleUrls: ['./kv-kanban.component.scss'],\n  imports: [CommonModule, DragDropModule, MenuModule, TooltipModule]\n})\nexport class KvKanbanComponent {\n\n  sharedMenu = viewChild<Menu>('sharedMenu');\n\n  currentMenuOptions: MenuItem[] = [];\n  currentCard: KanbanCard | null = null;\n\n  actions = input<MenuItem[]>([]);\n  columnConfigs = input<KanbanColumnConfig[]>([]);\n  columnLists = input<KanbanColumnList[]>([]);\n  cardTemplate = input<TemplateRef<any> | null>(null);\n  showColumnsCounter = input<boolean>(true);\n  enableDrag = input<boolean>(true);\n  onCardMoved = output<any>();\n  onActionClicked = output<{ action: string, card: KanbanCard }>();\n  onLoadMoreCards = output<{ columnId: number }>();\n  onSelectedCard = output<KanbanCard>();\n\n  getColumnList = computed(() => (columnId: number) => {\n    const list = this.columnLists().find(l => l.idColuna === columnId);\n    return list?.listagem || [] as KanbanCard[];\n  });\n\n  drop(event: CdkDragDrop<KanbanCard[]>) {\n    if (event.previousContainer === event.container) {\n      moveItemInArray(event.container.data, event.previousIndex, event.currentIndex);\n    } else {\n      transferArrayItem(\n        event.previousContainer.data,\n        event.container.data,\n        event.previousIndex,\n        event.currentIndex,\n      );\n    }\n\n    const movedCard = event.container.data[event.currentIndex];\n    \n    this.onCardMoved.emit({\n      item: movedCard,\n      fromColumnId: event.previousContainer.id,\n      toColumnId: event.container.id\n    });\n    \n    this.onSelectedCard.emit(movedCard);\n  }\n\n  onActionClick(actionCode: string, card: KanbanCard) {\n    this.onActionClicked.emit({ action: actionCode, card });\n    \n    this.onSelectedCard.emit(card);\n  }\n\n  openCardMenu(event: MouseEvent, item: any) {\n    event.stopPropagation();\n\n    this.currentCard = item;\n    this.currentMenuOptions = this.getActionsForCard(item);\n\n    this.onSelectedCard.emit(item);\n    \n    this.sharedMenu()?.toggle(event);\n  }\n\n  onScroll(event: Event, columnId: number) {\n    const element = event.target as HTMLElement;\n    const threshold = 50;\n    const atBottom = element.scrollHeight - element.scrollTop - element.clientHeight < threshold;\n    \n    if (atBottom) {\n      this.onLoadMoreCards.emit({ columnId });\n    }\n  }\n\n  getColumnTotalItems(columnId: number): number {\n    const config = this.columnConfigs().find(c => c.id === columnId);\n    return config?.contador || 0;\n  }\n\n  getActionsForCard(card: KanbanCard): MenuItem[] {\n    return this.actions().map(action => ({\n      ...action,\n      command: (event?: any) => {\n        if (action.command) {\n          action.command(event);\n        }\n        \n        if (action.label && this.currentCard) {\n          this.onActionClick(action.label, this.currentCard);\n        }\n      }\n    }));\n  }\n\n  getColumnFlex(): string {\n    const totalColumns = this.columnConfigs().length;\n    if (totalColumns === 0) return '1 1 280px';\n    \n    return `1 1 calc((100% - ${(totalColumns - 1) * 16}px) / ${totalColumns})`;\n  }\n\n  getStatusTooltip(status: any[]): string {\n    if (!status || status.length === 0) return '';\n    return status.map(s => s.label).join(', ');\n  }\n\n}\n","<div class=\"flex w-full h-full\">\r\n  <div class=\"board-wrapper flex-column lg:flex-row\" cdkDropListGroup>\r\n    \r\n    @for(config of columnConfigs(); track $index) {\r\n\r\n      <div class=\"board-column\" [style.flex]=\"getColumnFlex()\">\r\n        \r\n        <div class=\"column-header\" [style.backgroundColor]=\"config.corTitulo\">\r\n          <span class=\"text-base font-semibold\">{{ config.nome }}</span>\r\n          @if(this.showColumnsCounter()) {\r\n            <span class=\"column-count-badge px-2 py-1\" [style.color]=\"config.corTitulo\">{{ config.contador | number:'2.0' }}</span>\r\n          }\r\n        </div>\r\n\r\n        <div \r\n          class=\"column-content\"\r\n          cdkDropList\r\n          [id]=\"config.id.toString()\"\r\n          [cdkDropListData]=\"getColumnList()(config.id)\"\r\n          (cdkDropListDropped)=\"drop($event)\"\r\n          (scroll)=\"onScroll($event, config.id)\">\r\n\r\n\r\n          @for(item of getColumnList()(config.id); track $index) {\r\n            \r\n            <div class=\"kanban-card\" cdkDrag [cdkDragDisabled]=\"!enableDrag()\">\r\n\r\n              @if(actions().length > 0) {\r\n                <span class=\"material-symbols-outlined card-menu-btn text-xl text-black-alpha-50 hover:surface-200 border-round-lg\" (click)=\"openCardMenu($event, item)\">\r\n                  more_vert\r\n                </span>\r\n              }\r\n              \r\n\r\n              @if (item.status && item.status.length > 0) {\r\n                <div class=\"card-header mt-1 mr-3 gap-2 overflow-hidden\" \r\n                     [pTooltip]=\"getStatusTooltip(item.status)\" \r\n                     tooltipPosition=\"top\">\r\n                  @for(statusItem of item.status; track $index) {\r\n                    <span class=\"status-tag font-semibold text-xs border-round-3xl py-1 px-2\" \r\n                          [style.backgroundColor]=\"statusItem.statusColor\"\r\n                          [style.color]=\"statusItem.statusLabelColor\">\r\n                      {{ statusItem.label }}\r\n                    </span>\r\n                  }\r\n                </div>\r\n              }\r\n\r\n              <div class=\"card-body overflow-hidden ml-1\">\r\n                <p class=\"p-0 m-0 text-sm text-black-alpha-70 font-semibold mb-2 pr-4 white-space-nowrap\" pTooltip=\"{{item.titulo}}\" tooltipPosition=\"top\">\r\n                  {{ item.titulo }}\r\n                </p>\r\n                \r\n                <ng-container [ngTemplateOutlet]=\"cardTemplate()\" [ngTemplateOutletContext]=\"{ $implicit: item }\"></ng-container>\r\n              </div>\r\n\r\n              <div *cdkDragPlaceholder class=\"custom-placeholder\"></div>\r\n            </div>\r\n          }\r\n\r\n        </div>\r\n\r\n        <div class=\"column-footer text-xs text-black-alpha-80\">\r\n          Ver {{ getColumnList()(config.id).length }} de {{ config.contador }}\r\n        </div>\r\n\r\n      </div>\r\n\r\n    }\r\n\r\n  </div>\r\n</div>\r\n\r\n<p-menu #sharedMenu [model]=\"currentMenuOptions\" [popup]=\"true\" appendTo=\"body\"></p-menu>"]}
100
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-kanban.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-kanban/kv-kanban.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-kanban/kv-kanban.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, input, OnInit, output, TemplateRef, viewChild } from '@angular/core';\r\nimport { KanbanColumn, KanbanCard, KanbanAction, KanbanColumnConfig, KanbanColumnList } from './kv-kanban-models.model';\r\nimport { CdkDragDrop, DragDropModule, moveItemInArray, transferArrayItem } from '@angular/cdk/drag-drop';\r\nimport { CommonModule } from '@angular/common';\r\nimport { MenuModule, Menu } from 'primeng/menu';\r\nimport { MenuItem } from 'primeng/api';\r\nimport { TooltipModule } from 'primeng/tooltip';\r\n\r\n@Component({\r\n  standalone: true,\r\n  selector: 'kv-kanban',\r\n  templateUrl: './kv-kanban.component.html',\r\n  styleUrls: ['./kv-kanban.component.scss'],\r\n  imports: [CommonModule, DragDropModule, MenuModule, TooltipModule]\r\n})\r\nexport class KvKanbanComponent {\r\n\r\n  sharedMenu = viewChild<Menu>('sharedMenu');\r\n\r\n  currentMenuOptions: MenuItem[] = [];\r\n  currentCard: KanbanCard | null = null;\r\n\r\n  actions = input<MenuItem[]>([]);\r\n  columnConfigs = input<KanbanColumnConfig[]>([]);\r\n  columnLists = input<KanbanColumnList[]>([]);\r\n  cardTemplate = input<TemplateRef<any> | null>(null);\r\n  showColumnsCounter = input<boolean>(true);\r\n  enableDrag = input<boolean>(true);\r\n  onCardMoved = output<any>();\r\n  onActionClicked = output<{ action: string, card: KanbanCard }>();\r\n  onLoadMoreCards = output<{ columnId: number }>();\r\n  onSelectedCard = output<KanbanCard>();\r\n\r\n  getColumnList = computed(() => (columnId: number) => {\r\n    const list = this.columnLists().find(l => l.idColuna === columnId);\r\n    return list?.listagem || [] as KanbanCard[];\r\n  });\r\n\r\n  drop(event: CdkDragDrop<KanbanCard[]>) {\r\n    if (event.previousContainer === event.container) {\r\n      moveItemInArray(event.container.data, event.previousIndex, event.currentIndex);\r\n    } else {\r\n      transferArrayItem(\r\n        event.previousContainer.data,\r\n        event.container.data,\r\n        event.previousIndex,\r\n        event.currentIndex,\r\n      );\r\n    }\r\n\r\n    const movedCard = event.container.data[event.currentIndex];\r\n    \r\n    this.onCardMoved.emit({\r\n      item: movedCard,\r\n      fromColumnId: event.previousContainer.id,\r\n      toColumnId: event.container.id\r\n    });\r\n    \r\n    this.onSelectedCard.emit(movedCard);\r\n  }\r\n\r\n  onActionClick(actionCode: string, card: KanbanCard) {\r\n    this.onActionClicked.emit({ action: actionCode, card });\r\n    \r\n    this.onSelectedCard.emit(card);\r\n  }\r\n\r\n  openCardMenu(event: MouseEvent, item: any) {\r\n    event.stopPropagation();\r\n\r\n    this.currentCard = item;\r\n    this.currentMenuOptions = this.getActionsForCard(item);\r\n\r\n    this.onSelectedCard.emit(item);\r\n    \r\n    this.sharedMenu()?.toggle(event);\r\n  }\r\n\r\n  onScroll(event: Event, columnId: number) {\r\n    const element = event.target as HTMLElement;\r\n    const threshold = 50;\r\n    const atBottom = element.scrollHeight - element.scrollTop - element.clientHeight < threshold;\r\n    \r\n    if (atBottom) {\r\n      this.onLoadMoreCards.emit({ columnId });\r\n    }\r\n  }\r\n\r\n  getColumnTotalItems(columnId: number): number {\r\n    const config = this.columnConfigs().find(c => c.id === columnId);\r\n    return config?.contador || 0;\r\n  }\r\n\r\n  getActionsForCard(card: KanbanCard): MenuItem[] {\r\n    return this.actions().map(action => ({\r\n      ...action,\r\n      command: (event?: any) => {\r\n        if (action.command) {\r\n          action.command(event);\r\n        }\r\n        \r\n        if (action.label && this.currentCard) {\r\n          this.onActionClick(action.label, this.currentCard);\r\n        }\r\n      }\r\n    }));\r\n  }\r\n\r\n  getColumnFlex(): string {\r\n    const totalColumns = this.columnConfigs().length;\r\n    if (totalColumns === 0) return '1 1 280px';\r\n    \r\n    return `1 1 calc((100% - ${(totalColumns - 1) * 16}px) / ${totalColumns})`;\r\n  }\r\n\r\n  getStatusTooltip(status: any[]): string {\r\n    if (!status || status.length === 0) return '';\r\n    return status.map(s => s.label).join(', ');\r\n  }\r\n\r\n}\r\n","<div class=\"flex w-full h-full\">\r\n  <div class=\"board-wrapper flex-column lg:flex-row\" cdkDropListGroup>\r\n    \r\n    @for(config of columnConfigs(); track $index) {\r\n\r\n      <div class=\"board-column\" [style.flex]=\"getColumnFlex()\">\r\n        \r\n        <div class=\"column-header\" [style.backgroundColor]=\"config.corTitulo\">\r\n          <span class=\"text-base font-semibold\">{{ config.nome }}</span>\r\n          @if(this.showColumnsCounter()) {\r\n            <span class=\"column-count-badge px-2 py-1\" [style.color]=\"config.corTitulo\">{{ config.contador | number:'2.0' }}</span>\r\n          }\r\n        </div>\r\n\r\n        <div \r\n          class=\"column-content\"\r\n          cdkDropList\r\n          [id]=\"config.id.toString()\"\r\n          [cdkDropListData]=\"getColumnList()(config.id)\"\r\n          (cdkDropListDropped)=\"drop($event)\"\r\n          (scroll)=\"onScroll($event, config.id)\">\r\n\r\n\r\n          @for(item of getColumnList()(config.id); track $index) {\r\n            \r\n            <div class=\"kanban-card\" cdkDrag [cdkDragDisabled]=\"!enableDrag()\">\r\n\r\n              @if(actions().length > 0) {\r\n                <span class=\"material-symbols-outlined card-menu-btn text-xl text-black-alpha-50 hover:surface-200 border-round-lg\" (click)=\"openCardMenu($event, item)\">\r\n                  more_vert\r\n                </span>\r\n              }\r\n              \r\n\r\n              @if (item.status && item.status.length > 0) {\r\n                <div class=\"card-header mt-1 mr-3 gap-2 overflow-hidden\" \r\n                     [pTooltip]=\"getStatusTooltip(item.status)\" \r\n                     tooltipPosition=\"top\">\r\n                  @for(statusItem of item.status; track $index) {\r\n                    <span class=\"status-tag font-semibold text-xs border-round-3xl py-1 px-2\" \r\n                          [style.backgroundColor]=\"statusItem.statusColor\"\r\n                          [style.color]=\"statusItem.statusLabelColor\">\r\n                      {{ statusItem.label }}\r\n                    </span>\r\n                  }\r\n                </div>\r\n              }\r\n\r\n              <div class=\"card-body overflow-hidden ml-1\">\r\n                <p class=\"p-0 m-0 text-sm text-black-alpha-70 font-semibold mb-2 pr-4 white-space-nowrap\" pTooltip=\"{{item.titulo}}\" tooltipPosition=\"top\">\r\n                  {{ item.titulo }}\r\n                </p>\r\n                \r\n                <ng-container [ngTemplateOutlet]=\"cardTemplate()\" [ngTemplateOutletContext]=\"{ $implicit: item }\"></ng-container>\r\n              </div>\r\n\r\n              <div *cdkDragPlaceholder class=\"custom-placeholder\"></div>\r\n            </div>\r\n          }\r\n\r\n        </div>\r\n\r\n        <div class=\"column-footer text-xs text-black-alpha-80\">\r\n          Ver {{ getColumnList()(config.id).length }} de {{ config.contador }}\r\n        </div>\r\n\r\n      </div>\r\n\r\n    }\r\n\r\n  </div>\r\n</div>\r\n\r\n<p-menu #sharedMenu [model]=\"currentMenuOptions\" [popup]=\"true\" appendTo=\"body\"></p-menu>"]}
@@ -11,10 +11,10 @@ export class KvSelectCardsComponent {
11
11
  this.selection.set(option.value);
12
12
  }
13
13
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvSelectCardsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
14
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: KvSelectCardsComponent, isStandalone: true, selector: "kv-select-cards", inputs: { options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: true, transformFunction: null }, selection: { classPropertyName: "selection", publicName: "selection", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { selection: "selectionChange" }, ngImport: i0, template: "<div class=\"cards-container\">\r\n @for (option of options(); track option.value) {\r\n <div\r\n class=\"card-option\"\r\n [class.selected]=\"selection() === option.value\"\r\n (click)=\"select(option)\"\r\n >\r\n <div class=\"icon-box\">\r\n <span class=\"material-symbols-outlined\">{{ option.icon }}</span>\r\n </div>\r\n\r\n <div class=\"content\">\r\n <div class=\"title\">{{ option.title }}</div>\r\n <div class=\"description\">{{ option.description }}</div>\r\n </div>\r\n\r\n <div class=\"radio-indicator\">\r\n <div class=\"dot\"></div>\r\n </div>\r\n </div>\r\n }\r\n</div>\r\n", styles: [".cards-container{display:flex;flex-direction:column;gap:1rem;width:100%}.card-option{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;cursor:pointer;transition:all .2s ease-in-out;-webkit-user-select:none;user-select:none}.card-option:hover{border-color:#b0c0d6;background:#f8fafc}.card-option.selected{background:#f0f9ff;border-color:#0ea5e9;box-shadow:0 4px 6px -1px #0ea5e91a}.card-option.selected .icon-box{background:#0ea5e91a;color:#0ea5e9}.card-option.selected .title{color:#0284c7}.card-option.selected .radio-indicator{border-color:#0ea5e9;background:#fff}.card-option.selected .radio-indicator .dot{transform:scale(1);background:#0ea5e9}.icon-box{display:flex;align-items:center;justify-content:center;width:3rem;height:3rem;border-radius:.5rem;background:#f1f5f9;color:#64748b;flex-shrink:0;transition:all .2s}.icon-box span{font-size:1.5rem}.content{flex:1;display:flex;flex-direction:column;gap:.25rem}.title{font-size:.95rem;font-weight:700;color:#0f172a;transition:color .2s}.description{font-size:.8rem;color:#64748b;line-height:1.4}.radio-indicator{width:1.25rem;height:1.25rem;border-radius:50%;border:2px solid #e2e8f0;display:flex;align-items:center;justify-content:center;transition:all .2s;background:#fff}.radio-indicator .dot{width:.625rem;height:.625rem;border-radius:50%;background:transparent;transform:scale(0);transition:transform .2s cubic-bezier(.4,0,.2,1)}\n"] }); }
14
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: KvSelectCardsComponent, isStandalone: true, selector: "kv-select-cards", inputs: { options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: true, transformFunction: null }, selection: { classPropertyName: "selection", publicName: "selection", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { selection: "selectionChange" }, ngImport: i0, template: "<div class=\"cards-container\">\r\n @for (option of options(); track option.value) {\r\n <div\r\n class=\"card-option\"\r\n [class.selected]=\"selection() === option.value\"\r\n (click)=\"select(option)\"\r\n >\r\n <div class=\"icon-box\">\r\n <span class=\"material-symbols-outlined\">{{ option.icon }}</span>\r\n </div>\r\n\r\n <div class=\"content\">\r\n <div class=\"title\">{{ option.title }}</div>\r\n <div class=\"description\">{{ option.description }}</div>\r\n </div>\r\n\r\n <div class=\"radio-indicator\">\r\n <div class=\"dot\"></div>\r\n </div>\r\n </div>\r\n }\r\n</div>\r\n", styles: [".cards-container{display:flex;flex-direction:column;gap:1rem;width:100%}.card-option{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;cursor:pointer;transition:all .2s ease-in-out;-webkit-user-select:none;user-select:none}.card-option:hover{border-color:#b0c0d6;background:#f8fafc}.card-option.selected{background:#eff4ff;border-color:#3b82f6;box-shadow:0 4px 6px -1px #0ea5e91a}.card-option.selected .icon-box{background:#3b82f61a;color:#3b82f6}.card-option.selected .title{color:#3b82f6}.card-option.selected .radio-indicator{border-color:#3b82f6;background:#fff}.card-option.selected .radio-indicator .dot{transform:scale(1);background:#3b82f6}.icon-box{display:flex;align-items:center;justify-content:center;width:3rem;height:3rem;border-radius:.5rem;background:#f1f5f9;color:#64748b;flex-shrink:0;transition:all .2s}.icon-box span{font-size:1.5rem}.content{flex:1;display:flex;flex-direction:column;gap:.25rem}.title{font-size:.95rem;font-weight:700;color:#0f172a;transition:color .2s}.description{font-size:.8rem;color:#64748b;line-height:1.4}.radio-indicator{width:1.25rem;height:1.25rem;border-radius:50%;border:2px solid #e2e8f0;display:flex;align-items:center;justify-content:center;transition:all .2s;background:#fff}.radio-indicator .dot{width:.625rem;height:.625rem;border-radius:50%;background:transparent;transform:scale(0);transition:transform .2s cubic-bezier(.4,0,.2,1)}\n"] }); }
15
15
  }
16
16
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvSelectCardsComponent, decorators: [{
17
17
  type: Component,
18
- args: [{ selector: 'kv-select-cards', standalone: true, imports: [], template: "<div class=\"cards-container\">\r\n @for (option of options(); track option.value) {\r\n <div\r\n class=\"card-option\"\r\n [class.selected]=\"selection() === option.value\"\r\n (click)=\"select(option)\"\r\n >\r\n <div class=\"icon-box\">\r\n <span class=\"material-symbols-outlined\">{{ option.icon }}</span>\r\n </div>\r\n\r\n <div class=\"content\">\r\n <div class=\"title\">{{ option.title }}</div>\r\n <div class=\"description\">{{ option.description }}</div>\r\n </div>\r\n\r\n <div class=\"radio-indicator\">\r\n <div class=\"dot\"></div>\r\n </div>\r\n </div>\r\n }\r\n</div>\r\n", styles: [".cards-container{display:flex;flex-direction:column;gap:1rem;width:100%}.card-option{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;cursor:pointer;transition:all .2s ease-in-out;-webkit-user-select:none;user-select:none}.card-option:hover{border-color:#b0c0d6;background:#f8fafc}.card-option.selected{background:#f0f9ff;border-color:#0ea5e9;box-shadow:0 4px 6px -1px #0ea5e91a}.card-option.selected .icon-box{background:#0ea5e91a;color:#0ea5e9}.card-option.selected .title{color:#0284c7}.card-option.selected .radio-indicator{border-color:#0ea5e9;background:#fff}.card-option.selected .radio-indicator .dot{transform:scale(1);background:#0ea5e9}.icon-box{display:flex;align-items:center;justify-content:center;width:3rem;height:3rem;border-radius:.5rem;background:#f1f5f9;color:#64748b;flex-shrink:0;transition:all .2s}.icon-box span{font-size:1.5rem}.content{flex:1;display:flex;flex-direction:column;gap:.25rem}.title{font-size:.95rem;font-weight:700;color:#0f172a;transition:color .2s}.description{font-size:.8rem;color:#64748b;line-height:1.4}.radio-indicator{width:1.25rem;height:1.25rem;border-radius:50%;border:2px solid #e2e8f0;display:flex;align-items:center;justify-content:center;transition:all .2s;background:#fff}.radio-indicator .dot{width:.625rem;height:.625rem;border-radius:50%;background:transparent;transform:scale(0);transition:transform .2s cubic-bezier(.4,0,.2,1)}\n"] }]
18
+ args: [{ selector: 'kv-select-cards', standalone: true, imports: [], template: "<div class=\"cards-container\">\r\n @for (option of options(); track option.value) {\r\n <div\r\n class=\"card-option\"\r\n [class.selected]=\"selection() === option.value\"\r\n (click)=\"select(option)\"\r\n >\r\n <div class=\"icon-box\">\r\n <span class=\"material-symbols-outlined\">{{ option.icon }}</span>\r\n </div>\r\n\r\n <div class=\"content\">\r\n <div class=\"title\">{{ option.title }}</div>\r\n <div class=\"description\">{{ option.description }}</div>\r\n </div>\r\n\r\n <div class=\"radio-indicator\">\r\n <div class=\"dot\"></div>\r\n </div>\r\n </div>\r\n }\r\n</div>\r\n", styles: [".cards-container{display:flex;flex-direction:column;gap:1rem;width:100%}.card-option{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;cursor:pointer;transition:all .2s ease-in-out;-webkit-user-select:none;user-select:none}.card-option:hover{border-color:#b0c0d6;background:#f8fafc}.card-option.selected{background:#eff4ff;border-color:#3b82f6;box-shadow:0 4px 6px -1px #0ea5e91a}.card-option.selected .icon-box{background:#3b82f61a;color:#3b82f6}.card-option.selected .title{color:#3b82f6}.card-option.selected .radio-indicator{border-color:#3b82f6;background:#fff}.card-option.selected .radio-indicator .dot{transform:scale(1);background:#3b82f6}.icon-box{display:flex;align-items:center;justify-content:center;width:3rem;height:3rem;border-radius:.5rem;background:#f1f5f9;color:#64748b;flex-shrink:0;transition:all .2s}.icon-box span{font-size:1.5rem}.content{flex:1;display:flex;flex-direction:column;gap:.25rem}.title{font-size:.95rem;font-weight:700;color:#0f172a;transition:color .2s}.description{font-size:.8rem;color:#64748b;line-height:1.4}.radio-indicator{width:1.25rem;height:1.25rem;border-radius:50%;border:2px solid #e2e8f0;display:flex;align-items:center;justify-content:center;transition:all .2s;background:#fff}.radio-indicator .dot{width:.625rem;height:.625rem;border-radius:50%;background:transparent;transform:scale(0);transition:transform .2s cubic-bezier(.4,0,.2,1)}\n"] }]
19
19
  }] });
20
20
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia3Ytc2VsZWN0LWNhcmRzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tlZXZvLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2t2LXNlbGVjdC1jYXJkcy9rdi1zZWxlY3QtY2FyZHMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2Vldm8tY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMva3Ytc2VsZWN0LWNhcmRzL2t2LXNlbGVjdC1jYXJkcy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBZ0J4RCxNQUFNLE9BQU8sc0JBQXNCO0lBUG5DO1FBU0UsbUJBQW1CO1FBQ25CLFlBQU8sR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFzQixDQUFDO1FBRS9DLDJDQUEyQztRQUMzQyxjQUFTLEdBQUcsS0FBSyxDQUFNLElBQUksQ0FBQyxDQUFDO0tBSzlCO0lBSEMsTUFBTSxDQUFDLE1BQXdCO1FBQzdCLElBQUksQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNuQyxDQUFDOzhHQVZVLHNCQUFzQjtrR0FBdEIsc0JBQXNCLG1ZQ2hCbkMsa3FCQXNCQTs7MkZETmEsc0JBQXNCO2tCQVBsQyxTQUFTOytCQUNFLGlCQUFpQixjQUNmLElBQUksV0FDUCxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBpbnB1dCwgbW9kZWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbmV4cG9ydCBpbnRlcmZhY2UgU2VsZWN0Q2FyZE9wdGlvbiB7XHJcbiAgdGl0bGU6IHN0cmluZztcclxuICBkZXNjcmlwdGlvbjogc3RyaW5nO1xyXG4gIHZhbHVlOiBhbnk7XHJcbiAgaWNvbjogc3RyaW5nOyAvLyBOb21lIGRvIE1hdGVyaWFsIFN5bWJvbFxyXG59XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2t2LXNlbGVjdC1jYXJkcycsXHJcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcclxuICBpbXBvcnRzOiBbXSxcclxuICB0ZW1wbGF0ZVVybDogJy4va3Ytc2VsZWN0LWNhcmRzLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybDogJy4va3Ytc2VsZWN0LWNhcmRzLmNvbXBvbmVudC5zY3NzJ1xyXG59KVxyXG5leHBvcnQgY2xhc3MgS3ZTZWxlY3RDYXJkc0NvbXBvbmVudCB7XHJcblxyXG4gIC8vIFJlY2ViZSBhcyBvcMOnw7Vlc1xyXG4gIG9wdGlvbnMgPSBpbnB1dC5yZXF1aXJlZDxTZWxlY3RDYXJkT3B0aW9uW10+KCk7XHJcblxyXG4gIC8vIFR3by13YXkgYmluZGluZyBwYXJhIG8gdmFsb3Igc2VsZWNpb25hZG9cclxuICBzZWxlY3Rpb24gPSBtb2RlbDxhbnk+KG51bGwpO1xyXG5cclxuICBzZWxlY3Qob3B0aW9uOiBTZWxlY3RDYXJkT3B0aW9uKSB7XHJcbiAgICB0aGlzLnNlbGVjdGlvbi5zZXQob3B0aW9uLnZhbHVlKTtcclxuICB9XHJcbn1cclxuIiwiPGRpdiBjbGFzcz1cImNhcmRzLWNvbnRhaW5lclwiPlxyXG4gIEBmb3IgKG9wdGlvbiBvZiBvcHRpb25zKCk7IHRyYWNrIG9wdGlvbi52YWx1ZSkge1xyXG4gICAgPGRpdlxyXG4gICAgICBjbGFzcz1cImNhcmQtb3B0aW9uXCJcclxuICAgICAgW2NsYXNzLnNlbGVjdGVkXT1cInNlbGVjdGlvbigpID09PSBvcHRpb24udmFsdWVcIlxyXG4gICAgICAoY2xpY2spPVwic2VsZWN0KG9wdGlvbilcIlxyXG4gICAgPlxyXG4gICAgICA8ZGl2IGNsYXNzPVwiaWNvbi1ib3hcIj5cclxuICAgICAgICA8c3BhbiBjbGFzcz1cIm1hdGVyaWFsLXN5bWJvbHMtb3V0bGluZWRcIj57eyBvcHRpb24uaWNvbiB9fTwvc3Bhbj5cclxuICAgICAgPC9kaXY+XHJcblxyXG4gICAgICA8ZGl2IGNsYXNzPVwiY29udGVudFwiPlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJ0aXRsZVwiPnt7IG9wdGlvbi50aXRsZSB9fTwvZGl2PlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJkZXNjcmlwdGlvblwiPnt7IG9wdGlvbi5kZXNjcmlwdGlvbiB9fTwvZGl2PlxyXG4gICAgICA8L2Rpdj5cclxuXHJcbiAgICAgIDxkaXYgY2xhc3M9XCJyYWRpby1pbmRpY2F0b3JcIj5cclxuICAgICAgICA8ZGl2IGNsYXNzPVwiZG90XCI+PC9kaXY+XHJcbiAgICAgIDwvZGl2PlxyXG4gICAgPC9kaXY+XHJcbiAgfVxyXG48L2Rpdj5cclxuIl19