tudu-components 0.2.11 → 0.2.13
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.
- package/esm2020/lib/components/custom-modal/custom-modal.component.mjs +148 -0
- package/esm2020/lib/components/cutom-modal/cutom-modal.component.mjs +14 -0
- package/esm2020/lib/tudu-components.module.mjs +28 -7
- package/esm2020/public-api.mjs +2 -1
- package/fesm2015/tudu-components.mjs +251 -86
- package/fesm2015/tudu-components.mjs.map +1 -1
- package/fesm2020/tudu-components.mjs +251 -86
- package/fesm2020/tudu-components.mjs.map +1 -1
- package/lib/components/custom-modal/custom-modal.component.d.ts +40 -0
- package/lib/components/cutom-modal/cutom-modal.component.d.ts +8 -0
- package/lib/tudu-components.module.d.ts +3 -2
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
|
@@ -0,0 +1,148 @@
|
|
|
1
|
+
import { Component, EventEmitter, HostListener, 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(location) {
|
|
6
|
+
this.location = location;
|
|
7
|
+
this.modalId = 'customModal';
|
|
8
|
+
this.title = 'Aviso';
|
|
9
|
+
this.message = '';
|
|
10
|
+
this.closeButtonText = 'Fechar';
|
|
11
|
+
this.actionButtonText = '';
|
|
12
|
+
this.paymentMethod = null;
|
|
13
|
+
this.errorDetails = null;
|
|
14
|
+
this.modalClosed = new EventEmitter();
|
|
15
|
+
this.modalAction = new EventEmitter();
|
|
16
|
+
this.showModal = false;
|
|
17
|
+
this.messageTitle = 'Pagamento Aprovado!';
|
|
18
|
+
this.showBtn = true;
|
|
19
|
+
this.priceNegotiated = 0;
|
|
20
|
+
this.messageBody = 'Seu pagamento foi processado com sucesso.';
|
|
21
|
+
// Configuração dinâmica
|
|
22
|
+
this.modalIcon = 'fa-check';
|
|
23
|
+
this.modalIconColor = 'text-green-600';
|
|
24
|
+
this.modalBgColor = 'bg-green-100';
|
|
25
|
+
this.isClosing = false;
|
|
26
|
+
}
|
|
27
|
+
ngOnInit() { }
|
|
28
|
+
// Centraliza a abertura do modal com suporte ao botão voltar
|
|
29
|
+
openModal() {
|
|
30
|
+
this.showModal = true;
|
|
31
|
+
// Adiciona um estado no histórico para o botão voltar funcionar
|
|
32
|
+
this.location.go(this.location.path() + '#modalOpen');
|
|
33
|
+
}
|
|
34
|
+
// Atalho para abrir com tipos específicos
|
|
35
|
+
open(type, message = '', paymentMethod) {
|
|
36
|
+
this.configureModal(type, message);
|
|
37
|
+
if (paymentMethod) {
|
|
38
|
+
this.paymentMethod = paymentMethod;
|
|
39
|
+
}
|
|
40
|
+
this.openModal();
|
|
41
|
+
}
|
|
42
|
+
configureModal(type, message = '') {
|
|
43
|
+
switch (type) {
|
|
44
|
+
case 'success':
|
|
45
|
+
this.setSuccessStyles(message);
|
|
46
|
+
break;
|
|
47
|
+
case 'error':
|
|
48
|
+
this.setErrorStyles(message);
|
|
49
|
+
break;
|
|
50
|
+
case 'warning':
|
|
51
|
+
this.setWarningStyles(message);
|
|
52
|
+
break;
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
setSuccessStyles(message) {
|
|
56
|
+
this.modalIcon = 'fa-check-circle';
|
|
57
|
+
this.modalIconColor = 'modal-icon-success';
|
|
58
|
+
this.modalBgColor = 'modal-bg-success';
|
|
59
|
+
this.messageTitle = 'Sucesso!';
|
|
60
|
+
this.messageBody = message || 'Operação realizada com sucesso.';
|
|
61
|
+
}
|
|
62
|
+
setErrorStyles(message) {
|
|
63
|
+
this.modalIcon = 'fa-times-circle';
|
|
64
|
+
this.modalIconColor = 'modal-icon-error';
|
|
65
|
+
this.modalBgColor = 'modal-bg-error';
|
|
66
|
+
this.messageTitle = 'Ops! Algo deu errado';
|
|
67
|
+
this.messageBody = message || 'Não conseguimos processar sua solicitação.';
|
|
68
|
+
}
|
|
69
|
+
setWarningStyles(message) {
|
|
70
|
+
this.modalIcon = 'fa-exclamation-circle';
|
|
71
|
+
this.modalIconColor = 'modal-icon-warning';
|
|
72
|
+
this.modalBgColor = 'modal-bg-warning';
|
|
73
|
+
this.messageTitle = 'Atenção';
|
|
74
|
+
this.messageBody = message || 'Verifique os dados antes de continuar.';
|
|
75
|
+
}
|
|
76
|
+
actionModal() {
|
|
77
|
+
if (this.isLoadingBtn !== undefined) {
|
|
78
|
+
this.isLoadingBtn = true;
|
|
79
|
+
this.modalAction.emit();
|
|
80
|
+
}
|
|
81
|
+
else {
|
|
82
|
+
this.modalAction.emit();
|
|
83
|
+
this.isLoadingBtn = false;
|
|
84
|
+
this.closeModal(); // Usa o método de fechar para limpar o histórico
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
closeModal() {
|
|
88
|
+
this.isClosing = true; // Ativa a animação de descida
|
|
89
|
+
// Aguarda o tempo da animação (300ms) antes de remover do DOM
|
|
90
|
+
setTimeout(() => {
|
|
91
|
+
this.showModal = false;
|
|
92
|
+
this.isClosing = false; // Reseta para a próxima abertura
|
|
93
|
+
this.modalClosed.emit();
|
|
94
|
+
// Lógica do histórico que já fizemos
|
|
95
|
+
if (window.location.hash === '#modalOpen') {
|
|
96
|
+
const currentPath = this.location.path().split('#')[0];
|
|
97
|
+
this.location.replaceState(currentPath);
|
|
98
|
+
}
|
|
99
|
+
}, 300);
|
|
100
|
+
}
|
|
101
|
+
// Escuta o botão voltar do navegador ou celular
|
|
102
|
+
onPopState() {
|
|
103
|
+
if (this.showModal) {
|
|
104
|
+
this.showModal = false;
|
|
105
|
+
this.modalClosed.emit();
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
CustomModalComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CustomModalComponent, deps: [{ token: i1.Location }], target: i0.ɵɵFactoryTarget.Component });
|
|
110
|
+
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" }, host: { listeners: { "window:popstate": "onPopState()" } }, ngImport: i0, template: "<div\n *ngIf=\"showModal\"\n class=\"modal-overlay-fixed\"\n [ngClass]=\"{ 'overlay-hide': isClosing }\"\n (click)=\"closeModal()\"\n>\n <div\n class=\"bg-white w-full max-w-2xl rounded-t-[2.5rem] p-6 shadow-2xl border-t border-gray-100 flex flex-col\"\n [ngClass]=\"isClosing ? 'animate-slide-down' : 'animate-slide-up'\"\n (click)=\"$event.stopPropagation()\"\n >\n <div\n class=\"w-full py-4 -mt-2 cursor-pointer flex justify-center\"\n (click)=\"closeModal()\"\n >\n <div class=\"w-12 h-1.5 bg-gray-200 rounded-full\"></div>\n </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)}}@keyframes slideDown{0%{transform:translateY(0)}to{transform:translateY(100%)}}.animate-slide-up{animation:slideUp .4s cubic-bezier(.25,1,.5,1) forwards}.animate-slide-down{animation:slideDown .4s cubic-bezier(.25,1,.5,1) forwards}.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;transition:opacity .3s ease;opacity:1}.overlay-hide{opacity:0;pointer-events:none}.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}.custom-scrollbar::-webkit-scrollbar{width:4px}.custom-scrollbar::-webkit-scrollbar-thumb{background:#f1f1f1;border-radius:10px}.custom-scrollbar::-webkit-scrollbar-track{background:transparent}.btn-primary-custom:hover:not(:disabled){filter:brightness(.9);transition:filter .2s ease}.btn-primary-custom:disabled{opacity:.6;cursor:not-allowed}.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}@media (min-width: 768px){.modal-overlay-fixed{align-items:center}.animate-slide-up,.animate-slide-down{border-radius:2.5rem;width:90%;margin-bottom:0}@keyframes slideUp{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}@keyframes slideDown{0%{transform:scale(1);opacity:1}to{transform:scale(.9);opacity:0}}}:host-context(body:has(.modal-overlay-fixed)){overflow:hidden}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i1.JsonPipe, name: "json" }] });
|
|
111
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CustomModalComponent, decorators: [{
|
|
112
|
+
type: Component,
|
|
113
|
+
args: [{ selector: 'lib-custom-modal', standalone: false, template: "<div\n *ngIf=\"showModal\"\n class=\"modal-overlay-fixed\"\n [ngClass]=\"{ 'overlay-hide': isClosing }\"\n (click)=\"closeModal()\"\n>\n <div\n class=\"bg-white w-full max-w-2xl rounded-t-[2.5rem] p-6 shadow-2xl border-t border-gray-100 flex flex-col\"\n [ngClass]=\"isClosing ? 'animate-slide-down' : 'animate-slide-up'\"\n (click)=\"$event.stopPropagation()\"\n >\n <div\n class=\"w-full py-4 -mt-2 cursor-pointer flex justify-center\"\n (click)=\"closeModal()\"\n >\n <div class=\"w-12 h-1.5 bg-gray-200 rounded-full\"></div>\n </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)}}@keyframes slideDown{0%{transform:translateY(0)}to{transform:translateY(100%)}}.animate-slide-up{animation:slideUp .4s cubic-bezier(.25,1,.5,1) forwards}.animate-slide-down{animation:slideDown .4s cubic-bezier(.25,1,.5,1) forwards}.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;transition:opacity .3s ease;opacity:1}.overlay-hide{opacity:0;pointer-events:none}.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}.custom-scrollbar::-webkit-scrollbar{width:4px}.custom-scrollbar::-webkit-scrollbar-thumb{background:#f1f1f1;border-radius:10px}.custom-scrollbar::-webkit-scrollbar-track{background:transparent}.btn-primary-custom:hover:not(:disabled){filter:brightness(.9);transition:filter .2s ease}.btn-primary-custom:disabled{opacity:.6;cursor:not-allowed}.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}@media (min-width: 768px){.modal-overlay-fixed{align-items:center}.animate-slide-up,.animate-slide-down{border-radius:2.5rem;width:90%;margin-bottom:0}@keyframes slideUp{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}@keyframes slideDown{0%{transform:scale(1);opacity:1}to{transform:scale(.9);opacity:0}}}:host-context(body:has(.modal-overlay-fixed)){overflow:hidden}\n"] }]
|
|
114
|
+
}], ctorParameters: function () { return [{ type: i1.Location }]; }, propDecorators: { modalId: [{
|
|
115
|
+
type: Input
|
|
116
|
+
}], title: [{
|
|
117
|
+
type: Input
|
|
118
|
+
}], message: [{
|
|
119
|
+
type: Input
|
|
120
|
+
}], closeButtonText: [{
|
|
121
|
+
type: Input
|
|
122
|
+
}], actionButtonText: [{
|
|
123
|
+
type: Input
|
|
124
|
+
}], paymentMethod: [{
|
|
125
|
+
type: Input
|
|
126
|
+
}], errorDetails: [{
|
|
127
|
+
type: Input
|
|
128
|
+
}], modalClosed: [{
|
|
129
|
+
type: Output
|
|
130
|
+
}], modalAction: [{
|
|
131
|
+
type: Output
|
|
132
|
+
}], showModal: [{
|
|
133
|
+
type: Input
|
|
134
|
+
}], messageTitle: [{
|
|
135
|
+
type: Input
|
|
136
|
+
}], showBtn: [{
|
|
137
|
+
type: Input
|
|
138
|
+
}], priceNegotiated: [{
|
|
139
|
+
type: Input
|
|
140
|
+
}], messageBody: [{
|
|
141
|
+
type: Input
|
|
142
|
+
}], isLoadingBtn: [{
|
|
143
|
+
type: Input
|
|
144
|
+
}], onPopState: [{
|
|
145
|
+
type: HostListener,
|
|
146
|
+
args: ['window:popstate']
|
|
147
|
+
}] } });
|
|
148
|
+
//# 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 {\n  Component,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnInit,\n  Output,\n} from '@angular/core';\nimport { Location } from '@angular/common'; // Importação correta\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\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  @Input() isLoadingBtn: boolean | undefined;\n\n  // Configuração dinâmica\n  modalIcon: string = 'fa-check';\n  modalIconColor: string = 'text-green-600';\n  modalBgColor: string = 'bg-green-100';\n  isClosing = false;\n\n  constructor(private location: Location) {}\n\n  ngOnInit(): void {}\n\n  // Centraliza a abertura do modal com suporte ao botão voltar\n  openModal(): void {\n    this.showModal = true;\n    // Adiciona um estado no histórico para o botão voltar funcionar\n    this.location.go(this.location.path() + '#modalOpen');\n  }\n\n  // Atalho para abrir com tipos específicos\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.openModal();\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';\n    this.modalBgColor = 'modal-bg-success';\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\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.closeModal(); // Usa o método de fechar para limpar o histórico\n    }\n  }\n\n  closeModal(): void {\n    this.isClosing = true; // Ativa a animação de descida\n\n    // Aguarda o tempo da animação (300ms) antes de remover do DOM\n    setTimeout(() => {\n      this.showModal = false;\n      this.isClosing = false; // Reseta para a próxima abertura\n      this.modalClosed.emit();\n\n      // Lógica do histórico que já fizemos\n      if (window.location.hash === '#modalOpen') {\n        const currentPath = this.location.path().split('#')[0];\n        this.location.replaceState(currentPath);\n      }\n    }, 300);\n  }\n  // Escuta o botão voltar do navegador ou celular\n  @HostListener('window:popstate')\n  onPopState(): void {\n    if (this.showModal) {\n      this.showModal = false;\n      this.modalClosed.emit();\n    }\n  }\n}\n","<div\n  *ngIf=\"showModal\"\n  class=\"modal-overlay-fixed\"\n  [ngClass]=\"{ 'overlay-hide': isClosing }\"\n  (click)=\"closeModal()\"\n>\n  <div\n    class=\"bg-white w-full max-w-2xl rounded-t-[2.5rem] p-6 shadow-2xl border-t border-gray-100 flex flex-col\"\n    [ngClass]=\"isClosing ? 'animate-slide-down' : 'animate-slide-up'\"\n    (click)=\"$event.stopPropagation()\"\n  >\n    <div\n      class=\"w-full py-4 -mt-2 cursor-pointer flex justify-center\"\n      (click)=\"closeModal()\"\n    >\n      <div class=\"w-12 h-1.5 bg-gray-200 rounded-full\"></div>\n    </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 {
|
|
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,
|
|
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: [
|
|
25
|
+
declarations: [
|
|
26
|
+
TuduComponentsComponent,
|
|
27
|
+
CardLayoutComponent,
|
|
28
|
+
NavComponent,
|
|
29
|
+
FallbackMessageComponent,
|
|
30
|
+
CustomModalComponent,
|
|
31
|
+
],
|
|
17
32
|
imports: [CommonModule],
|
|
18
|
-
exports: [
|
|
33
|
+
exports: [
|
|
34
|
+
TuduComponentsComponent,
|
|
35
|
+
CardLayoutComponent,
|
|
36
|
+
NavComponent,
|
|
37
|
+
FallbackMessageComponent,
|
|
38
|
+
CustomModalComponent,
|
|
39
|
+
],
|
|
19
40
|
}]
|
|
20
41
|
}] });
|
|
21
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
42
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHVkdS1jb21wb25lbnRzLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3R1ZHUtY29tcG9uZW50cy9zcmMvbGliL3R1ZHUtY29tcG9uZW50cy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0scURBQXFELENBQUM7QUFDMUYsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sa0RBQWtELENBQUM7QUFDeEYsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0sMERBQTBELENBQUM7QUFDcEcsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQzlELE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLDZCQUE2QixDQUFDOztBQW1CdEUsTUFBTSxPQUFPLG9CQUFvQjs7aUhBQXBCLG9CQUFvQjtrSEFBcEIsb0JBQW9CLGlCQWY3Qix1QkFBdUI7UUFDdkIsbUJBQW1CO1FBQ25CLFlBQVk7UUFDWix3QkFBd0I7UUFDeEIsb0JBQW9CLGFBRVosWUFBWSxhQUVwQix1QkFBdUI7UUFDdkIsbUJBQW1CO1FBQ25CLFlBQVk7UUFDWix3QkFBd0I7UUFDeEIsb0JBQW9CO2tIQUdYLG9CQUFvQixZQVRyQixZQUFZOzJGQVNYLG9CQUFvQjtrQkFqQmhDLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLHVCQUF1Qjt3QkFDdkIsbUJBQW1CO3dCQUNuQixZQUFZO3dCQUNaLHdCQUF3Qjt3QkFDeEIsb0JBQW9CO3FCQUNyQjtvQkFDRCxPQUFPLEVBQUUsQ0FBQyxZQUFZLENBQUM7b0JBQ3ZCLE9BQU8sRUFBRTt3QkFDUCx1QkFBdUI7d0JBQ3ZCLG1CQUFtQjt3QkFDbkIsWUFBWTt3QkFDWix3QkFBd0I7d0JBQ3hCLG9CQUFvQjtxQkFDckI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENhcmRMYXlvdXRDb21wb25lbnQgfSBmcm9tICcuLi9saWIvY29tcG9uZW50cy9jYXJkLWxheW91dC9jYXJkLWxheW91dC5jb21wb25lbnQnO1xuaW1wb3J0IHsgQ3VzdG9tTW9kYWxDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvY3VzdG9tLW1vZGFsL2N1c3RvbS1tb2RhbC5jb21wb25lbnQnO1xuaW1wb3J0IHsgRmFsbGJhY2tNZXNzYWdlQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2ZhbGxiYWNrLW1lc3NhZ2UvZmFsbGJhY2stbWVzc2FnZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgTmF2Q29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL25hdi9uYXYuY29tcG9uZW50JztcbmltcG9ydCB7IFR1ZHVDb21wb25lbnRzQ29tcG9uZW50IH0gZnJvbSAnLi90dWR1LWNvbXBvbmVudHMuY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgVHVkdUNvbXBvbmVudHNDb21wb25lbnQsXG4gICAgQ2FyZExheW91dENvbXBvbmVudCxcbiAgICBOYXZDb21wb25lbnQsXG4gICAgRmFsbGJhY2tNZXNzYWdlQ29tcG9uZW50LFxuICAgIEN1c3RvbU1vZGFsQ29tcG9uZW50LFxuICBdLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbiAgZXhwb3J0czogW1xuICAgIFR1ZHVDb21wb25lbnRzQ29tcG9uZW50LFxuICAgIENhcmRMYXlvdXRDb21wb25lbnQsXG4gICAgTmF2Q29tcG9uZW50LFxuICAgIEZhbGxiYWNrTWVzc2FnZUNvbXBvbmVudCxcbiAgICBDdXN0b21Nb2RhbENvbXBvbmVudCxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgVHVkdUNvbXBvbmVudHNNb2R1bGUge31cbiJdfQ==
|
package/esm2020/public-api.mjs
CHANGED
|
@@ -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,
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL3R1ZHUtY29tcG9uZW50cy9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUNILGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyw4QkFBOEIsQ0FBQyxDQUFDLHlCQUF5QjtBQUV2RSxjQUFjLG9EQUFvRCxDQUFDO0FBQ25FLGNBQWMsb0NBQW9DLENBQUM7QUFDbkQsY0FBYyw4REFBOEQsQ0FBQztBQUM3RSxjQUFjLHNEQUFzRCxDQUFDO0FBQ3JFLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsNkVBQTZFIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiB0dWR1LWNvbXBvbmVudHNcbiAqL1xuZXhwb3J0ICogZnJvbSAnLi9saWIvdHVkdS1jb21wb25lbnRzLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90dWR1LWNvbXBvbmVudHMubW9kdWxlJzsgLy8g4oaQIFNlIGNyaW91IGVzdGUgbcOzZHVsb1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2NhcmQtbGF5b3V0L2NhcmQtbGF5b3V0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL25hdi9uYXYuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvZmFsbGJhY2stbWVzc2FnZS9mYWxsYmFjay1tZXNzYWdlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2N1c3RvbS1tb2RhbC9jdXN0b20tbW9kYWwuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3R1ZHUtY29tcG9uZW50cy5zZXJ2aWNlJztcbi8vIGV4cG9ydCAqIGZyb20gJy4vbGliL2NhcmQtbGF5b3V0Lm1vZHVsZSc7IC8vIOKGkCBPdSBzZSB1c291IENhcmRMYXlvdXRNb2R1bGVcbiJdfQ==
|