@litigiovirtual/ius-design-components 1.0.64 → 1.0.66
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/esm2022/lib/button-auth/button-auth.component.mjs +90 -6
- package/esm2022/lib/directives/popover.directive.mjs +170 -0
- package/esm2022/lib/input-otp/index.mjs +2 -0
- package/esm2022/lib/input-otp/input-otp.component.mjs +173 -0
- package/esm2022/lib/input-password/index.mjs +2 -0
- package/esm2022/lib/input-password/input-password.component.mjs +71 -0
- package/esm2022/lib/popover/popover.component.mjs +30 -0
- package/esm2022/public-api.mjs +5 -1
- package/fesm2022/litigiovirtual-ius-design-components.mjs +515 -8
- package/fesm2022/litigiovirtual-ius-design-components.mjs.map +1 -1
- package/lib/button-auth/button-auth.component.d.ts +12 -0
- package/lib/directives/popover.directive.d.ts +41 -0
- package/lib/input-otp/index.d.ts +1 -0
- package/lib/input-otp/input-otp.component.d.ts +34 -0
- package/lib/input-password/index.d.ts +1 -0
- package/lib/input-password/input-password.component.d.ts +24 -0
- package/lib/popover/popover.component.d.ts +10 -0
- package/package.json +1 -1
- package/public-api.d.ts +3 -0
|
@@ -1,26 +1,110 @@
|
|
|
1
1
|
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/platform-browser";
|
|
3
5
|
export class ButtonAuthComponent {
|
|
4
|
-
constructor() {
|
|
6
|
+
constructor(sanitizer) {
|
|
7
|
+
this.sanitizer = sanitizer;
|
|
5
8
|
this.disabled = false;
|
|
6
9
|
this.buttonClicked = new EventEmitter();
|
|
10
|
+
this.colorDisabled = '#BFBFBF';
|
|
11
|
+
this.svg = '';
|
|
12
|
+
this.svgGoogle = `<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 20 20" fill="none">
|
|
13
|
+
<path d="M18.8 10.2084C18.8 9.55837 18.7417 8.93337 18.6333 8.33337H10V11.8834H14.9333C14.7167 13.025 14.0667 13.9917 13.0917 14.6417V16.95H16.0667C17.8 15.35 18.8 13 18.8 10.2084Z" fill="#4285F4"/>
|
|
14
|
+
<path d="M10 19.1667C12.475 19.1667 14.55 18.35 16.0667 16.95L13.0917 14.6417C12.275 15.1917 11.2333 15.525 10 15.525C7.61668 15.525 5.59168 13.9167 4.86668 11.75H1.81668V14.1167C3.32501 17.1083 6.41668 19.1667 10 19.1667Z" fill="#34A853"/>
|
|
15
|
+
<path d="M4.86668 11.7417C4.68334 11.1917 4.57501 10.6084 4.57501 10.0001C4.57501 9.39172 4.68334 8.80839 4.86668 8.25839V5.89172H1.81668C1.19168 7.12506 0.833344 8.51672 0.833344 10.0001C0.833344 11.4834 1.19168 12.8751 1.81668 14.1084L4.19168 12.2584L4.86668 11.7417Z" fill="#FBBC05"/>
|
|
16
|
+
<path d="M10 4.48337C11.35 4.48337 12.55 4.95004 13.5083 5.85004L16.1333 3.22504C14.5417 1.74171 12.475 0.833374 10 0.833374C6.41668 0.833374 3.32501 2.89171 1.81668 5.89171L4.86668 8.25837C5.59168 6.09171 7.61668 4.48337 10 4.48337Z" fill="#EA4335"/>
|
|
17
|
+
</svg>`;
|
|
18
|
+
this.svgGoogleDisabled = `<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 20 20" fill="none">
|
|
19
|
+
<path d="M18.8 10.2084C18.8 9.55837 18.7417 8.93337 18.6333 8.33337H10V11.8834H14.9333C14.7167 13.025 14.0667 13.9917 13.0917 14.6417V16.95H16.0667C17.8 15.35 18.8 13 18.8 10.2084Z" fill="#BFBFBF"/>
|
|
20
|
+
<path d="M10 19.1667C12.475 19.1667 14.55 18.35 16.0667 16.95L13.0917 14.6417C12.275 15.1917 11.2333 15.525 10 15.525C7.61668 15.525 5.59168 13.9167 4.86668 11.75H1.81668V14.1167C3.32501 17.1083 6.41668 19.1667 10 19.1667Z" fill="#BFBFBF"/>
|
|
21
|
+
<path d="M4.86668 11.7417C4.68334 11.1917 4.57501 10.6084 4.57501 10.0001C4.57501 9.39172 4.68334 8.80839 4.86668 8.25839V5.89172H1.81668C1.19168 7.12506 0.833344 8.51672 0.833344 10.0001C0.833344 11.4834 1.19168 12.8751 1.81668 14.1084L4.19168 12.2584L4.86668 11.7417Z" fill="#BFBFBF"/>
|
|
22
|
+
<path d="M10 4.48337C11.35 4.48337 12.55 4.95004 13.5083 5.85004L16.1333 3.22504C14.5417 1.74171 12.475 0.833374 10 0.833374C6.41668 0.833374 3.32501 2.89171 1.81668 5.89171L4.86668 8.25837C5.59168 6.09171 7.61668 4.48337 10 4.48337Z" fill="#BFBFBF"/>
|
|
23
|
+
</svg>`;
|
|
24
|
+
this.svgMicrosoft = `<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 20 20" fill="none">
|
|
25
|
+
<g clip-path="url(#clip0_1670_13811)">
|
|
26
|
+
<path d="M0 0H20V20H0V0Z" fill="#F3F3F3"/>
|
|
27
|
+
<path d="M0.869568 0.869507H9.56522V9.56516H0.869568V0.869507Z" fill="#F35325"/>
|
|
28
|
+
<path d="M10.4348 0.869507H19.1304V9.56516H10.4348V0.869507Z" fill="#81BC06"/>
|
|
29
|
+
<path d="M0.869568 10.4348H9.56522V19.1305H0.869568V10.4348Z" fill="#05A6F0"/>
|
|
30
|
+
<path d="M10.4348 10.4348H19.1304V19.1305H10.4348V10.4348Z" fill="#FFBA08"/>
|
|
31
|
+
</g>
|
|
32
|
+
<defs>
|
|
33
|
+
<clipPath id="clip0_1670_13811">
|
|
34
|
+
<rect width="20" height="20" fill="white"/>
|
|
35
|
+
</clipPath>
|
|
36
|
+
</defs>
|
|
37
|
+
</svg>`;
|
|
38
|
+
this.svgMicrosoftDisabled = `<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 20 20" fill="none">
|
|
39
|
+
<g clip-path="url(#clip0_1670_13817)">
|
|
40
|
+
<path d="M0 0H20V20H0V0Z" fill="#F3F3F3"/>
|
|
41
|
+
<path d="M0.869568 0.869507H9.56522V9.56516H0.869568V0.869507Z" fill="#BFBFBF"/>
|
|
42
|
+
<path d="M10.4348 0.869507H19.1304V9.56516H10.4348V0.869507Z" fill="#BFBFBF"/>
|
|
43
|
+
<path d="M0.869568 10.4348H9.56522V19.1305H0.869568V10.4348Z" fill="#BFBFBF"/>
|
|
44
|
+
<path d="M10.4348 10.4348H19.1304V19.1305H10.4348V10.4348Z" fill="#BFBFBF"/>
|
|
45
|
+
</g>
|
|
46
|
+
<defs>
|
|
47
|
+
<clipPath id="clip0_1670_13817">
|
|
48
|
+
<rect width="20" height="20" fill="white"/>
|
|
49
|
+
</clipPath>
|
|
50
|
+
</defs>
|
|
51
|
+
</svg>`;
|
|
52
|
+
this.svgLinkedin = `<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 20 20" fill="none">
|
|
53
|
+
<path fill-rule="evenodd" clip-rule="evenodd" d="M2.22222 20H17.7778C19.0051 20 20 19.0051 20 17.7778V2.22222C20 0.994923 19.0051 0 17.7778 0H2.22222C0.994923 0 0 0.994923 0 2.22222V17.7778C0 19.0051 0.994923 20 2.22222 20Z" fill="#007EBB"/>
|
|
54
|
+
</svg>`;
|
|
55
|
+
this.svgLinkedinDisabled = `<svg xmlns="http://www.w3.org/2000/svg" width="20" height="20" viewBox="0 0 20 20" fill="none">
|
|
56
|
+
<path fill-rule="evenodd" clip-rule="evenodd" d="M2.22222 20H17.7778C19.0051 20 20 19.0051 20 17.7778V2.22222C20 0.994923 19.0051 0 17.7778 0H2.22222C0.994923 0 0 0.994923 0 2.22222V17.7778C0 19.0051 0.994923 20 2.22222 20Z" fill="#BFBFBF"/>
|
|
57
|
+
</svg>`;
|
|
58
|
+
}
|
|
59
|
+
ngOnInit() {
|
|
60
|
+
var svgIcon = '';
|
|
61
|
+
switch (this.textButton) {
|
|
62
|
+
case 'Google':
|
|
63
|
+
if (this.disabled) {
|
|
64
|
+
svgIcon = this.svgGoogleDisabled;
|
|
65
|
+
}
|
|
66
|
+
else {
|
|
67
|
+
svgIcon = this.svgGoogle;
|
|
68
|
+
}
|
|
69
|
+
break;
|
|
70
|
+
case 'Microsoft':
|
|
71
|
+
if (this.disabled) {
|
|
72
|
+
svgIcon = this.svgMicrosoftDisabled;
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
svgIcon = this.svgMicrosoft;
|
|
76
|
+
}
|
|
77
|
+
break;
|
|
78
|
+
case 'LinkedIn':
|
|
79
|
+
if (this.disabled) {
|
|
80
|
+
svgIcon = this.svgLinkedinDisabled;
|
|
81
|
+
}
|
|
82
|
+
else {
|
|
83
|
+
svgIcon = this.svgLinkedin;
|
|
84
|
+
}
|
|
85
|
+
break;
|
|
86
|
+
default:
|
|
87
|
+
svgIcon = '';
|
|
88
|
+
break;
|
|
89
|
+
}
|
|
90
|
+
this.svg = this.sanitizer.bypassSecurityTrustHtml(svgIcon) ?? '';
|
|
7
91
|
}
|
|
8
92
|
onClick() {
|
|
9
93
|
if (this.disabled == false) {
|
|
10
94
|
this.buttonClicked.emit();
|
|
11
95
|
}
|
|
12
96
|
}
|
|
13
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ButtonAuthComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
14
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ButtonAuthComponent, isStandalone: true, selector: "ius-button-auth", inputs: { disabled: "disabled", textButton: "textButton" }, outputs: { buttonClicked: "buttonClicked" }, ngImport: i0, template: "<button class=\"ctn-button\"
|
|
97
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ButtonAuthComponent, deps: [{ token: i1.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
98
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ButtonAuthComponent, isStandalone: true, selector: "ius-button-auth", inputs: { disabled: "disabled", textButton: "textButton" }, outputs: { buttonClicked: "buttonClicked" }, ngImport: i0, template: "<button class=\"ctn-button\" [disabled]=\"disabled\">\r\n <span [innerHTML]=\"svg\" class=\"icon-btn\"></span>\r\n <span class=\"label-base\">{{textButton}}</span>\r\n</button>", styles: [".h1{font-family:Roboto,sans-serif;font-size:2.375rem;font-weight:500;line-height:46px}.h2{font-family:Roboto,sans-serif;font-size:1.875rem;font-weight:700;line-height:38px}.h3{font-family:Roboto,sans-serif;font-size:1.5rem;font-weight:500;line-height:32px}.h4{font-family:Roboto,sans-serif;font-size:1.25rem;font-weight:700;line-height:26px}.h5{font-family:Roboto,sans-serif;font-size:1.125rem;font-weight:500;line-height:24px;letter-spacing:.18px}.label-large{font-family:Roboto,sans-serif;font-size:1rem;font-weight:500;line-height:22px}.body-large{font-family:Rubik,sans-serif;font-size:1rem;font-weight:400;line-height:22px}.label-base{font-family:Rubik,sans-serif;font-size:.875rem;font-weight:500;line-height:20px;letter-spacing:.28px}.body-base{font-family:Rubik,sans-serif;font-size:.875rem;font-weight:400;line-height:20px;font-style:italic;letter-spacing:.28px}.body-sm{font-family:Rubik,sans-serif;font-size:.75rem;font-weight:400;line-height:16px;letter-spacing:.28px}.body-sm-italic{font-family:Rubik,sans-serif;font-size:.75rem;font-weight:400;line-height:16px;font-style:italic;letter-spacing:.28px}.caption-sm{font-family:Rubik,sans-serif;font-size:.75rem;font-weight:500;line-height:16px;letter-spacing:.28px}.caption-sm-italic{font-family:Rubik,sans-serif;font-size:.75rem;font-weight:500;line-height:16px;font-style:italic;letter-spacing:.28px}.ctn-button{position:relative;display:flex;padding:12px 24px;justify-content:center;align-items:center;gap:4px;border:none;cursor:pointer;border-radius:14px;background:#f0f0f0;color:#333}.ctn-button:hover:not(:disabled){background-color:#bfbfbf}.ctn-button:active:not(:disabled){color:#fff;background-color:#0581bc}.ctn-button:disabled{color:#bfbfbf;background-color:#f5f5f5;cursor:default}.icon-btn{width:20px;height:20px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }] }); }
|
|
15
99
|
}
|
|
16
100
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ButtonAuthComponent, decorators: [{
|
|
17
101
|
type: Component,
|
|
18
|
-
args: [{ selector: 'ius-button-auth', standalone: true, imports: [], template: "<button class=\"ctn-button\"
|
|
19
|
-
}], propDecorators: { disabled: [{
|
|
102
|
+
args: [{ selector: 'ius-button-auth', standalone: true, imports: [CommonModule], template: "<button class=\"ctn-button\" [disabled]=\"disabled\">\r\n <span [innerHTML]=\"svg\" class=\"icon-btn\"></span>\r\n <span class=\"label-base\">{{textButton}}</span>\r\n</button>", styles: [".h1{font-family:Roboto,sans-serif;font-size:2.375rem;font-weight:500;line-height:46px}.h2{font-family:Roboto,sans-serif;font-size:1.875rem;font-weight:700;line-height:38px}.h3{font-family:Roboto,sans-serif;font-size:1.5rem;font-weight:500;line-height:32px}.h4{font-family:Roboto,sans-serif;font-size:1.25rem;font-weight:700;line-height:26px}.h5{font-family:Roboto,sans-serif;font-size:1.125rem;font-weight:500;line-height:24px;letter-spacing:.18px}.label-large{font-family:Roboto,sans-serif;font-size:1rem;font-weight:500;line-height:22px}.body-large{font-family:Rubik,sans-serif;font-size:1rem;font-weight:400;line-height:22px}.label-base{font-family:Rubik,sans-serif;font-size:.875rem;font-weight:500;line-height:20px;letter-spacing:.28px}.body-base{font-family:Rubik,sans-serif;font-size:.875rem;font-weight:400;line-height:20px;font-style:italic;letter-spacing:.28px}.body-sm{font-family:Rubik,sans-serif;font-size:.75rem;font-weight:400;line-height:16px;letter-spacing:.28px}.body-sm-italic{font-family:Rubik,sans-serif;font-size:.75rem;font-weight:400;line-height:16px;font-style:italic;letter-spacing:.28px}.caption-sm{font-family:Rubik,sans-serif;font-size:.75rem;font-weight:500;line-height:16px;letter-spacing:.28px}.caption-sm-italic{font-family:Rubik,sans-serif;font-size:.75rem;font-weight:500;line-height:16px;font-style:italic;letter-spacing:.28px}.ctn-button{position:relative;display:flex;padding:12px 24px;justify-content:center;align-items:center;gap:4px;border:none;cursor:pointer;border-radius:14px;background:#f0f0f0;color:#333}.ctn-button:hover:not(:disabled){background-color:#bfbfbf}.ctn-button:active:not(:disabled){color:#fff;background-color:#0581bc}.ctn-button:disabled{color:#bfbfbf;background-color:#f5f5f5;cursor:default}.icon-btn{width:20px;height:20px}\n"] }]
|
|
103
|
+
}], ctorParameters: () => [{ type: i1.DomSanitizer }], propDecorators: { disabled: [{
|
|
20
104
|
type: Input
|
|
21
105
|
}], textButton: [{
|
|
22
106
|
type: Input
|
|
23
107
|
}], buttonClicked: [{
|
|
24
108
|
type: Output
|
|
25
109
|
}] } });
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnV0dG9uLWF1dGguY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvaXVzLWRlc2lnbi1jb21wb25lbnRzL3NyYy9saWIvYnV0dG9uLWF1dGgvYnV0dG9uLWF1dGguY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvaXVzLWRlc2lnbi1jb21wb25lbnRzL3NyYy9saWIvYnV0dG9uLWF1dGgvYnV0dG9uLWF1dGguY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFTdkUsTUFBTSxPQUFPLG1CQUFtQjtJQVBoQztRQVNXLGFBQVEsR0FBRyxLQUFLLENBQUM7UUFFaEIsa0JBQWEsR0FBdUIsSUFBSSxZQUFZLEVBQUUsQ0FBQztLQU9sRTtJQUxDLE9BQU87UUFDTCxJQUFJLElBQUksQ0FBQyxRQUFRLElBQUksS0FBSyxFQUFFLENBQUM7WUFDM0IsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUM1QixDQUFDO0lBQ0gsQ0FBQzsrR0FWVSxtQkFBbUI7bUdBQW5CLG1CQUFtQixvTENUaEMsdzVDQWdCUzs7NEZEUEksbUJBQW1CO2tCQVAvQixTQUFTOytCQUNFLGlCQUFpQixjQUNmLElBQUksV0FDUCxFQUFFOzhCQU1GLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csVUFBVTtzQkFBbEIsS0FBSztnQkFDSSxhQUFhO3NCQUF0QixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnaXVzLWJ1dHRvbi1hdXRoJyxcclxuICBzdGFuZGFsb25lOiB0cnVlLFxyXG4gIGltcG9ydHM6IFtdLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9idXR0b24tYXV0aC5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmw6ICcuL2J1dHRvbi1hdXRoLmNvbXBvbmVudC5zY3NzJ1xyXG59KVxyXG5leHBvcnQgY2xhc3MgQnV0dG9uQXV0aENvbXBvbmVudCB7XHJcblxyXG4gIEBJbnB1dCgpIGRpc2FibGVkID0gZmFsc2U7XHJcbiAgQElucHV0KCkgdGV4dEJ1dHRvbj86IHN0cmluZztcclxuICBAT3V0cHV0KCkgYnV0dG9uQ2xpY2tlZDogRXZlbnRFbWl0dGVyPHZvaWQ+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xyXG5cclxuICBvbkNsaWNrKCkge1xyXG4gICAgaWYgKHRoaXMuZGlzYWJsZWQgPT0gZmFsc2UpIHtcclxuICAgICAgdGhpcy5idXR0b25DbGlja2VkLmVtaXQoKTtcclxuICAgIH1cclxuICB9XHJcbn1cclxuIiwiPGJ1dHRvbiBjbGFzcz1cImN0bi1idXR0b25cIj5cclxuICAgIDxzdmcgeG1sbnM9XCJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2Z1wiIHdpZHRoPVwiMjFcIiBoZWlnaHQ9XCIyMVwiIHZpZXdCb3g9XCIwIDAgMjEgMjFcIiBmaWxsPVwibm9uZVwiPlxyXG4gICAgICAgIDxwYXRoXHJcbiAgICAgICAgICAgIGQ9XCJNMTkuMyAxMC44NTA2QzE5LjMgMTAuMjAwNiAxOS4yNDE3IDkuNTc1NTkgMTkuMTMzMyA4Ljk3NTU5SDEwLjVWMTIuNTI1NkgxNS40MzMzQzE1LjIxNjcgMTMuNjY3MyAxNC41NjY3IDE0LjYzMzkgMTMuNTkxNyAxNS4yODM5VjE3LjU5MjNIMTYuNTY2N0MxOC4zIDE1Ljk5MjMgMTkuMyAxMy42NDIzIDE5LjMgMTAuODUwNlpcIlxyXG4gICAgICAgICAgICBmaWxsPVwiIzQyODVGNFwiIC8+XHJcbiAgICAgICAgPHBhdGhcclxuICAgICAgICAgICAgZD1cIk0xMC41MDAyIDE5LjgwOTJDMTIuOTc1MiAxOS44MDkyIDE1LjA1MDIgMTguOTkyNiAxNi41NjY5IDE3LjU5MjZMMTMuNTkxOSAxNS4yODQyQzEyLjc3NTIgMTUuODM0MiAxMS43MzM2IDE2LjE2NzYgMTAuNTAwMiAxNi4xNjc2QzguMTE2ODkgMTYuMTY3NiA2LjA5MTg5IDE0LjU1OTIgNS4zNjY4OSAxMi4zOTI2SDIuMzE2ODlWMTQuNzU5MkMzLjgyNTIzIDE3Ljc1MDkgNi45MTY4OSAxOS44MDkyIDEwLjUwMDIgMTkuODA5MlpcIlxyXG4gICAgICAgICAgICBmaWxsPVwiIzM0QTg1M1wiIC8+XHJcbiAgICAgICAgPHBhdGhcclxuICAgICAgICAgICAgZD1cIk01LjM2NjgzIDEyLjM4NDJDNS4xODM1IDExLjgzNDIgNS4wNzUxNiAxMS4yNTA4IDUuMDc1MTYgMTAuNjQyNUM1LjA3NTE2IDEwLjAzNDIgNS4xODM1IDkuNDUwODUgNS4zNjY4MyA4LjkwMDg1VjYuNTM0MThIMi4zMTY4M0MxLjY5MTgzIDcuNzY3NTEgMS4zMzM1IDkuMTU5MTggMS4zMzM1IDEwLjY0MjVDMS4zMzM1IDEyLjEyNTggMS42OTE4MyAxMy41MTc1IDIuMzE2ODMgMTQuNzUwOEw0LjY5MTgzIDEyLjkwMDhMNS4zNjY4MyAxMi4zODQyWlwiXHJcbiAgICAgICAgICAgIGZpbGw9XCIjRkJCQzA1XCIgLz5cclxuICAgICAgICA8cGF0aFxyXG4gICAgICAgICAgICBkPVwiTTEwLjUwMDIgNS4xMjU1OUMxMS44NTAyIDUuMTI1NTkgMTMuMDUwMiA1LjU5MjI1IDE0LjAwODYgNi40OTIyNUwxNi42MzM2IDMuODY3MjVDMTUuMDQxOSAyLjM4MzkyIDEyLjk3NTIgMS40NzU1OSAxMC41MDAyIDEuNDc1NTlDNi45MTY4OSAxLjQ3NTU5IDMuODI1MjMgMy41MzM5MiAyLjMxNjg5IDYuNTMzOTJMNS4zNjY4OSA4LjkwMDU5QzYuMDkxODkgNi43MzM5MiA4LjExNjg5IDUuMTI1NTkgMTAuNTAwMiA1LjEyNTU5WlwiXHJcbiAgICAgICAgICAgIGZpbGw9XCIjRUE0MzM1XCIgLz5cclxuICAgIDwvc3ZnPlxyXG4gICAgPHNwYW4gY2xhc3M9XCJsYWJlbC1iYXNlXCI+R29vZ2xlPC9zcGFuPlxyXG48L2J1dHRvbj4iXX0=
|
|
110
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button-auth.component.js","sourceRoot":"","sources":["../../../../../projects/ius-design-components/src/lib/button-auth/button-auth.component.ts","../../../../../projects/ius-design-components/src/lib/button-auth/button-auth.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACvE,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;;;AAU/C,MAAM,OAAO,mBAAmB;IAU9B,YAAoB,SAAuB;QAAvB,cAAS,GAAT,SAAS,CAAc;QARlC,aAAQ,GAAG,KAAK,CAAC;QAEhB,kBAAa,GAAuB,IAAI,YAAY,EAAE,CAAC;QAEjE,kBAAa,GAAW,SAAS,CAAC;QAElC,QAAG,GAAa,EAAE,CAAC;QA2CnB,cAAS,GAAW;;;;;SAKb,CAAC;QAER,sBAAiB,GAAW;;;;;SAKrB,CAAC;QAER,iBAAY,GAAW;;;;;;;;;;;;;SAahB,CAAC;QAER,yBAAoB,GAAW;;;;;;;;;;;;;SAaxB,CAAC;QAER,gBAAW,GAAW;;SAEf,CAAC;QAER,wBAAmB,GAAW;;SAEvB,CAAC;IA3FuC,CAAC;IAEhD,QAAQ;QACN,IAAI,OAAO,GAAW,EAAE,CAAC;QAEzB,QAAQ,IAAI,CAAC,UAAU,EAAE,CAAC;YACxB,KAAK,QAAQ;gBACX,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;oBAClB,OAAO,GAAG,IAAI,CAAC,iBAAiB,CAAC;gBACnC,CAAC;qBAAM,CAAC;oBACN,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC;gBAC3B,CAAC;gBACD,MAAM;YACR,KAAK,WAAW;gBACd,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;oBAClB,OAAO,GAAG,IAAI,CAAC,oBAAoB,CAAC;gBACtC,CAAC;qBAAM,CAAC;oBACN,OAAO,GAAG,IAAI,CAAC,YAAY,CAAC;gBAC9B,CAAC;gBACD,MAAM;YACR,KAAK,UAAU;gBACb,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;oBAClB,OAAO,GAAG,IAAI,CAAC,mBAAmB,CAAC;gBACrC,CAAC;qBAAM,CAAC;oBACN,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC;gBAC7B,CAAC;gBACD,MAAM;YACR;gBACE,OAAO,GAAG,EAAE,CAAC;gBACb,MAAM;QACV,CAAC;QAED,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,uBAAuB,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;IACnE,CAAC;IAED,OAAO;QACL,IAAI,IAAI,CAAC,QAAQ,IAAI,KAAK,EAAE,CAAC;YAC3B,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;QAC5B,CAAC;IACH,CAAC;+GAjDU,mBAAmB;mGAAnB,mBAAmB,oLCXhC,wLAGS,qzDDIG,YAAY;;4FAIX,mBAAmB;kBAP/B,SAAS;+BACE,iBAAiB,cACf,IAAI,WACP,CAAC,YAAY,CAAC;iFAMd,QAAQ;sBAAhB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACI,aAAa;sBAAtB,MAAM","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\r\n\r\n@Component({\r\n  selector: 'ius-button-auth',\r\n  standalone: true,\r\n  imports: [CommonModule],\r\n  templateUrl: './button-auth.component.html',\r\n  styleUrl: './button-auth.component.scss'\r\n})\r\nexport class ButtonAuthComponent {\r\n\r\n  @Input() disabled = false;\r\n  @Input() textButton?: string;\r\n  @Output() buttonClicked: EventEmitter<void> = new EventEmitter();\r\n\r\n  colorDisabled: string = '#BFBFBF';\r\n\r\n  svg: SafeHtml = '';\r\n\r\n  constructor(private sanitizer: DomSanitizer) { }\r\n\r\n  ngOnInit() {\r\n    var svgIcon: string = '';\r\n\r\n    switch (this.textButton) {\r\n      case 'Google':\r\n        if (this.disabled) {\r\n          svgIcon = this.svgGoogleDisabled;\r\n        } else {\r\n          svgIcon = this.svgGoogle;\r\n        }\r\n        break;\r\n      case 'Microsoft':\r\n        if (this.disabled) {\r\n          svgIcon = this.svgMicrosoftDisabled;\r\n        } else {\r\n          svgIcon = this.svgMicrosoft;\r\n        }\r\n        break;\r\n      case 'LinkedIn':\r\n        if (this.disabled) {\r\n          svgIcon = this.svgLinkedinDisabled;\r\n        } else {\r\n          svgIcon = this.svgLinkedin;\r\n        }\r\n        break;\r\n      default:\r\n        svgIcon = '';\r\n        break;\r\n    }\r\n\r\n    this.svg = this.sanitizer.bypassSecurityTrustHtml(svgIcon) ?? '';\r\n  }\r\n\r\n  onClick() {\r\n    if (this.disabled == false) {\r\n      this.buttonClicked.emit();\r\n    }\r\n  }\r\n\r\n  svgGoogle: string = `<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n    <path d=\"M18.8 10.2084C18.8 9.55837 18.7417 8.93337 18.6333 8.33337H10V11.8834H14.9333C14.7167 13.025 14.0667 13.9917 13.0917 14.6417V16.95H16.0667C17.8 15.35 18.8 13 18.8 10.2084Z\" fill=\"#4285F4\"/>\r\n    <path d=\"M10 19.1667C12.475 19.1667 14.55 18.35 16.0667 16.95L13.0917 14.6417C12.275 15.1917 11.2333 15.525 10 15.525C7.61668 15.525 5.59168 13.9167 4.86668 11.75H1.81668V14.1167C3.32501 17.1083 6.41668 19.1667 10 19.1667Z\" fill=\"#34A853\"/>\r\n    <path d=\"M4.86668 11.7417C4.68334 11.1917 4.57501 10.6084 4.57501 10.0001C4.57501 9.39172 4.68334 8.80839 4.86668 8.25839V5.89172H1.81668C1.19168 7.12506 0.833344 8.51672 0.833344 10.0001C0.833344 11.4834 1.19168 12.8751 1.81668 14.1084L4.19168 12.2584L4.86668 11.7417Z\" fill=\"#FBBC05\"/>\r\n    <path d=\"M10 4.48337C11.35 4.48337 12.55 4.95004 13.5083 5.85004L16.1333 3.22504C14.5417 1.74171 12.475 0.833374 10 0.833374C6.41668 0.833374 3.32501 2.89171 1.81668 5.89171L4.86668 8.25837C5.59168 6.09171 7.61668 4.48337 10 4.48337Z\" fill=\"#EA4335\"/>\r\n  </svg>`;\r\n\r\n  svgGoogleDisabled: string = `<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n    <path d=\"M18.8 10.2084C18.8 9.55837 18.7417 8.93337 18.6333 8.33337H10V11.8834H14.9333C14.7167 13.025 14.0667 13.9917 13.0917 14.6417V16.95H16.0667C17.8 15.35 18.8 13 18.8 10.2084Z\" fill=\"#BFBFBF\"/>\r\n    <path d=\"M10 19.1667C12.475 19.1667 14.55 18.35 16.0667 16.95L13.0917 14.6417C12.275 15.1917 11.2333 15.525 10 15.525C7.61668 15.525 5.59168 13.9167 4.86668 11.75H1.81668V14.1167C3.32501 17.1083 6.41668 19.1667 10 19.1667Z\" fill=\"#BFBFBF\"/>\r\n    <path d=\"M4.86668 11.7417C4.68334 11.1917 4.57501 10.6084 4.57501 10.0001C4.57501 9.39172 4.68334 8.80839 4.86668 8.25839V5.89172H1.81668C1.19168 7.12506 0.833344 8.51672 0.833344 10.0001C0.833344 11.4834 1.19168 12.8751 1.81668 14.1084L4.19168 12.2584L4.86668 11.7417Z\" fill=\"#BFBFBF\"/>\r\n    <path d=\"M10 4.48337C11.35 4.48337 12.55 4.95004 13.5083 5.85004L16.1333 3.22504C14.5417 1.74171 12.475 0.833374 10 0.833374C6.41668 0.833374 3.32501 2.89171 1.81668 5.89171L4.86668 8.25837C5.59168 6.09171 7.61668 4.48337 10 4.48337Z\" fill=\"#BFBFBF\"/>\r\n  </svg>`;\r\n\r\n  svgMicrosoft: string = `<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n    <g clip-path=\"url(#clip0_1670_13811)\">\r\n      <path d=\"M0 0H20V20H0V0Z\" fill=\"#F3F3F3\"/>\r\n      <path d=\"M0.869568 0.869507H9.56522V9.56516H0.869568V0.869507Z\" fill=\"#F35325\"/>\r\n      <path d=\"M10.4348 0.869507H19.1304V9.56516H10.4348V0.869507Z\" fill=\"#81BC06\"/>\r\n      <path d=\"M0.869568 10.4348H9.56522V19.1305H0.869568V10.4348Z\" fill=\"#05A6F0\"/>\r\n      <path d=\"M10.4348 10.4348H19.1304V19.1305H10.4348V10.4348Z\" fill=\"#FFBA08\"/>\r\n    </g>\r\n    <defs>\r\n      <clipPath id=\"clip0_1670_13811\">\r\n        <rect width=\"20\" height=\"20\" fill=\"white\"/>\r\n      </clipPath>\r\n    </defs>\r\n  </svg>`;\r\n\r\n  svgMicrosoftDisabled: string = `<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n    <g clip-path=\"url(#clip0_1670_13817)\">\r\n      <path d=\"M0 0H20V20H0V0Z\" fill=\"#F3F3F3\"/>\r\n      <path d=\"M0.869568 0.869507H9.56522V9.56516H0.869568V0.869507Z\" fill=\"#BFBFBF\"/>\r\n      <path d=\"M10.4348 0.869507H19.1304V9.56516H10.4348V0.869507Z\" fill=\"#BFBFBF\"/>\r\n      <path d=\"M0.869568 10.4348H9.56522V19.1305H0.869568V10.4348Z\" fill=\"#BFBFBF\"/>\r\n      <path d=\"M10.4348 10.4348H19.1304V19.1305H10.4348V10.4348Z\" fill=\"#BFBFBF\"/>\r\n    </g>\r\n    <defs>\r\n      <clipPath id=\"clip0_1670_13817\">\r\n        <rect width=\"20\" height=\"20\" fill=\"white\"/>\r\n      </clipPath>\r\n    </defs>\r\n  </svg>`;\r\n\r\n  svgLinkedin: string = `<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n    <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M2.22222 20H17.7778C19.0051 20 20 19.0051 20 17.7778V2.22222C20 0.994923 19.0051 0 17.7778 0H2.22222C0.994923 0 0 0.994923 0 2.22222V17.7778C0 19.0051 0.994923 20 2.22222 20Z\" fill=\"#007EBB\"/>\r\n  </svg>`;\r\n\r\n  svgLinkedinDisabled: string = `<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n    <path fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M2.22222 20H17.7778C19.0051 20 20 19.0051 20 17.7778V2.22222C20 0.994923 19.0051 0 17.7778 0H2.22222C0.994923 0 0 0.994923 0 2.22222V17.7778C0 19.0051 0.994923 20 2.22222 20Z\" fill=\"#BFBFBF\"/>\r\n  </svg>`;\r\n}\r\n","<button class=\"ctn-button\" [disabled]=\"disabled\">\r\n    <span [innerHTML]=\"svg\" class=\"icon-btn\"></span>\r\n    <span class=\"label-base\">{{textButton}}</span>\r\n</button>"]}
|
|
@@ -0,0 +1,170 @@
|
|
|
1
|
+
import { Directive, ElementRef, Input, HostListener, inject, ViewContainerRef } from '@angular/core';
|
|
2
|
+
import { Overlay } from '@angular/cdk/overlay';
|
|
3
|
+
import { ComponentPortal } from '@angular/cdk/portal';
|
|
4
|
+
import { PopoverComponent } from '../popover/popover.component';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export class PopoverDirective {
|
|
7
|
+
constructor() {
|
|
8
|
+
this.overlay = inject(Overlay);
|
|
9
|
+
this.vcr = inject(ViewContainerRef);
|
|
10
|
+
this.hostEl = inject((ElementRef));
|
|
11
|
+
this.overHost = false;
|
|
12
|
+
this.overOverlay = false;
|
|
13
|
+
this.isOpen = false;
|
|
14
|
+
// Opcionales
|
|
15
|
+
this.iusPopoverPosition = ['right', 'left', 'top', 'bottom'];
|
|
16
|
+
this.iusPopoverOpenDelay = 400;
|
|
17
|
+
this.iusPopoverCloseDelay = 200;
|
|
18
|
+
}
|
|
19
|
+
// Eventos host
|
|
20
|
+
_enterHost() { this.overHost = true; this.show(); }
|
|
21
|
+
_focusHost() { this.overHost = true; this.show(); }
|
|
22
|
+
_leaveHost() { this.overHost = false; this.hide(); }
|
|
23
|
+
_blurHost() { this.overHost = false; this.hide(); }
|
|
24
|
+
ngOnDestroy() { this.dispose(); }
|
|
25
|
+
getPositions() {
|
|
26
|
+
const order = Array.isArray(this.iusPopoverPosition)
|
|
27
|
+
? this.iusPopoverPosition : [this.iusPopoverPosition];
|
|
28
|
+
const map = {
|
|
29
|
+
left: { originX: 'start', originY: 'center', overlayX: 'end', overlayY: 'center', offsetX: -10 },
|
|
30
|
+
right: { originX: 'end', originY: 'center', overlayX: 'start', overlayY: 'center', offsetX: 10 },
|
|
31
|
+
top: { originX: 'center', originY: 'top', overlayX: 'center', overlayY: 'bottom', offsetY: -10 },
|
|
32
|
+
bottom: { originX: 'center', originY: 'bottom', overlayX: 'center', overlayY: 'top', offsetY: 10 },
|
|
33
|
+
};
|
|
34
|
+
const all = ['left', 'right', 'top', 'bottom'].map(p => map[p]);
|
|
35
|
+
const preferred = order.map(p => map[p]).filter(Boolean);
|
|
36
|
+
return [...preferred, ...all];
|
|
37
|
+
}
|
|
38
|
+
ensureOverlay() {
|
|
39
|
+
if (this.overlayRef)
|
|
40
|
+
return this.overlayRef;
|
|
41
|
+
const strategy = this.overlay.position()
|
|
42
|
+
.flexibleConnectedTo(this.hostEl)
|
|
43
|
+
.withPositions(this.getPositions())
|
|
44
|
+
.withFlexibleDimensions(false)
|
|
45
|
+
.withViewportMargin(8)
|
|
46
|
+
.withPush(true);
|
|
47
|
+
this.overlayRef = this.overlay.create({
|
|
48
|
+
positionStrategy: strategy,
|
|
49
|
+
hasBackdrop: false,
|
|
50
|
+
panelClass: 'ius-popover-panel',
|
|
51
|
+
scrollStrategy: this.overlay.scrollStrategies.reposition(),
|
|
52
|
+
});
|
|
53
|
+
const el = this.overlayRef.overlayElement;
|
|
54
|
+
el.addEventListener('mouseenter', () => { this.overOverlay = true; clearTimeout(this.closeT); });
|
|
55
|
+
el.addEventListener('mouseleave', () => { this.overOverlay = false; this.hide(); });
|
|
56
|
+
// Cuando CDK re-posiciona, recalculamos el lado real y seteamos la clase de cola
|
|
57
|
+
strategy.positionChanges.subscribe(() => {
|
|
58
|
+
if (this.compRef && this.overlayRef) {
|
|
59
|
+
const cls = this.computeTailFromRects();
|
|
60
|
+
this.compRef.instance.positionClass = cls;
|
|
61
|
+
this.compRef.changeDetectorRef.markForCheck();
|
|
62
|
+
}
|
|
63
|
+
});
|
|
64
|
+
return this.overlayRef;
|
|
65
|
+
}
|
|
66
|
+
// Decide el lado de la cola comparando rects reales del host vs overlay
|
|
67
|
+
computeTailFromRects() {
|
|
68
|
+
const host = this.hostEl.nativeElement.getBoundingClientRect();
|
|
69
|
+
const pane = this.overlayRef.overlayElement.getBoundingClientRect();
|
|
70
|
+
const dLeft = Math.abs(pane.right - host.left); // popover a la IZQUIERDA
|
|
71
|
+
const dRight = Math.abs(pane.left - host.right); // popover a la DERECHA
|
|
72
|
+
const dTop = Math.abs(pane.bottom - host.top); // popover ARRIBA
|
|
73
|
+
const dBot = Math.abs(pane.top - host.bottom); // popover ABAJO
|
|
74
|
+
const min = Math.min(dLeft, dRight, dTop, dBot);
|
|
75
|
+
if (min === dRight)
|
|
76
|
+
return 'tail-left'; // popover a la DERECHA -> cola IZQUIERDA
|
|
77
|
+
if (min === dLeft)
|
|
78
|
+
return 'tail-right'; // popover a la IZQUIERDA -> cola DERECHA
|
|
79
|
+
if (min === dBot)
|
|
80
|
+
return 'tail-top'; // popover ABAJO -> cola ARRIBA
|
|
81
|
+
return 'tail-bottom'; // popover ARRIBA -> cola ABAJO
|
|
82
|
+
}
|
|
83
|
+
show() {
|
|
84
|
+
clearTimeout(this.closeT);
|
|
85
|
+
if (this.isOpen)
|
|
86
|
+
return;
|
|
87
|
+
this.openT = setTimeout(() => {
|
|
88
|
+
const overlayRef = this.ensureOverlay();
|
|
89
|
+
if (!this.portal)
|
|
90
|
+
this.portal = new ComponentPortal(PopoverComponent, this.vcr);
|
|
91
|
+
if (!overlayRef.hasAttached()) {
|
|
92
|
+
this.compRef = overlayRef.attach(this.portal);
|
|
93
|
+
this.compRef.instance.label = this.data?.title ?? this.title ?? '';
|
|
94
|
+
this.compRef.instance.content = this.data?.content ?? this.content ?? '';
|
|
95
|
+
}
|
|
96
|
+
overlayRef.updatePosition();
|
|
97
|
+
// Tras el layout real, calculamos la cola exacta
|
|
98
|
+
setTimeout(() => {
|
|
99
|
+
if (this.compRef && this.overlayRef) {
|
|
100
|
+
this.compRef.instance.positionClass = this.computeTailFromRects();
|
|
101
|
+
this.compRef.changeDetectorRef.markForCheck();
|
|
102
|
+
}
|
|
103
|
+
});
|
|
104
|
+
this.isOpen = true;
|
|
105
|
+
}, this.iusPopoverOpenDelay);
|
|
106
|
+
}
|
|
107
|
+
hide() {
|
|
108
|
+
clearTimeout(this.openT);
|
|
109
|
+
if (this.overHost || this.overOverlay)
|
|
110
|
+
return;
|
|
111
|
+
this.closeT = setTimeout(() => {
|
|
112
|
+
if (this.overlayRef?.hasAttached())
|
|
113
|
+
this.overlayRef.detach();
|
|
114
|
+
this.isOpen = false;
|
|
115
|
+
this.compRef = undefined;
|
|
116
|
+
}, this.iusPopoverCloseDelay);
|
|
117
|
+
}
|
|
118
|
+
forceClose() {
|
|
119
|
+
this.overHost = this.overOverlay = false;
|
|
120
|
+
clearTimeout(this.openT);
|
|
121
|
+
clearTimeout(this.closeT);
|
|
122
|
+
if (this.overlayRef?.hasAttached())
|
|
123
|
+
this.overlayRef.detach();
|
|
124
|
+
this.isOpen = false;
|
|
125
|
+
this.compRef = undefined;
|
|
126
|
+
}
|
|
127
|
+
dispose() {
|
|
128
|
+
this.forceClose();
|
|
129
|
+
this.overlayRef?.dispose();
|
|
130
|
+
this.overlayRef = undefined;
|
|
131
|
+
}
|
|
132
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PopoverDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
133
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: PopoverDirective, isStandalone: true, selector: "[iusPopover], [iusPopoverTitle], [iusPopoverContent]", inputs: { data: ["iusPopover", "data"], title: ["iusPopoverTitle", "title"], content: ["iusPopoverContent", "content"], iusPopoverPosition: "iusPopoverPosition", iusPopoverOpenDelay: "iusPopoverOpenDelay", iusPopoverCloseDelay: "iusPopoverCloseDelay" }, host: { listeners: { "keydown.Escape": "forceClose()", "mouseenter": "_enterHost()", "focusin": "_focusHost()", "mouseleave": "_leaveHost()", "focusout": "_blurHost()" } }, ngImport: i0 }); }
|
|
134
|
+
}
|
|
135
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: PopoverDirective, decorators: [{
|
|
136
|
+
type: Directive,
|
|
137
|
+
args: [{
|
|
138
|
+
selector: '[iusPopover], [iusPopoverTitle], [iusPopoverContent]',
|
|
139
|
+
standalone: true,
|
|
140
|
+
host: { '(keydown.Escape)': 'forceClose()' }
|
|
141
|
+
}]
|
|
142
|
+
}], propDecorators: { data: [{
|
|
143
|
+
type: Input,
|
|
144
|
+
args: ['iusPopover']
|
|
145
|
+
}], title: [{
|
|
146
|
+
type: Input,
|
|
147
|
+
args: ['iusPopoverTitle']
|
|
148
|
+
}], content: [{
|
|
149
|
+
type: Input,
|
|
150
|
+
args: ['iusPopoverContent']
|
|
151
|
+
}], iusPopoverPosition: [{
|
|
152
|
+
type: Input
|
|
153
|
+
}], iusPopoverOpenDelay: [{
|
|
154
|
+
type: Input
|
|
155
|
+
}], iusPopoverCloseDelay: [{
|
|
156
|
+
type: Input
|
|
157
|
+
}], _enterHost: [{
|
|
158
|
+
type: HostListener,
|
|
159
|
+
args: ['mouseenter']
|
|
160
|
+
}], _focusHost: [{
|
|
161
|
+
type: HostListener,
|
|
162
|
+
args: ['focusin']
|
|
163
|
+
}], _leaveHost: [{
|
|
164
|
+
type: HostListener,
|
|
165
|
+
args: ['mouseleave']
|
|
166
|
+
}], _blurHost: [{
|
|
167
|
+
type: HostListener,
|
|
168
|
+
args: ['focusout']
|
|
169
|
+
}] } });
|
|
170
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.directive.js","sourceRoot":"","sources":["../../../../../projects/ius-design-components/src/lib/directives/popover.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Input, OnDestroy, HostListener, inject, ViewContainerRef, ComponentRef } from '@angular/core';\r\nimport { Overlay, OverlayRef, ConnectedPosition, FlexibleConnectedPositionStrategy, OverlayModule } from '@angular/cdk/overlay';\r\nimport { ComponentPortal, PortalModule } from '@angular/cdk/portal';\r\nimport { PopoverComponent } from '../popover/popover.component';\r\n\r\ntype PrefPos = 'left' | 'right' | 'top' | 'bottom';\r\n\r\n@Directive({\r\n  selector: '[iusPopover], [iusPopoverTitle], [iusPopoverContent]',\r\n  standalone: true,\r\n  host: { '(keydown.Escape)': 'forceClose()' }\r\n})\r\nexport class PopoverDirective implements OnDestroy {\r\n  private overlay = inject(Overlay);\r\n  private vcr = inject(ViewContainerRef);\r\n  private hostEl = inject(ElementRef<HTMLElement>);\r\n  private overlayRef?: OverlayRef;\r\n  private portal?: ComponentPortal<PopoverComponent>;\r\n  private compRef?: ComponentRef<PopoverComponent>;\r\n\r\n  private openT?: any;\r\n  private closeT?: any;\r\n  private overHost = false;\r\n  private overOverlay = false;\r\n  private isOpen = false;\r\n\r\n  // API simple\r\n  @Input('iusPopover') data?: { title?: string; content?: string };\r\n  @Input('iusPopoverTitle') title?: string;\r\n  @Input('iusPopoverContent') content?: string;\r\n\r\n  // Opcionales\r\n  @Input() iusPopoverPosition: PrefPos | PrefPos[] = ['right','left','top','bottom'];\r\n  @Input() iusPopoverOpenDelay = 400;\r\n  @Input() iusPopoverCloseDelay = 200;\r\n\r\n  // Eventos host\r\n  @HostListener('mouseenter') _enterHost() { this.overHost = true; this.show(); }\r\n  @HostListener('focusin') _focusHost() { this.overHost = true; this.show(); }\r\n  @HostListener('mouseleave') _leaveHost() { this.overHost = false; this.hide(); }\r\n  @HostListener('focusout') _blurHost() { this.overHost = false; this.hide(); }\r\n\r\n  ngOnDestroy() { this.dispose(); }\r\n\r\n  getPositions(): ConnectedPosition[] {\r\n    const order: PrefPos[] = Array.isArray(this.iusPopoverPosition)\r\n      ? this.iusPopoverPosition : [this.iusPopoverPosition];\r\n\r\n    const map: Record<PrefPos, ConnectedPosition> = {\r\n      left: { originX: 'start', originY: 'center', overlayX: 'end', overlayY: 'center', offsetX: -10 },\r\n      right: { originX: 'end', originY: 'center', overlayX: 'start', overlayY: 'center', offsetX: 10 },\r\n      top: { originX: 'center', originY: 'top', overlayX: 'center', overlayY: 'bottom', offsetY: -10 },\r\n      bottom: { originX: 'center', originY: 'bottom', overlayX: 'center', overlayY: 'top', offsetY: 10 },\r\n    };\r\n\r\n    const all = ['left', 'right', 'top', 'bottom'].map(p => map[p as PrefPos]);\r\n    const preferred = order.map(p => map[p]).filter(Boolean);\r\n    return [...preferred, ...all];\r\n  }\r\n\r\n  ensureOverlay(): OverlayRef {\r\n    if (this.overlayRef) return this.overlayRef;\r\n\r\n    const strategy: FlexibleConnectedPositionStrategy = this.overlay.position()\r\n      .flexibleConnectedTo(this.hostEl)\r\n      .withPositions(this.getPositions())\r\n      .withFlexibleDimensions(false)\r\n      .withViewportMargin(8)\r\n      .withPush(true);\r\n\r\n    this.overlayRef = this.overlay.create({\r\n      positionStrategy: strategy,\r\n      hasBackdrop: false,\r\n      panelClass: 'ius-popover-panel',\r\n      scrollStrategy: this.overlay.scrollStrategies.reposition(),\r\n    });\r\n\r\n    const el = this.overlayRef.overlayElement;\r\n    el.addEventListener('mouseenter', () => { this.overOverlay = true; clearTimeout(this.closeT); });\r\n    el.addEventListener('mouseleave', () => { this.overOverlay = false; this.hide(); });\r\n\r\n    // Cuando CDK re-posiciona, recalculamos el lado real y seteamos la clase de cola\r\n    strategy.positionChanges.subscribe(() => {\r\n      if (this.compRef && this.overlayRef) {\r\n        const cls = this.computeTailFromRects();\r\n        this.compRef.instance.positionClass = cls;\r\n        this.compRef.changeDetectorRef.markForCheck();\r\n      }\r\n    });\r\n\r\n    return this.overlayRef;\r\n  }\r\n\r\n  // Decide el lado de la cola comparando rects reales del host vs overlay\r\n  computeTailFromRects(): 'tail-left' | 'tail-right' | 'tail-top' | 'tail-bottom' {\r\n    const host = this.hostEl.nativeElement.getBoundingClientRect();\r\n    const pane = this.overlayRef!.overlayElement.getBoundingClientRect();\r\n\r\n    const dLeft = Math.abs(pane.right - host.left);    // popover a la IZQUIERDA\r\n    const dRight = Math.abs(pane.left - host.right);   // popover a la DERECHA\r\n    const dTop = Math.abs(pane.bottom - host.top);     // popover ARRIBA\r\n    const dBot = Math.abs(pane.top - host.bottom);  // popover ABAJO\r\n\r\n    const min = Math.min(dLeft, dRight, dTop, dBot);\r\n    if (min === dRight) return 'tail-left';   // popover a la DERECHA -> cola IZQUIERDA\r\n    if (min === dLeft) return 'tail-right';  // popover a la IZQUIERDA -> cola DERECHA\r\n    if (min === dBot) return 'tail-top';    // popover ABAJO -> cola ARRIBA\r\n    return 'tail-bottom';                     // popover ARRIBA -> cola ABAJO\r\n  }\r\n\r\n  show(): void {\r\n    clearTimeout(this.closeT);\r\n    if (this.isOpen) return;\r\n\r\n    this.openT = setTimeout(() => {\r\n      const overlayRef = this.ensureOverlay();\r\n      if (!this.portal) this.portal = new ComponentPortal(PopoverComponent, this.vcr);\r\n\r\n      if (!overlayRef.hasAttached()) {\r\n        this.compRef = overlayRef.attach(this.portal);\r\n        this.compRef.instance.label = this.data?.title ?? this.title ?? '';\r\n        this.compRef.instance.content = this.data?.content ?? this.content ?? '';\r\n      }\r\n\r\n      overlayRef.updatePosition();\r\n\r\n      // Tras el layout real, calculamos la cola exacta\r\n      setTimeout(() => {\r\n        if (this.compRef && this.overlayRef) {\r\n          this.compRef.instance.positionClass = this.computeTailFromRects();\r\n          this.compRef.changeDetectorRef.markForCheck();\r\n        }\r\n      });\r\n\r\n      this.isOpen = true;\r\n    }, this.iusPopoverOpenDelay);\r\n  }\r\n\r\n  hide(): void {\r\n    clearTimeout(this.openT);\r\n    if (this.overHost || this.overOverlay) return;\r\n\r\n    this.closeT = setTimeout(() => {\r\n      if (this.overlayRef?.hasAttached()) this.overlayRef.detach();\r\n      this.isOpen = false;\r\n      this.compRef = undefined;\r\n    }, this.iusPopoverCloseDelay);\r\n  }\r\n\r\n  forceClose() {\r\n    this.overHost = this.overOverlay = false;\r\n    clearTimeout(this.openT);\r\n    clearTimeout(this.closeT);\r\n    if (this.overlayRef?.hasAttached()) this.overlayRef.detach();\r\n    this.isOpen = false;\r\n    this.compRef = undefined;\r\n  }\r\n\r\n  dispose() {\r\n    this.forceClose();\r\n    this.overlayRef?.dispose();\r\n    this.overlayRef = undefined;\r\n  }\r\n}\r\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './input-otp.component';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9pdXMtZGVzaWduLWNvbXBvbmVudHMvc3JjL2xpYi9pbnB1dC1vdHAvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx1QkFBdUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vaW5wdXQtb3RwLmNvbXBvbmVudCc7XHJcblxyXG4iXX0=
|
|
@@ -0,0 +1,173 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output, ViewChildren } from '@angular/core';
|
|
2
|
+
import { IconMdComponent } from '../icon-md/icon-md.component';
|
|
3
|
+
import { CommonModule } from '@angular/common';
|
|
4
|
+
import { FormsModule } from '@angular/forms';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/common";
|
|
7
|
+
export class InputOtpComponent {
|
|
8
|
+
constructor() {
|
|
9
|
+
this.length = 6;
|
|
10
|
+
this.disabled = false;
|
|
11
|
+
this.showHelpText = false;
|
|
12
|
+
this.required = true;
|
|
13
|
+
this.onChangesValueEvent = new EventEmitter();
|
|
14
|
+
this.codeComplete = new EventEmitter(); // cuando se llenan todas las casillas
|
|
15
|
+
this.values = [];
|
|
16
|
+
this.focusedIndex = null;
|
|
17
|
+
this.isAlertText = false;
|
|
18
|
+
}
|
|
19
|
+
get isAnyFocused() { return this.focusedIndex !== null; }
|
|
20
|
+
get boxes() { return Array.from({ length: this.length }); }
|
|
21
|
+
get code() { return this.values.join(''); }
|
|
22
|
+
ngOnInit() {
|
|
23
|
+
this.values = Array(this.length).fill('');
|
|
24
|
+
}
|
|
25
|
+
clearSearch() {
|
|
26
|
+
this.values.fill('');
|
|
27
|
+
this.emitChange();
|
|
28
|
+
this.isAlertText = this.required;
|
|
29
|
+
this.focusIndex(0);
|
|
30
|
+
}
|
|
31
|
+
onFocus(index) {
|
|
32
|
+
this.focusedIndex = index;
|
|
33
|
+
this.isAlertText = false;
|
|
34
|
+
}
|
|
35
|
+
onBlur() {
|
|
36
|
+
this.focusedIndex = null;
|
|
37
|
+
if (this.required) {
|
|
38
|
+
this.isAlertText = this.code.length !== this.length;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
// Restringe a dígitos y mueve el foco
|
|
42
|
+
onInputBox(e, index) {
|
|
43
|
+
const inputEvent = e;
|
|
44
|
+
const input = inputEvent.target;
|
|
45
|
+
const raw = (input.value || '').replace(/\D/g, '');
|
|
46
|
+
// Nos quedamos con el último dígito si escribió varios
|
|
47
|
+
const char = raw.slice(-1);
|
|
48
|
+
this.values[index] = char ?? '';
|
|
49
|
+
input.value = this.values[index];
|
|
50
|
+
// Avanza si hay valor
|
|
51
|
+
if (char && index < this.length - 1)
|
|
52
|
+
this.focusIndex(index + 1);
|
|
53
|
+
this.emitChange();
|
|
54
|
+
// Si escribió múltiples (p.ej. autofill) distribuye
|
|
55
|
+
if (raw.length > 1)
|
|
56
|
+
this.spreadFrom(index, raw);
|
|
57
|
+
}
|
|
58
|
+
// Teclas especiales: backspace, flechas, delete
|
|
59
|
+
onKeyDown(event, index) {
|
|
60
|
+
const key = event.key;
|
|
61
|
+
if (!/^[0-9]$/.test(key) &&
|
|
62
|
+
!['Backspace', 'ArrowLeft', 'ArrowRight', 'Delete', 'Tab'].includes(key)) {
|
|
63
|
+
event.preventDefault();
|
|
64
|
+
return;
|
|
65
|
+
}
|
|
66
|
+
if (key === 'Backspace') {
|
|
67
|
+
if (this.values[index]) {
|
|
68
|
+
this.values[index] = '';
|
|
69
|
+
this.emitChange();
|
|
70
|
+
}
|
|
71
|
+
else if (index > 0) {
|
|
72
|
+
this.focusIndex(index - 1);
|
|
73
|
+
// limpia la anterior para UX tipo “focused-error”
|
|
74
|
+
const prev = this.otpInputs.get(index - 1)?.nativeElement;
|
|
75
|
+
if (prev) {
|
|
76
|
+
prev.value = '';
|
|
77
|
+
this.values[index - 1] = '';
|
|
78
|
+
this.emitChange();
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
event.preventDefault();
|
|
82
|
+
return;
|
|
83
|
+
}
|
|
84
|
+
if (key === 'Delete') {
|
|
85
|
+
this.values[index] = '';
|
|
86
|
+
this.emitChange();
|
|
87
|
+
event.preventDefault();
|
|
88
|
+
return;
|
|
89
|
+
}
|
|
90
|
+
if (key === 'ArrowLeft' && index > 0) {
|
|
91
|
+
this.focusIndex(index - 1);
|
|
92
|
+
event.preventDefault();
|
|
93
|
+
return;
|
|
94
|
+
}
|
|
95
|
+
if (key === 'ArrowRight' && index < this.length - 1) {
|
|
96
|
+
this.focusIndex(index + 1);
|
|
97
|
+
event.preventDefault();
|
|
98
|
+
return;
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
// Pegar un código completo
|
|
102
|
+
onPaste(event) {
|
|
103
|
+
if (this.disabled)
|
|
104
|
+
return;
|
|
105
|
+
event.preventDefault();
|
|
106
|
+
const data = (event.clipboardData?.getData('text') || '').replace(/\D/g, '').slice(0, this.length);
|
|
107
|
+
if (!data)
|
|
108
|
+
return;
|
|
109
|
+
const start = this.focusedIndex ?? 0;
|
|
110
|
+
this.spreadFrom(start, data);
|
|
111
|
+
this.emitChange();
|
|
112
|
+
}
|
|
113
|
+
/** Distribuye una cadena a partir de un índice */
|
|
114
|
+
spreadFrom(startIndex, data) {
|
|
115
|
+
let i = startIndex;
|
|
116
|
+
for (const ch of data) {
|
|
117
|
+
if (i >= this.length)
|
|
118
|
+
break;
|
|
119
|
+
this.values[i] = ch;
|
|
120
|
+
const el = this.otpInputs.get(i)?.nativeElement;
|
|
121
|
+
if (el)
|
|
122
|
+
el.value = ch;
|
|
123
|
+
i++;
|
|
124
|
+
}
|
|
125
|
+
// Enfoca siguiente libre o se queda en el último
|
|
126
|
+
const nextFree = this.values.findIndex((v, idx) => v === '' && idx >= startIndex);
|
|
127
|
+
this.focusIndex(nextFree === -1 ? this.length - 1 : nextFree);
|
|
128
|
+
}
|
|
129
|
+
/** Enfoca por índice de forma segura */
|
|
130
|
+
focusIndex(i) {
|
|
131
|
+
setTimeout(() => {
|
|
132
|
+
const el = this.otpInputs?.get(i)?.nativeElement;
|
|
133
|
+
if (el)
|
|
134
|
+
el.focus();
|
|
135
|
+
this.focusedIndex = i;
|
|
136
|
+
});
|
|
137
|
+
}
|
|
138
|
+
/** Emite cambios y dispara codeComplete si procede */
|
|
139
|
+
emitChange() {
|
|
140
|
+
const code = this.code;
|
|
141
|
+
this.onChangesValueEvent.emit(code);
|
|
142
|
+
if (code.length === this.length) {
|
|
143
|
+
this.isAlertText = false;
|
|
144
|
+
this.codeComplete.emit(code);
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: InputOtpComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
148
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: InputOtpComponent, isStandalone: true, selector: "ius-input-otp", inputs: { length: "length", disabled: "disabled", showHelpText: "showHelpText", labelSuperior: "labelSuperior", labelInferior: "labelInferior", required: "required" }, outputs: { onChangesValueEvent: "onChangesValueEvent", codeComplete: "codeComplete" }, viewQueries: [{ propertyName: "otpInputs", predicate: ["otpInput"], descendants: true }], ngImport: i0, template: "<div class=\"container-general\">\r\n @if (labelSuperior) {\r\n <div class=\"container-label-sup\" [ngClass]=\"{ 'disabled': disabled }\">\r\n @if(!disabled && required){ <div class=\"icon-dot\"></div> }\r\n <span>{{ labelSuperior }}</span>\r\n @if(!disabled && showHelpText){\r\n <ius-icon-md iconName=\"icon-help\" class=\"icon-color-help\"></ius-icon-md>\r\n }\r\n <span>:</span>\r\n </div>\r\n }\r\n\r\n <div class=\"container-otp\">\r\n <!-- Casillas OTP -->\r\n <div class=\"otp-grid\">\r\n @for (ctrl of boxes; track $index) {\r\n <div\r\n class=\"container-textfield\"\r\n [ngClass]=\"{\r\n 'disabled': disabled,\r\n 'focused': focusedIndex === $index,\r\n 'alert': !disabled && isAlertText\r\n }\"\r\n >\r\n <input\r\n #otpInput\r\n type=\"text\"\r\n inputmode=\"numeric\"\r\n pattern=\"[0-9]*\"\r\n maxlength=\"1\"\r\n [disabled]=\"disabled\"\r\n [value]=\"values[$index]\"\r\n (focus)=\"onFocus($index)\"\r\n (blur)=\"onBlur()\"\r\n (keydown)=\"onKeyDown($event, $index)\"\r\n (input)=\"onInputBox($event, $index)\"\r\n (paste)=\"onPaste($event)\"\r\n />\r\n </div>\r\n }\r\n </div>\r\n\r\n @if (!disabled && this.code.length > 0 ) {\r\n <button class=\"button-delete\" (click)=\"clearSearch()\" [ngClass]=\"{\r\n 'alert': !disabled && isAlertText\r\n }\">\r\n <ius-icon-md iconName=\"icon-cancel\" class=\"icon-color-cancel\" [ngClass]=\"{\r\n 'alert': !disabled && isAlertText\r\n }\"></ius-icon-md>\r\n </button>\r\n }\r\n </div>\r\n\r\n @if (labelInferior && isAnyFocused) {\r\n <span class=\"label-inf\">{{ labelInferior }}</span>\r\n }\r\n @if (labelInferior && !isAnyFocused && isAlertText) {\r\n <span class=\"label-inf\" [ngClass]=\"{ 'alert': isAlertText }\">{{ labelInferior }}</span>\r\n }\r\n</div>\r\n", styles: [".h1{font-family:Roboto,sans-serif;font-size:2.375rem;font-weight:500;line-height:46px}.h2{font-family:Roboto,sans-serif;font-size:1.875rem;font-weight:700;line-height:38px}.h3{font-family:Roboto,sans-serif;font-size:1.5rem;font-weight:500;line-height:32px}.h4{font-family:Roboto,sans-serif;font-size:1.25rem;font-weight:700;line-height:26px}.h5{font-family:Roboto,sans-serif;font-size:1.125rem;font-weight:500;line-height:24px;letter-spacing:.18px}.label-large{font-family:Roboto,sans-serif;font-size:1rem;font-weight:500;line-height:22px}.body-large{font-family:Rubik,sans-serif;font-size:1rem;font-weight:400;line-height:22px}.label-base{font-family:Rubik,sans-serif;font-size:.875rem;font-weight:500;line-height:20px;letter-spacing:.28px}.body-base{font-family:Rubik,sans-serif;font-size:.875rem;font-weight:400;line-height:20px;font-style:italic;letter-spacing:.28px}.body-sm{font-family:Rubik,sans-serif;font-size:.75rem;font-weight:400;line-height:16px;letter-spacing:.28px}.body-sm-italic{font-family:Rubik,sans-serif;font-size:.75rem;font-weight:400;line-height:16px;font-style:italic;letter-spacing:.28px}.caption-sm{font-family:Rubik,sans-serif;font-size:.75rem;font-weight:500;line-height:16px;letter-spacing:.28px}.caption-sm-italic{font-family:Rubik,sans-serif;font-size:.75rem;font-weight:500;line-height:16px;font-style:italic;letter-spacing:.28px}.container-general{position:relative;height:100%}.container-otp{display:flex;align-items:center;gap:8px}.otp-grid{display:flex;gap:4px}.otp-grid:hover .container-textfield:not(.disabled){background:#edf6ff;border:1px solid #EDF6FF}.container-textfield{display:inline-flex;width:40px;height:40px;border:1px solid #f5f5f5;border-radius:8px;background:#f5f5f5;transition:all .15s ease-in-out}.container-textfield:hover:not(.disabled):not(.focused):not(.alert){background:#edf6ff;border:1px solid #EDF6FF}.container-textfield.focused{border:1px solid #0581BC;background:#edf6ff}.container-textfield.alert{border:1px solid #DB2E2A;background:#fff4f0}.container-textfield.disabled{background:#f5f5f5}.container-textfield input{width:100%;height:100%;border:none;outline:none;text-align:center;background:transparent;color:#8c8c8c;font-family:Rubik,sans-serif;font-size:.875rem;line-height:20px;letter-spacing:.28px}.container-textfield input::-webkit-outer-spin-button,.container-textfield input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.button-delete{display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;padding:0;color:#595959}.container-label-sup{display:flex;align-items:center;gap:4px;margin-bottom:8px;color:#333;font-family:Roboto,sans-serif;font-size:.875rem;font-weight:500;line-height:20px;letter-spacing:.28px}.container-label-sup.disabled{color:#bfbfbf}.icon-dot{width:4px;height:4px;background-color:#db2e2a;border-radius:100px}.icon-color-help{color:#8c8c8c}.icon-color-cancel{color:#013169}.icon-color-cancel.alert{color:#b71d26}.label-inf{position:absolute;margin-top:4px;color:#595959;font-family:Roboto,sans-serif;font-size:.75rem;font-style:italic;font-weight:500;line-height:16px;letter-spacing:.24px}.label-inf.alert{color:#931224}\n"], dependencies: [{ kind: "component", type: IconMdComponent, selector: "ius-icon-md", inputs: ["iconName", "color"] }, { kind: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] }); }
|
|
149
|
+
}
|
|
150
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: InputOtpComponent, decorators: [{
|
|
151
|
+
type: Component,
|
|
152
|
+
args: [{ selector: 'ius-input-otp', standalone: true, imports: [IconMdComponent, FormsModule, CommonModule], template: "<div class=\"container-general\">\r\n @if (labelSuperior) {\r\n <div class=\"container-label-sup\" [ngClass]=\"{ 'disabled': disabled }\">\r\n @if(!disabled && required){ <div class=\"icon-dot\"></div> }\r\n <span>{{ labelSuperior }}</span>\r\n @if(!disabled && showHelpText){\r\n <ius-icon-md iconName=\"icon-help\" class=\"icon-color-help\"></ius-icon-md>\r\n }\r\n <span>:</span>\r\n </div>\r\n }\r\n\r\n <div class=\"container-otp\">\r\n <!-- Casillas OTP -->\r\n <div class=\"otp-grid\">\r\n @for (ctrl of boxes; track $index) {\r\n <div\r\n class=\"container-textfield\"\r\n [ngClass]=\"{\r\n 'disabled': disabled,\r\n 'focused': focusedIndex === $index,\r\n 'alert': !disabled && isAlertText\r\n }\"\r\n >\r\n <input\r\n #otpInput\r\n type=\"text\"\r\n inputmode=\"numeric\"\r\n pattern=\"[0-9]*\"\r\n maxlength=\"1\"\r\n [disabled]=\"disabled\"\r\n [value]=\"values[$index]\"\r\n (focus)=\"onFocus($index)\"\r\n (blur)=\"onBlur()\"\r\n (keydown)=\"onKeyDown($event, $index)\"\r\n (input)=\"onInputBox($event, $index)\"\r\n (paste)=\"onPaste($event)\"\r\n />\r\n </div>\r\n }\r\n </div>\r\n\r\n @if (!disabled && this.code.length > 0 ) {\r\n <button class=\"button-delete\" (click)=\"clearSearch()\" [ngClass]=\"{\r\n 'alert': !disabled && isAlertText\r\n }\">\r\n <ius-icon-md iconName=\"icon-cancel\" class=\"icon-color-cancel\" [ngClass]=\"{\r\n 'alert': !disabled && isAlertText\r\n }\"></ius-icon-md>\r\n </button>\r\n }\r\n </div>\r\n\r\n @if (labelInferior && isAnyFocused) {\r\n <span class=\"label-inf\">{{ labelInferior }}</span>\r\n }\r\n @if (labelInferior && !isAnyFocused && isAlertText) {\r\n <span class=\"label-inf\" [ngClass]=\"{ 'alert': isAlertText }\">{{ labelInferior }}</span>\r\n }\r\n</div>\r\n", styles: [".h1{font-family:Roboto,sans-serif;font-size:2.375rem;font-weight:500;line-height:46px}.h2{font-family:Roboto,sans-serif;font-size:1.875rem;font-weight:700;line-height:38px}.h3{font-family:Roboto,sans-serif;font-size:1.5rem;font-weight:500;line-height:32px}.h4{font-family:Roboto,sans-serif;font-size:1.25rem;font-weight:700;line-height:26px}.h5{font-family:Roboto,sans-serif;font-size:1.125rem;font-weight:500;line-height:24px;letter-spacing:.18px}.label-large{font-family:Roboto,sans-serif;font-size:1rem;font-weight:500;line-height:22px}.body-large{font-family:Rubik,sans-serif;font-size:1rem;font-weight:400;line-height:22px}.label-base{font-family:Rubik,sans-serif;font-size:.875rem;font-weight:500;line-height:20px;letter-spacing:.28px}.body-base{font-family:Rubik,sans-serif;font-size:.875rem;font-weight:400;line-height:20px;font-style:italic;letter-spacing:.28px}.body-sm{font-family:Rubik,sans-serif;font-size:.75rem;font-weight:400;line-height:16px;letter-spacing:.28px}.body-sm-italic{font-family:Rubik,sans-serif;font-size:.75rem;font-weight:400;line-height:16px;font-style:italic;letter-spacing:.28px}.caption-sm{font-family:Rubik,sans-serif;font-size:.75rem;font-weight:500;line-height:16px;letter-spacing:.28px}.caption-sm-italic{font-family:Rubik,sans-serif;font-size:.75rem;font-weight:500;line-height:16px;font-style:italic;letter-spacing:.28px}.container-general{position:relative;height:100%}.container-otp{display:flex;align-items:center;gap:8px}.otp-grid{display:flex;gap:4px}.otp-grid:hover .container-textfield:not(.disabled){background:#edf6ff;border:1px solid #EDF6FF}.container-textfield{display:inline-flex;width:40px;height:40px;border:1px solid #f5f5f5;border-radius:8px;background:#f5f5f5;transition:all .15s ease-in-out}.container-textfield:hover:not(.disabled):not(.focused):not(.alert){background:#edf6ff;border:1px solid #EDF6FF}.container-textfield.focused{border:1px solid #0581BC;background:#edf6ff}.container-textfield.alert{border:1px solid #DB2E2A;background:#fff4f0}.container-textfield.disabled{background:#f5f5f5}.container-textfield input{width:100%;height:100%;border:none;outline:none;text-align:center;background:transparent;color:#8c8c8c;font-family:Rubik,sans-serif;font-size:.875rem;line-height:20px;letter-spacing:.28px}.container-textfield input::-webkit-outer-spin-button,.container-textfield input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.button-delete{display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;padding:0;color:#595959}.container-label-sup{display:flex;align-items:center;gap:4px;margin-bottom:8px;color:#333;font-family:Roboto,sans-serif;font-size:.875rem;font-weight:500;line-height:20px;letter-spacing:.28px}.container-label-sup.disabled{color:#bfbfbf}.icon-dot{width:4px;height:4px;background-color:#db2e2a;border-radius:100px}.icon-color-help{color:#8c8c8c}.icon-color-cancel{color:#013169}.icon-color-cancel.alert{color:#b71d26}.label-inf{position:absolute;margin-top:4px;color:#595959;font-family:Roboto,sans-serif;font-size:.75rem;font-style:italic;font-weight:500;line-height:16px;letter-spacing:.24px}.label-inf.alert{color:#931224}\n"] }]
|
|
153
|
+
}], propDecorators: { length: [{
|
|
154
|
+
type: Input
|
|
155
|
+
}], disabled: [{
|
|
156
|
+
type: Input
|
|
157
|
+
}], showHelpText: [{
|
|
158
|
+
type: Input
|
|
159
|
+
}], labelSuperior: [{
|
|
160
|
+
type: Input
|
|
161
|
+
}], labelInferior: [{
|
|
162
|
+
type: Input
|
|
163
|
+
}], required: [{
|
|
164
|
+
type: Input
|
|
165
|
+
}], onChangesValueEvent: [{
|
|
166
|
+
type: Output
|
|
167
|
+
}], codeComplete: [{
|
|
168
|
+
type: Output
|
|
169
|
+
}], otpInputs: [{
|
|
170
|
+
type: ViewChildren,
|
|
171
|
+
args: ['otpInput']
|
|
172
|
+
}] } });
|
|
173
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-otp.component.js","sourceRoot":"","sources":["../../../../../projects/ius-design-components/src/lib/input-otp/input-otp.component.ts","../../../../../projects/ius-design-components/src/lib/input-otp/input-otp.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output, ViewChildren, QueryList, ElementRef } from '@angular/core';\r\nimport { IconMdComponent } from '../icon-md/icon-md.component';\r\nimport { CommonModule } from '@angular/common';\r\nimport { FormsModule } from '@angular/forms';\r\n\r\n@Component({\r\n  selector: 'ius-input-otp',\r\n  standalone: true,\r\n  imports: [IconMdComponent, FormsModule, CommonModule],\r\n  templateUrl: './input-otp.component.html',\r\n  styleUrl: './input-otp.component.scss'\r\n})\r\nexport class InputOtpComponent {\r\n  @Input() length = 6;\r\n\r\n  @Input() disabled = false;\r\n  @Input() showHelpText = false;\r\n  @Input() labelSuperior?: string;\r\n  @Input() labelInferior?: string;\r\n  @Input() required = true;\r\n\r\n  @Output() onChangesValueEvent = new EventEmitter<string>();\r\n  @Output() codeComplete = new EventEmitter<string>(); // cuando se llenan todas las casillas\r\n  @ViewChildren('otpInput') otpInputs!: QueryList<ElementRef<HTMLInputElement>>;\r\n\r\n  values: string[] = [];\r\n  focusedIndex: number | null = null;\r\n  isAlertText = false;\r\n\r\n  get isAnyFocused(): boolean { return this.focusedIndex !== null; }\r\n  get boxes(): any[] { return Array.from({ length: this.length }); }\r\n  get code(): string { return this.values.join(''); }\r\n\r\n  ngOnInit() {\r\n    this.values = Array(this.length).fill('');\r\n  }\r\n\r\n  clearSearch() {\r\n    this.values.fill('');\r\n    this.emitChange();\r\n    this.isAlertText = this.required;\r\n    this.focusIndex(0);\r\n  }\r\n\r\n  onFocus(index: number) {\r\n    this.focusedIndex = index;\r\n    this.isAlertText = false;\r\n  }\r\n\r\n  onBlur() {\r\n    this.focusedIndex = null;\r\n    if (this.required) {\r\n      this.isAlertText = this.code.length !== this.length;\r\n    }\r\n  }\r\n\r\n  // Restringe a dígitos y mueve el foco\r\n  onInputBox(e: Event, index: number) {\r\n    const inputEvent = e as InputEvent;\r\n    const input = inputEvent.target as HTMLInputElement;\r\n    const raw = (input.value || '').replace(/\\D/g, '');\r\n\r\n    // Nos quedamos con el último dígito si escribió varios\r\n    const char = raw.slice(-1);\r\n    this.values[index] = char ?? '';\r\n    input.value = this.values[index];\r\n\r\n    // Avanza si hay valor\r\n    if (char && index < this.length - 1) this.focusIndex(index + 1);\r\n\r\n    this.emitChange();\r\n\r\n    // Si escribió múltiples (p.ej. autofill) distribuye\r\n    if (raw.length > 1) this.spreadFrom(index, raw);\r\n  }\r\n\r\n  // Teclas especiales: backspace, flechas, delete\r\n  onKeyDown(event: KeyboardEvent, index: number) {\r\n    const key = event.key;\r\n\r\n    if (!/^[0-9]$/.test(key) &&\r\n      !['Backspace', 'ArrowLeft', 'ArrowRight', 'Delete', 'Tab'].includes(key)) {\r\n      event.preventDefault();\r\n      return;\r\n    }\r\n\r\n    if (key === 'Backspace') {\r\n      if (this.values[index]) {\r\n        this.values[index] = '';\r\n        this.emitChange();\r\n      } else if (index > 0) {\r\n        this.focusIndex(index - 1);\r\n        // limpia la anterior para UX tipo “focused-error”\r\n        const prev = this.otpInputs.get(index - 1)?.nativeElement;\r\n        if (prev) { prev.value = ''; this.values[index - 1] = ''; this.emitChange(); }\r\n      }\r\n      event.preventDefault();\r\n      return;\r\n    }\r\n\r\n    if (key === 'Delete') {\r\n      this.values[index] = '';\r\n      this.emitChange();\r\n      event.preventDefault();\r\n      return;\r\n    }\r\n\r\n    if (key === 'ArrowLeft' && index > 0) {\r\n      this.focusIndex(index - 1); event.preventDefault(); return;\r\n    }\r\n    if (key === 'ArrowRight' && index < this.length - 1) {\r\n      this.focusIndex(index + 1); event.preventDefault(); return;\r\n    }\r\n  }\r\n\r\n  // Pegar un código completo\r\n  onPaste(event: ClipboardEvent) {\r\n    if (this.disabled) return;\r\n    event.preventDefault();\r\n    const data = (event.clipboardData?.getData('text') || '').replace(/\\D/g, '').slice(0, this.length);\r\n    if (!data) return;\r\n\r\n    const start = this.focusedIndex ?? 0;\r\n    this.spreadFrom(start, data);\r\n    this.emitChange();\r\n  }\r\n\r\n  /** Distribuye una cadena a partir de un índice */\r\n  spreadFrom(startIndex: number, data: string) {\r\n    let i = startIndex;\r\n    for (const ch of data) {\r\n      if (i >= this.length) break;\r\n      this.values[i] = ch;\r\n      const el = this.otpInputs.get(i)?.nativeElement;\r\n      if (el) el.value = ch;\r\n      i++;\r\n    }\r\n    // Enfoca siguiente libre o se queda en el último\r\n    const nextFree = this.values.findIndex((v, idx) => v === '' && idx >= startIndex);\r\n    this.focusIndex(nextFree === -1 ? this.length - 1 : nextFree);\r\n  }\r\n\r\n  /** Enfoca por índice de forma segura */\r\n  focusIndex(i: number) {\r\n    setTimeout(() => {\r\n      const el = this.otpInputs?.get(i)?.nativeElement;\r\n      if (el) el.focus();\r\n      this.focusedIndex = i;\r\n    });\r\n  }\r\n\r\n  /** Emite cambios y dispara codeComplete si procede */\r\n  emitChange() {\r\n    const code = this.code;\r\n    this.onChangesValueEvent.emit(code);\r\n    if (code.length === this.length) {\r\n      this.isAlertText = false;\r\n      this.codeComplete.emit(code);\r\n    }\r\n  }\r\n}\r\n","<div class=\"container-general\">\r\n  @if (labelSuperior) {\r\n    <div class=\"container-label-sup\" [ngClass]=\"{ 'disabled': disabled }\">\r\n      @if(!disabled && required){ <div class=\"icon-dot\"></div> }\r\n      <span>{{ labelSuperior }}</span>\r\n      @if(!disabled && showHelpText){\r\n        <ius-icon-md iconName=\"icon-help\" class=\"icon-color-help\"></ius-icon-md>\r\n      }\r\n      <span>:</span>\r\n    </div>\r\n  }\r\n\r\n  <div class=\"container-otp\">\r\n    <!-- Casillas OTP -->\r\n    <div class=\"otp-grid\">\r\n      @for (ctrl of boxes; track $index) {\r\n        <div\r\n          class=\"container-textfield\"\r\n          [ngClass]=\"{\r\n            'disabled': disabled,\r\n            'focused': focusedIndex === $index,\r\n            'alert': !disabled && isAlertText\r\n          }\"\r\n        >\r\n          <input\r\n            #otpInput\r\n            type=\"text\"\r\n            inputmode=\"numeric\"\r\n            pattern=\"[0-9]*\"\r\n            maxlength=\"1\"\r\n            [disabled]=\"disabled\"\r\n            [value]=\"values[$index]\"\r\n            (focus)=\"onFocus($index)\"\r\n            (blur)=\"onBlur()\"\r\n            (keydown)=\"onKeyDown($event, $index)\"\r\n            (input)=\"onInputBox($event, $index)\"\r\n            (paste)=\"onPaste($event)\"\r\n          />\r\n        </div>\r\n      }\r\n    </div>\r\n\r\n    @if (!disabled && this.code.length > 0 ) {\r\n      <button class=\"button-delete\" (click)=\"clearSearch()\" [ngClass]=\"{\r\n            'alert': !disabled && isAlertText\r\n          }\">\r\n        <ius-icon-md iconName=\"icon-cancel\" class=\"icon-color-cancel\" [ngClass]=\"{\r\n            'alert': !disabled && isAlertText\r\n          }\"></ius-icon-md>\r\n      </button>\r\n    }\r\n  </div>\r\n\r\n  @if (labelInferior && isAnyFocused) {\r\n    <span class=\"label-inf\">{{ labelInferior }}</span>\r\n  }\r\n  @if (labelInferior && !isAnyFocused && isAlertText) {\r\n    <span class=\"label-inf\" [ngClass]=\"{ 'alert': isAlertText }\">{{ labelInferior }}</span>\r\n  }\r\n</div>\r\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './input-password.component';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9pdXMtZGVzaWduLWNvbXBvbmVudHMvc3JjL2xpYi9pbnB1dC1wYXNzd29yZC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDRCQUE0QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9pbnB1dC1wYXNzd29yZC5jb21wb25lbnQnO1xyXG5cclxuIl19
|