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.
- package/esm2020/lib/components/custom-modal/custom-modal.component.mjs +123 -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 +228 -88
- package/fesm2015/tudu-components.mjs.map +1 -1
- package/fesm2020/tudu-components.mjs +228 -88
- package/fesm2020/tudu-components.mjs.map +1 -1
- package/lib/components/custom-modal/custom-modal.component.d.ts +35 -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,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 {
|
|
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==
|