tudu-components 0.2.11 → 0.2.12

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,123 @@
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "@angular/common";
4
+ export class CustomModalComponent {
5
+ constructor() {
6
+ this.modalId = 'customModal';
7
+ this.title = 'Aviso';
8
+ this.message = '';
9
+ this.closeButtonText = 'Fechar';
10
+ this.actionButtonText = '';
11
+ this.paymentMethod = null;
12
+ this.errorDetails = null;
13
+ this.modalClosed = new EventEmitter();
14
+ this.modalAction = new EventEmitter();
15
+ this.showModal = false;
16
+ this.messageTitle = 'Pagamento Aprovado!';
17
+ this.showBtn = true;
18
+ this.priceNegotiated = 0;
19
+ this.messageBody = 'Seu pagamento foi processado com sucesso.';
20
+ // Configuração dinâmica
21
+ this.modalIcon = 'fa-check';
22
+ this.modalIconColor = 'text-green-600';
23
+ this.modalBgColor = 'bg-green-100';
24
+ }
25
+ ngOnInit() { }
26
+ openModal() {
27
+ this.showModal = true;
28
+ }
29
+ configureModal(type, message = '') {
30
+ switch (type) {
31
+ case 'success':
32
+ this.setSuccessStyles(message);
33
+ break;
34
+ case 'error':
35
+ this.setErrorStyles(message);
36
+ break;
37
+ case 'warning':
38
+ this.setWarningStyles(message);
39
+ break;
40
+ }
41
+ }
42
+ setSuccessStyles(message) {
43
+ this.modalIcon = 'fa-check-circle';
44
+ this.modalIconColor = 'modal-icon-success'; // Nome da classe no CSS
45
+ this.modalBgColor = 'modal-bg-success'; // Nome da classe no CSS
46
+ this.messageTitle = 'Sucesso!';
47
+ this.messageBody = message || 'Operação realizada com sucesso.';
48
+ }
49
+ setErrorStyles(message) {
50
+ this.modalIcon = 'fa-times-circle';
51
+ this.modalIconColor = 'modal-icon-error';
52
+ this.modalBgColor = 'modal-bg-error';
53
+ this.messageTitle = 'Ops! Algo deu errado';
54
+ this.messageBody = message || 'Não conseguimos processar sua solicitação.';
55
+ }
56
+ setWarningStyles(message) {
57
+ this.modalIcon = 'fa-exclamation-circle';
58
+ this.modalIconColor = 'modal-icon-warning';
59
+ this.modalBgColor = 'modal-bg-warning';
60
+ this.messageTitle = 'Atenção';
61
+ this.messageBody = message || 'Verifique os dados antes de continuar.';
62
+ }
63
+ actionModal() {
64
+ if (this.isLoadingBtn !== undefined) {
65
+ this.isLoadingBtn = true;
66
+ this.modalAction.emit();
67
+ }
68
+ else {
69
+ this.modalAction.emit();
70
+ this.isLoadingBtn = false;
71
+ this.showModal = false;
72
+ }
73
+ }
74
+ closeModal() {
75
+ this.showModal = false;
76
+ this.modalClosed.emit();
77
+ }
78
+ // Controle externo
79
+ open(type, message = '', paymentMethod) {
80
+ this.configureModal(type, message);
81
+ if (paymentMethod) {
82
+ this.paymentMethod = paymentMethod;
83
+ }
84
+ this.showModal = true;
85
+ }
86
+ }
87
+ CustomModalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CustomModalComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
88
+ CustomModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: CustomModalComponent, selector: "lib-custom-modal", inputs: { modalId: "modalId", title: "title", message: "message", closeButtonText: "closeButtonText", actionButtonText: "actionButtonText", paymentMethod: "paymentMethod", errorDetails: "errorDetails", showModal: "showModal", messageTitle: "messageTitle", showBtn: "showBtn", priceNegotiated: "priceNegotiated", messageBody: "messageBody", isLoadingBtn: "isLoadingBtn" }, outputs: { modalClosed: "modalClosed", modalAction: "modalAction" }, ngImport: i0, template: "<div\n *ngIf=\"showModal\"\n class=\"modal-overlay-fixed transition-all\"\n (click)=\"closeModal()\"\n>\n <div\n class=\"bg-white w-full max-w-2xl rounded-t-[2.5rem] p-6 shadow-2xl animate-slide-up border-t border-gray-100 flex flex-col\"\n (click)=\"$event.stopPropagation()\"\n >\n <div class=\"w-12 h-1.5 bg-gray-200 rounded-full mx-auto mb-6\"></div>\n\n <div class=\"flex flex-col items-center text-center\">\n <div class=\"relative mb-4\">\n <div\n [class]=\"modalBgColor\"\n class=\"w-20 h-20 rounded-full opacity-40\"\n ></div>\n <div class=\"absolute inset-0 flex items-center justify-center\">\n <i\n [class]=\"modalIcon + ' ' + modalIconColor\"\n class=\"fas text-3xl\"\n ></i>\n </div>\n </div>\n\n <h2 class=\"text-2xl font-bold text-gray-900 mb-2\">{{ messageTitle }}</h2>\n\n <div class=\"w-full modal-scroll-area px-2 custom-scrollbar\">\n <p *ngIf=\"messageBody\" class=\"text-gray-600 mb-4\">{{ messageBody }}</p>\n\n <div class=\"modal-dynamic-content text-left\">\n <ng-content select=\"[optional-content]\"></ng-content>\n </div>\n\n <div\n *ngIf=\"errorDetails\"\n class=\"mt-4 p-4 bg-red-50 rounded-2xl text-left border border-red-100\"\n >\n <p class=\"text-[10px] font-bold text-red-700 uppercase mb-1\">\n Log do sistema:\n </p>\n <pre class=\"text-[11px] text-red-600 font-mono whitespace-pre-wrap\">{{\n errorDetails | json\n }}</pre>\n </div>\n </div>\n\n <div class=\"mt-6 flex flex-col w-full gap-3 pb-4\">\n <button\n [disabled]=\"priceNegotiated <= 0 && actionButtonText === 'Negociar'\"\n *ngIf=\"actionButtonText\"\n (click)=\"actionModal()\"\n class=\"w-full py-4 text-white rounded-2xl font-bold active:scale-[0.98] transition-all flex items-center justify-center gap-3 shadow-lg btn-primary-custom\"\n [style.background-color]=\"'var(--primary)'\"\n >\n <span *ngIf=\"!isLoadingBtn\">{{ actionButtonText }}</span>\n <ng-container *ngIf=\"isLoadingBtn\">\n <span>Processando</span>\n <i class=\"fas fa-circle-notch fa-spin\"></i>\n </ng-container>\n </button>\n\n <button\n *ngIf=\"showBtn\"\n (click)=\"closeModal()\"\n class=\"w-full py-2 text-gray-500 font-semibold hover:text-gray-800 transition-colors\"\n >\n {{ closeButtonText }}\n </button>\n </div>\n </div>\n </div>\n</div>\n", styles: ["@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.animate-slide-up{animation:slideUp .4s cubic-bezier(.25,1,.5,1) forwards}.btn-primary-custom:hover:not(:disabled){filter:brightness(.9);transition:filter .2s ease}.btn-primary-custom:disabled{opacity:.6;cursor:not-allowed}.custom-scrollbar::-webkit-scrollbar{width:4px}.custom-scrollbar::-webkit-scrollbar-thumb{background:#f1f1f1;border-radius:10px}.custom-scrollbar::-webkit-scrollbar-track{background:transparent}@media (min-width: 768px){.animate-slide-up{margin-bottom:2rem;border-radius:2.5rem;width:90%}}.modal-scroll-area{max-height:60vh;overflow-y:auto;overflow-x:hidden;transition:max-height .4s cubic-bezier(.25,1,.5,1)}.modal-scroll-area:has(.animate-fade-in),.modal-scroll-area:focus-within{max-height:85vh}.modal-dynamic-content{height:auto;overflow:visible!important;display:block}.modal-overlay{position:fixed;inset:0;background-color:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:99999;transition:opacity .3s ease}:host-context(body:has(.modal-overlay)){overflow:hidden}.modal-overlay-fixed{position:fixed;inset:0;background-color:#0009!important;backdrop-filter:blur(8px)!important;-webkit-backdrop-filter:blur(8px)!important;display:flex;align-items:flex-end;justify-content:center;z-index:9999}.modal-bg-success{background-color:#d1fae5!important}.modal-icon-success{color:#10b981!important}.modal-bg-error{background-color:#fee2e2!important}.modal-icon-error{color:#ef4444!important}.modal-bg-warning{background-color:#fef3c7!important}.modal-icon-warning{color:#f59e0b!important}.modal-overlay-fixed{position:fixed;inset:0;background-color:#0009;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:flex-end;justify-content:center;z-index:9999}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i1.JsonPipe, name: "json" }] });
89
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CustomModalComponent, decorators: [{
90
+ type: Component,
91
+ args: [{ selector: 'lib-custom-modal', standalone: false, template: "<div\n *ngIf=\"showModal\"\n class=\"modal-overlay-fixed transition-all\"\n (click)=\"closeModal()\"\n>\n <div\n class=\"bg-white w-full max-w-2xl rounded-t-[2.5rem] p-6 shadow-2xl animate-slide-up border-t border-gray-100 flex flex-col\"\n (click)=\"$event.stopPropagation()\"\n >\n <div class=\"w-12 h-1.5 bg-gray-200 rounded-full mx-auto mb-6\"></div>\n\n <div class=\"flex flex-col items-center text-center\">\n <div class=\"relative mb-4\">\n <div\n [class]=\"modalBgColor\"\n class=\"w-20 h-20 rounded-full opacity-40\"\n ></div>\n <div class=\"absolute inset-0 flex items-center justify-center\">\n <i\n [class]=\"modalIcon + ' ' + modalIconColor\"\n class=\"fas text-3xl\"\n ></i>\n </div>\n </div>\n\n <h2 class=\"text-2xl font-bold text-gray-900 mb-2\">{{ messageTitle }}</h2>\n\n <div class=\"w-full modal-scroll-area px-2 custom-scrollbar\">\n <p *ngIf=\"messageBody\" class=\"text-gray-600 mb-4\">{{ messageBody }}</p>\n\n <div class=\"modal-dynamic-content text-left\">\n <ng-content select=\"[optional-content]\"></ng-content>\n </div>\n\n <div\n *ngIf=\"errorDetails\"\n class=\"mt-4 p-4 bg-red-50 rounded-2xl text-left border border-red-100\"\n >\n <p class=\"text-[10px] font-bold text-red-700 uppercase mb-1\">\n Log do sistema:\n </p>\n <pre class=\"text-[11px] text-red-600 font-mono whitespace-pre-wrap\">{{\n errorDetails | json\n }}</pre>\n </div>\n </div>\n\n <div class=\"mt-6 flex flex-col w-full gap-3 pb-4\">\n <button\n [disabled]=\"priceNegotiated <= 0 && actionButtonText === 'Negociar'\"\n *ngIf=\"actionButtonText\"\n (click)=\"actionModal()\"\n class=\"w-full py-4 text-white rounded-2xl font-bold active:scale-[0.98] transition-all flex items-center justify-center gap-3 shadow-lg btn-primary-custom\"\n [style.background-color]=\"'var(--primary)'\"\n >\n <span *ngIf=\"!isLoadingBtn\">{{ actionButtonText }}</span>\n <ng-container *ngIf=\"isLoadingBtn\">\n <span>Processando</span>\n <i class=\"fas fa-circle-notch fa-spin\"></i>\n </ng-container>\n </button>\n\n <button\n *ngIf=\"showBtn\"\n (click)=\"closeModal()\"\n class=\"w-full py-2 text-gray-500 font-semibold hover:text-gray-800 transition-colors\"\n >\n {{ closeButtonText }}\n </button>\n </div>\n </div>\n </div>\n</div>\n", styles: ["@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.animate-slide-up{animation:slideUp .4s cubic-bezier(.25,1,.5,1) forwards}.btn-primary-custom:hover:not(:disabled){filter:brightness(.9);transition:filter .2s ease}.btn-primary-custom:disabled{opacity:.6;cursor:not-allowed}.custom-scrollbar::-webkit-scrollbar{width:4px}.custom-scrollbar::-webkit-scrollbar-thumb{background:#f1f1f1;border-radius:10px}.custom-scrollbar::-webkit-scrollbar-track{background:transparent}@media (min-width: 768px){.animate-slide-up{margin-bottom:2rem;border-radius:2.5rem;width:90%}}.modal-scroll-area{max-height:60vh;overflow-y:auto;overflow-x:hidden;transition:max-height .4s cubic-bezier(.25,1,.5,1)}.modal-scroll-area:has(.animate-fade-in),.modal-scroll-area:focus-within{max-height:85vh}.modal-dynamic-content{height:auto;overflow:visible!important;display:block}.modal-overlay{position:fixed;inset:0;background-color:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:99999;transition:opacity .3s ease}:host-context(body:has(.modal-overlay)){overflow:hidden}.modal-overlay-fixed{position:fixed;inset:0;background-color:#0009!important;backdrop-filter:blur(8px)!important;-webkit-backdrop-filter:blur(8px)!important;display:flex;align-items:flex-end;justify-content:center;z-index:9999}.modal-bg-success{background-color:#d1fae5!important}.modal-icon-success{color:#10b981!important}.modal-bg-error{background-color:#fee2e2!important}.modal-icon-error{color:#ef4444!important}.modal-bg-warning{background-color:#fef3c7!important}.modal-icon-warning{color:#f59e0b!important}.modal-overlay-fixed{position:fixed;inset:0;background-color:#0009;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:flex-end;justify-content:center;z-index:9999}\n"] }]
92
+ }], propDecorators: { modalId: [{
93
+ type: Input
94
+ }], title: [{
95
+ type: Input
96
+ }], message: [{
97
+ type: Input
98
+ }], closeButtonText: [{
99
+ type: Input
100
+ }], actionButtonText: [{
101
+ type: Input
102
+ }], paymentMethod: [{
103
+ type: Input
104
+ }], errorDetails: [{
105
+ type: Input
106
+ }], modalClosed: [{
107
+ type: Output
108
+ }], modalAction: [{
109
+ type: Output
110
+ }], showModal: [{
111
+ type: Input
112
+ }], messageTitle: [{
113
+ type: Input
114
+ }], showBtn: [{
115
+ type: Input
116
+ }], priceNegotiated: [{
117
+ type: Input
118
+ }], messageBody: [{
119
+ type: Input
120
+ }], isLoadingBtn: [{
121
+ type: Input
122
+ }] } });
123
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-modal.component.js","sourceRoot":"","sources":["../../../../../../projects/tudu-components/src/lib/components/custom-modal/custom-modal.component.ts","../../../../../../projects/tudu-components/src/lib/components/custom-modal/custom-modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\n\ntype ModalType = 'success' | 'error' | 'warning';\n\n@Component({\n  selector: 'lib-custom-modal',\n  standalone: false,\n  templateUrl: './custom-modal.component.html',\n  styleUrls: ['./custom-modal.component.css'],\n})\nexport class CustomModalComponent implements OnInit {\n  @Input() modalId = 'customModal';\n  @Input() title = 'Aviso';\n  @Input() message = '';\n  @Input() closeButtonText = 'Fechar';\n  @Input() actionButtonText = '';\n  @Input() paymentMethod: 'pix' | 'credit' | null = null;\n  @Input() errorDetails: any = null;\n\n  @Output() modalClosed = new EventEmitter<void>();\n  @Output() modalAction = new EventEmitter<void>();\n  @Input() showModal = false;\n  @Input() messageTitle: string = 'Pagamento Aprovado!';\n  @Input() showBtn = true;\n  @Input() priceNegotiated = 0;\n  @Input() messageBody: string = 'Seu pagamento foi processado com sucesso.';\n\n  // Configuração dinâmica\n  modalIcon: string = 'fa-check';\n  modalIconColor: string = 'text-green-600';\n  modalBgColor: string = 'bg-green-100';\n  @Input() isLoadingBtn: boolean | undefined;\n\n  ngOnInit(): void {}\n  openModal(): void {\n    this.showModal = true;\n  }\n\n  configureModal(type: ModalType, message: string = ''): void {\n    switch (type) {\n      case 'success':\n        this.setSuccessStyles(message);\n        break;\n      case 'error':\n        this.setErrorStyles(message);\n        break;\n      case 'warning':\n        this.setWarningStyles(message);\n        break;\n    }\n  }\n\n  private setSuccessStyles(message: string): void {\n    this.modalIcon = 'fa-check-circle';\n    this.modalIconColor = 'modal-icon-success'; // Nome da classe no CSS\n    this.modalBgColor = 'modal-bg-success'; // Nome da classe no CSS\n    this.messageTitle = 'Sucesso!';\n    this.messageBody = message || 'Operação realizada com sucesso.';\n  }\n\n  private setErrorStyles(message: string): void {\n    this.modalIcon = 'fa-times-circle';\n    this.modalIconColor = 'modal-icon-error';\n    this.modalBgColor = 'modal-bg-error';\n    this.messageTitle = 'Ops! Algo deu errado';\n    this.messageBody = message || 'Não conseguimos processar sua solicitação.';\n  }\n\n  private setWarningStyles(message: string): void {\n    this.modalIcon = 'fa-exclamation-circle';\n    this.modalIconColor = 'modal-icon-warning';\n    this.modalBgColor = 'modal-bg-warning';\n    this.messageTitle = 'Atenção';\n    this.messageBody = message || 'Verifique os dados antes de continuar.';\n  }\n  actionModal(): void {\n    if (this.isLoadingBtn !== undefined) {\n      this.isLoadingBtn = true;\n      this.modalAction.emit();\n    } else {\n      this.modalAction.emit();\n      this.isLoadingBtn = false;\n      this.showModal = false;\n    }\n  }\n  closeModal(): void {\n    this.showModal = false;\n    this.modalClosed.emit();\n  }\n\n  // Controle externo\n  open(\n    type: ModalType,\n    message: string = '',\n    paymentMethod?: 'pix' | 'credit'\n  ): void {\n    this.configureModal(type, message);\n    if (paymentMethod) {\n      this.paymentMethod = paymentMethod;\n    }\n    this.showModal = true;\n  }\n}\n","<div\n  *ngIf=\"showModal\"\n  class=\"modal-overlay-fixed transition-all\"\n  (click)=\"closeModal()\"\n>\n  <div\n    class=\"bg-white w-full max-w-2xl rounded-t-[2.5rem] p-6 shadow-2xl animate-slide-up border-t border-gray-100 flex flex-col\"\n    (click)=\"$event.stopPropagation()\"\n  >\n    <div class=\"w-12 h-1.5 bg-gray-200 rounded-full mx-auto mb-6\"></div>\n\n    <div class=\"flex flex-col items-center text-center\">\n      <div class=\"relative mb-4\">\n        <div\n          [class]=\"modalBgColor\"\n          class=\"w-20 h-20 rounded-full opacity-40\"\n        ></div>\n        <div class=\"absolute inset-0 flex items-center justify-center\">\n          <i\n            [class]=\"modalIcon + ' ' + modalIconColor\"\n            class=\"fas text-3xl\"\n          ></i>\n        </div>\n      </div>\n\n      <h2 class=\"text-2xl font-bold text-gray-900 mb-2\">{{ messageTitle }}</h2>\n\n      <div class=\"w-full modal-scroll-area px-2 custom-scrollbar\">\n        <p *ngIf=\"messageBody\" class=\"text-gray-600 mb-4\">{{ messageBody }}</p>\n\n        <div class=\"modal-dynamic-content text-left\">\n          <ng-content select=\"[optional-content]\"></ng-content>\n        </div>\n\n        <div\n          *ngIf=\"errorDetails\"\n          class=\"mt-4 p-4 bg-red-50 rounded-2xl text-left border border-red-100\"\n        >\n          <p class=\"text-[10px] font-bold text-red-700 uppercase mb-1\">\n            Log do sistema:\n          </p>\n          <pre class=\"text-[11px] text-red-600 font-mono whitespace-pre-wrap\">{{\n            errorDetails | json\n          }}</pre>\n        </div>\n      </div>\n\n      <div class=\"mt-6 flex flex-col w-full gap-3 pb-4\">\n        <button\n          [disabled]=\"priceNegotiated <= 0 && actionButtonText === 'Negociar'\"\n          *ngIf=\"actionButtonText\"\n          (click)=\"actionModal()\"\n          class=\"w-full py-4 text-white rounded-2xl font-bold active:scale-[0.98] transition-all flex items-center justify-center gap-3 shadow-lg btn-primary-custom\"\n          [style.background-color]=\"'var(--primary)'\"\n        >\n          <span *ngIf=\"!isLoadingBtn\">{{ actionButtonText }}</span>\n          <ng-container *ngIf=\"isLoadingBtn\">\n            <span>Processando</span>\n            <i class=\"fas fa-circle-notch fa-spin\"></i>\n          </ng-container>\n        </button>\n\n        <button\n          *ngIf=\"showBtn\"\n          (click)=\"closeModal()\"\n          class=\"w-full py-2 text-gray-500 font-semibold hover:text-gray-800 transition-colors\"\n        >\n          {{ closeButtonText }}\n        </button>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
@@ -0,0 +1,14 @@
1
+ import { Component } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class CutomModalComponent {
4
+ constructor() { }
5
+ ngOnInit() {
6
+ }
7
+ }
8
+ CutomModalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CutomModalComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
9
+ CutomModalComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: CutomModalComponent, selector: "lib-cutom-modal", ngImport: i0, template: "<p>cutom-modal works!</p>\n", styles: [""] });
10
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CutomModalComponent, decorators: [{
11
+ type: Component,
12
+ args: [{ selector: 'lib-cutom-modal', template: "<p>cutom-modal works!</p>\n" }]
13
+ }], ctorParameters: function () { return []; } });
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3V0b20tbW9kYWwuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdHVkdS1jb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9jdXRvbS1tb2RhbC9jdXRvbS1tb2RhbC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90dWR1LWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2N1dG9tLW1vZGFsL2N1dG9tLW1vZGFsLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVUsTUFBTSxlQUFlLENBQUM7O0FBT2xELE1BQU0sT0FBTyxtQkFBbUI7SUFFOUIsZ0JBQWdCLENBQUM7SUFFakIsUUFBUTtJQUNSLENBQUM7O2dIQUxVLG1CQUFtQjtvR0FBbkIsbUJBQW1CLHVEQ1BoQyw2QkFDQTsyRkRNYSxtQkFBbUI7a0JBTC9CLFNBQVM7K0JBQ0UsaUJBQWlCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbGliLWN1dG9tLW1vZGFsJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2N1dG9tLW1vZGFsLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vY3V0b20tbW9kYWwuY29tcG9uZW50LmNzcyddXG59KVxuZXhwb3J0IGNsYXNzIEN1dG9tTW9kYWxDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuXG4gIGNvbnN0cnVjdG9yKCkgeyB9XG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG4gIH1cblxufVxuIiwiPHA+Y3V0b20tbW9kYWwgd29ya3MhPC9wPlxuIl19
@@ -1,21 +1,42 @@
1
- import { NgModule } from '@angular/core';
2
- import { TuduComponentsComponent } from './tudu-components.component';
3
1
  import { CommonModule } from '@angular/common';
2
+ import { NgModule } from '@angular/core';
4
3
  import { CardLayoutComponent } from '../lib/components/card-layout/card-layout.component';
5
- import { NavComponent } from './components/nav/nav.component';
4
+ import { CustomModalComponent } from './components/custom-modal/custom-modal.component';
6
5
  import { FallbackMessageComponent } from './components/fallback-message/fallback-message.component';
6
+ import { NavComponent } from './components/nav/nav.component';
7
+ import { TuduComponentsComponent } from './tudu-components.component';
7
8
  import * as i0 from "@angular/core";
8
9
  export class TuduComponentsModule {
9
10
  }
10
11
  TuduComponentsModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TuduComponentsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
11
- TuduComponentsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.3.0", ngImport: i0, type: TuduComponentsModule, declarations: [TuduComponentsComponent, CardLayoutComponent, NavComponent, FallbackMessageComponent], imports: [CommonModule], exports: [TuduComponentsComponent, CardLayoutComponent, NavComponent, FallbackMessageComponent] });
12
+ TuduComponentsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.3.0", ngImport: i0, type: TuduComponentsModule, declarations: [TuduComponentsComponent,
13
+ CardLayoutComponent,
14
+ NavComponent,
15
+ FallbackMessageComponent,
16
+ CustomModalComponent], imports: [CommonModule], exports: [TuduComponentsComponent,
17
+ CardLayoutComponent,
18
+ NavComponent,
19
+ FallbackMessageComponent,
20
+ CustomModalComponent] });
12
21
  TuduComponentsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TuduComponentsModule, imports: [CommonModule] });
13
22
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TuduComponentsModule, decorators: [{
14
23
  type: NgModule,
15
24
  args: [{
16
- declarations: [TuduComponentsComponent, CardLayoutComponent, NavComponent, FallbackMessageComponent],
25
+ declarations: [
26
+ TuduComponentsComponent,
27
+ CardLayoutComponent,
28
+ NavComponent,
29
+ FallbackMessageComponent,
30
+ CustomModalComponent,
31
+ ],
17
32
  imports: [CommonModule],
18
- exports: [TuduComponentsComponent, CardLayoutComponent, NavComponent, FallbackMessageComponent],
33
+ exports: [
34
+ TuduComponentsComponent,
35
+ CardLayoutComponent,
36
+ NavComponent,
37
+ FallbackMessageComponent,
38
+ CustomModalComponent,
39
+ ],
19
40
  }]
20
41
  }] });
21
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHVkdS1jb21wb25lbnRzLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3R1ZHUtY29tcG9uZW50cy9zcmMvbGliL3R1ZHUtY29tcG9uZW50cy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUN0RSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0scURBQXFELENBQUM7QUFDMUYsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQzlELE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLDBEQUEwRCxDQUFDOztBQU9wRyxNQUFNLE9BQU8sb0JBQW9COztpSEFBcEIsb0JBQW9CO2tIQUFwQixvQkFBb0IsaUJBSmhCLHVCQUF1QixFQUFFLG1CQUFtQixFQUFFLFlBQVksRUFBRSx3QkFBd0IsYUFDekYsWUFBWSxhQUNaLHVCQUF1QixFQUFFLG1CQUFtQixFQUFFLFlBQVksRUFBRSx3QkFBd0I7a0hBRW5GLG9CQUFvQixZQUhyQixZQUFZOzJGQUdYLG9CQUFvQjtrQkFMaEMsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyx1QkFBdUIsRUFBRSxtQkFBbUIsRUFBRSxZQUFZLEVBQUUsd0JBQXdCLENBQUM7b0JBQ3BHLE9BQU8sRUFBRSxDQUFDLFlBQVksQ0FBQztvQkFDdkIsT0FBTyxFQUFFLENBQUMsdUJBQXVCLEVBQUUsbUJBQW1CLEVBQUUsWUFBWSxFQUFFLHdCQUF3QixDQUFDO2lCQUNoRyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUdWR1Q29tcG9uZW50c0NvbXBvbmVudCB9IGZyb20gJy4vdHVkdS1jb21wb25lbnRzLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQ2FyZExheW91dENvbXBvbmVudCB9IGZyb20gJy4uL2xpYi9jb21wb25lbnRzL2NhcmQtbGF5b3V0L2NhcmQtbGF5b3V0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBOYXZDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvbmF2L25hdi5jb21wb25lbnQnO1xuaW1wb3J0IHsgRmFsbGJhY2tNZXNzYWdlQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2ZhbGxiYWNrLW1lc3NhZ2UvZmFsbGJhY2stbWVzc2FnZS5jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtUdWR1Q29tcG9uZW50c0NvbXBvbmVudCwgQ2FyZExheW91dENvbXBvbmVudCwgTmF2Q29tcG9uZW50LCBGYWxsYmFja01lc3NhZ2VDb21wb25lbnRdLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbiAgZXhwb3J0czogW1R1ZHVDb21wb25lbnRzQ29tcG9uZW50LCBDYXJkTGF5b3V0Q29tcG9uZW50LCBOYXZDb21wb25lbnQsIEZhbGxiYWNrTWVzc2FnZUNvbXBvbmVudF0sXG59KVxuZXhwb3J0IGNsYXNzIFR1ZHVDb21wb25lbnRzTW9kdWxlIHt9XG4iXX0=
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHVkdS1jb21wb25lbnRzLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3R1ZHUtY29tcG9uZW50cy9zcmMvbGliL3R1ZHUtY29tcG9uZW50cy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0scURBQXFELENBQUM7QUFDMUYsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sa0RBQWtELENBQUM7QUFDeEYsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sMERBQTBELENBQUM7QUFDcEcsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQzlELE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLDZCQUE2QixDQUFDOztBQW1CdEUsTUFBTSxPQUFPLG9CQUFvQjs7aUhBQXBCLG9CQUFvQjtrSEFBcEIsb0JBQW9CLGlCQWY3Qix1QkFBdUI7UUFDdkIsbUJBQW1CO1FBQ25CLFlBQVk7UUFDWix3QkFBd0I7UUFDeEIsb0JBQW9CLGFBRVosWUFBWSxhQUVwQix1QkFBdUI7UUFDdkIsbUJBQW1CO1FBQ25CLFlBQVk7UUFDWix3QkFBd0I7UUFDeEIsb0JBQW9CO2tIQUdYLG9CQUFvQixZQVRyQixZQUFZOzJGQVNYLG9CQUFvQjtrQkFqQmhDLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLHVCQUF1Qjt3QkFDdkIsbUJBQW1CO3dCQUNuQixZQUFZO3dCQUNaLHdCQUF3Qjt3QkFDeEIsb0JBQW9CO3FCQUNyQjtvQkFDRCxPQUFPLEVBQUUsQ0FBQyxZQUFZLENBQUM7b0JBQ3ZCLE9BQU8sRUFBRTt3QkFDUCx1QkFBdUI7d0JBQ3ZCLG1CQUFtQjt3QkFDbkIsWUFBWTt3QkFDWix3QkFBd0I7d0JBQ3hCLG9CQUFvQjtxQkFDckI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENhcmRMYXlvdXRDb21wb25lbnQgfSBmcm9tICcuLi9saWIvY29tcG9uZW50cy9jYXJkLWxheW91dC9jYXJkLWxheW91dC5jb21wb25lbnQnO1xuaW1wb3J0IHsgQ3VzdG9tTW9kYWxDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvY3VzdG9tLW1vZGFsL2N1c3RvbS1tb2RhbC5jb21wb25lbnQnO1xuaW1wb3J0IHsgRmFsbGJhY2tNZXNzYWdlQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2ZhbGxiYWNrLW1lc3NhZ2UvZmFsbGJhY2stbWVzc2FnZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgTmF2Q29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL25hdi9uYXYuY29tcG9uZW50JztcbmltcG9ydCB7IFR1ZHVDb21wb25lbnRzQ29tcG9uZW50IH0gZnJvbSAnLi90dWR1LWNvbXBvbmVudHMuY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgVHVkdUNvbXBvbmVudHNDb21wb25lbnQsXG4gICAgQ2FyZExheW91dENvbXBvbmVudCxcbiAgICBOYXZDb21wb25lbnQsXG4gICAgRmFsbGJhY2tNZXNzYWdlQ29tcG9uZW50LFxuICAgIEN1c3RvbU1vZGFsQ29tcG9uZW50LFxuICBdLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbiAgZXhwb3J0czogW1xuICAgIFR1ZHVDb21wb25lbnRzQ29tcG9uZW50LFxuICAgIENhcmRMYXlvdXRDb21wb25lbnQsXG4gICAgTmF2Q29tcG9uZW50LFxuICAgIEZhbGxiYWNrTWVzc2FnZUNvbXBvbmVudCxcbiAgICBDdXN0b21Nb2RhbENvbXBvbmVudCxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgVHVkdUNvbXBvbmVudHNNb2R1bGUge31cbiJdfQ==
@@ -6,6 +6,7 @@ export * from './lib/tudu-components.module'; // ← Se criou este módulo
6
6
  export * from './lib/components/card-layout/card-layout.component';
7
7
  export * from './lib/components/nav/nav.component';
8
8
  export * from './lib/components/fallback-message/fallback-message.component';
9
+ export * from './lib/components/custom-modal/custom-modal.component';
9
10
  export * from './lib/tudu-components.service';
10
11
  // export * from './lib/card-layout.module'; // ← Ou se usou CardLayoutModule
11
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL3R1ZHUtY29tcG9uZW50cy9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUNILGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyw4QkFBOEIsQ0FBQyxDQUFDLHlCQUF5QjtBQUV2RSxjQUFjLG9EQUFvRCxDQUFDO0FBQ25FLGNBQWMsb0NBQW9DLENBQUM7QUFDbkQsY0FBYyw4REFBOEQsQ0FBQztBQUM3RSxjQUFjLCtCQUErQixDQUFDO0FBQzlDLDZFQUE2RSIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgdHVkdS1jb21wb25lbnRzXG4gKi9cbmV4cG9ydCAqIGZyb20gJy4vbGliL3R1ZHUtY29tcG9uZW50cy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdHVkdS1jb21wb25lbnRzLm1vZHVsZSc7IC8vIOKGkCBTZSBjcmlvdSBlc3RlIG3Ds2R1bG9cblxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jYXJkLWxheW91dC9jYXJkLWxheW91dC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9uYXYvbmF2LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2ZhbGxiYWNrLW1lc3NhZ2UvZmFsbGJhY2stbWVzc2FnZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdHVkdS1jb21wb25lbnRzLnNlcnZpY2UnO1xuLy8gZXhwb3J0ICogZnJvbSAnLi9saWIvY2FyZC1sYXlvdXQubW9kdWxlJzsgLy8g4oaQIE91IHNlIHVzb3UgQ2FyZExheW91dE1vZHVsZVxuIl19
12
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL3R1ZHUtY29tcG9uZW50cy9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUNILGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyw4QkFBOEIsQ0FBQyxDQUFDLHlCQUF5QjtBQUV2RSxjQUFjLG9EQUFvRCxDQUFDO0FBQ25FLGNBQWMsb0NBQW9DLENBQUM7QUFDbkQsY0FBYyw4REFBOEQsQ0FBQztBQUM3RSxjQUFjLHNEQUFzRCxDQUFDO0FBQ3JFLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsNkVBQTZFIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiB0dWR1LWNvbXBvbmVudHNcbiAqL1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdHVkdS1jb21wb25lbnRzLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90dWR1LWNvbXBvbmVudHMubW9kdWxlJzsgLy8g4oaQIFNlIGNyaW91IGVzdGUgbcOzZHVsb1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2NhcmQtbGF5b3V0L2NhcmQtbGF5b3V0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL25hdi9uYXYuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvZmFsbGJhY2stbWVzc2FnZS9mYWxsYmFjay1tZXNzYWdlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2N1c3RvbS1tb2RhbC9jdXN0b20tbW9kYWwuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3R1ZHUtY29tcG9uZW50cy5zZXJ2aWNlJztcbi8vIGV4cG9ydCAqIGZyb20gJy4vbGliL2NhcmQtbGF5b3V0Lm1vZHVsZSc7IC8vIOKGkCBPdSBzZSB1c291IENhcmRMYXlvdXRNb2R1bGVcbiJdfQ==