@dev-tcloud/tcloud-ui 0.1.18 → 0.1.20
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/_directives/el-copy/el-copy.directive.mjs +21 -3
- package/esm2020/lib/_directives/tooltip/tooltip.directive.mjs +35 -32
- package/esm2020/lib/_modules/tcloud-ui-input-password/tcloud-ui-input-password.component.mjs +13 -4
- package/esm2020/lib/_pipes/bytes.mjs +10 -2
- package/fesm2015/dev-tcloud-tcloud-ui.mjs +77 -38
- package/fesm2015/dev-tcloud-tcloud-ui.mjs.map +1 -1
- package/fesm2020/dev-tcloud-tcloud-ui.mjs +75 -37
- package/fesm2020/dev-tcloud-tcloud-ui.mjs.map +1 -1
- package/lib/_modules/tcloud-ui-input-password/tcloud-ui-input-password.component.d.ts +4 -1
- package/lib/_pipes/bytes.d.ts +1 -1
- package/package.json +1 -1
- package/scss/components/custom/el-copy.scss +12 -0
|
@@ -14,7 +14,13 @@ export class TCloudUiElCopyDirective {
|
|
|
14
14
|
const btn_copy = this.renderer.createElement('i');
|
|
15
15
|
var copyText = () => {
|
|
16
16
|
const elementWithCopyAttribute = document.querySelector(`[data-el-copy="${id}"]`);
|
|
17
|
-
|
|
17
|
+
let copyText = '';
|
|
18
|
+
if (elementWithCopyAttribute && elementWithCopyAttribute.tagName && (elementWithCopyAttribute.tagName).toUpperCase() === 'INPUT') {
|
|
19
|
+
copyText = elementWithCopyAttribute?.value;
|
|
20
|
+
}
|
|
21
|
+
else {
|
|
22
|
+
copyText = elementWithCopyAttribute?.textContent;
|
|
23
|
+
}
|
|
18
24
|
navigator.clipboard.writeText(copyText);
|
|
19
25
|
this.renderer.removeClass(btn_copy, 'fa-copy');
|
|
20
26
|
this.renderer.addClass(btn_copy, 'fa-check');
|
|
@@ -33,7 +39,19 @@ export class TCloudUiElCopyDirective {
|
|
|
33
39
|
this.renderer.setAttribute(btn_copy, 'id', id);
|
|
34
40
|
this.renderer.setAttribute(btn_copy, 'title', 'Copy');
|
|
35
41
|
this.renderer.listen(btn_copy, 'click', () => { copyText(); });
|
|
36
|
-
|
|
42
|
+
if (((this.el.nativeElement).tagName).toUpperCase() === 'INPUT') {
|
|
43
|
+
let classList = this.el.nativeElement?.classList;
|
|
44
|
+
if (classList && (classList).length > 0 && ('tc-form-control').indexOf(classList) > -1) {
|
|
45
|
+
this.renderer.addClass(btn_copy, 'tcloud-ui-el-input-copy-tc-form-control');
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
this.renderer.addClass(btn_copy, 'tcloud-ui-el-input-copy');
|
|
49
|
+
}
|
|
50
|
+
this.renderer.appendChild(this.el.nativeElement.parentNode, btn_copy);
|
|
51
|
+
}
|
|
52
|
+
else {
|
|
53
|
+
this.renderer.appendChild(this.el.nativeElement, btn_copy);
|
|
54
|
+
}
|
|
37
55
|
}
|
|
38
56
|
generateID(target) {
|
|
39
57
|
const ref = (target) ? `-${target}` : '';
|
|
@@ -48,4 +66,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
48
66
|
selector: '[TCCopy]'
|
|
49
67
|
}]
|
|
50
68
|
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }]; } });
|
|
51
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
69
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWwtY29weS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90Y2xvdWQtdWkvc3JjL2xpYi9fZGlyZWN0aXZlcy9lbC1jb3B5L2VsLWNvcHkuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQXVDLE1BQU0sZUFBZSxDQUFDOztBQU0vRSxNQUFNLE9BQU8sdUJBQXVCO0lBSWxDLFlBQ1UsRUFBYyxFQUNkLFFBQW1CO1FBRG5CLE9BQUUsR0FBRixFQUFFLENBQVk7UUFDZCxhQUFRLEdBQVIsUUFBUSxDQUFXO1FBSnJCLFlBQU8sR0FBWSxLQUFLLENBQUM7SUFLNUIsQ0FBQztJQUVOLFFBQVE7UUFDTixPQUFPLENBQUMsR0FBRyxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBRXpDLElBQUksQ0FBQyxlQUFlLEVBQUUsQ0FBQztJQUN6QixDQUFDO0lBRUQsZUFBZTtRQUViLE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBRWxELElBQUksUUFBUSxHQUFHLEdBQUUsRUFBRTtZQUNmLE1BQU0sd0JBQXdCLEdBQUcsUUFBUSxDQUFDLGFBQWEsQ0FBQyxrQkFBa0IsRUFBRSxJQUFJLENBQVEsQ0FBQztZQUN6RixJQUFJLFFBQVEsR0FBRyxFQUFFLENBQUE7WUFDakIsSUFBSSx3QkFBd0IsSUFBSSx3QkFBd0IsQ0FBQyxPQUFPLElBQUksQ0FBQyx3QkFBd0IsQ0FBQyxPQUFPLENBQUMsQ0FBQyxXQUFXLEVBQUUsS0FBSyxPQUFPLEVBQUU7Z0JBQ2hJLFFBQVEsR0FBRyx3QkFBd0IsRUFBRSxLQUFNLENBQUM7YUFDN0M7aUJBQUk7Z0JBQ0gsUUFBUSxHQUFHLHdCQUF3QixFQUFFLFdBQVksQ0FBQzthQUNuRDtZQUNELFNBQVMsQ0FB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QUUsQ0FBQztRQUN6QyxPQUFPLGNBQWMsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLEdBQUcsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUMsR0FBRyxHQUFHLEVBQUUsQ0FBQztJQUNsRyxDQUFDOztxSEF2RVUsdUJBQXVCO3lHQUF2Qix1QkFBdUI7NEZBQXZCLHVCQUF1QjtrQkFIbkMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsVUFBVTtpQkFDckIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIE9uSW5pdCwgUmVuZGVyZXIyLCBJbnB1dH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5cclxuQERpcmVjdGl2ZSh7XHJcbiAgc2VsZWN0b3I6ICdbVENDb3B5XSdcclxufSlcclxuZXhwb3J0IGNsYXNzIFRDbG91ZFVpRWxDb3B5RGlyZWN0aXZlIGltcGxlbWVudHMgT25Jbml0e1xyXG5cclxuICBwcml2YXRlIF9pc0NvcHk6IGJvb2xlYW4gPSBmYWxzZTtcclxuICBcclxuICBjb25zdHJ1Y3RvcihcclxuICAgIHByaXZhdGUgZWw6IEVsZW1lbnRSZWYsXHJcbiAgICBwcml2YXRlIHJlbmRlcmVyOiBSZW5kZXJlcjJcclxuICAgICkge31cclxuXHJcbiAgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgICBjb25zb2xlLmxvZygnZWwnLCB0aGlzLmVsLm5hdGl2ZUVsZW1lbnQpO1xyXG5cclxuICAgIHRoaXMuc2V0SXRlbUZ1bmNDb3B5KCk7XHJcbiAgfVxyXG5cclxuICBzZXRJdGVtRnVuY0NvcHkoKXtcclxuXHJcbiAgICBjb25zdCBidG5fY29weSA9IHRoaXMucmVuZGVyZXIuY3JlYXRlRWxlbWVudCgnaScpO1xyXG5cclxuICAgIHZhciBjb3B5VGV4dCA9ICgpPT57ICAgICAgICBcclxuICAgICAgICBjb25zdCBlbGVtZW50V2l0aENvcHlBdHRyaWJ1dGUgPSBkb2N1bWVudC5xdWVyeVNlbGVjdG9yKGBbZGF0YS1lbC1jb3B5PVwiJHtpZH1cIl1gKSBhcyBhbnk7XHJcbiAgICAgICAgbGV0IGNvcHlUZXh0ID0gJydcclxuICAgICAgICBpZiggZWxlbWVudFdpdGhDb3B5QXR0cmlidXRlICYmIGVsZW1lbnRXaXRoQ29weUF0dHJpYnV0ZS50YWdOYW1lICYmIChlbGVtZW50V2l0aENvcHlBdHRyaWJ1dGUudGFnTmFtZSkudG9VcHBlckNhc2UoKSA9PT0gJ0lOUFVUJyApe1xyXG4gICAgICAgICAgY29weVRleHQgPSBlbGVtZW50V2l0aENvcHlBdHRyaWJ1dGU/LnZhbHVlITtcclxuICAgICAgICB9ZWxzZXtcclxuICAgICAgICAgIGNvcHlUZXh0ID0gZWxlbWVudFdpdGhDb3B5QXR0cmlidXRlPy50ZXh0Q29udGVudCE7XHJcbiAgICAgICAgfSAgICAgICAgXHJcbiAgICAgICAgbmF2aWdhdG9yLmNsaXBib2FyZC53cml0ZVRleHQoY29weVRleHQpO1xyXG4gICAgICAgIHRoaXMucmVuZGVyZXIucmVtb3ZlQ2xhc3MoYnRuX2NvcHksICdmYS1jb3B5Jyk7XHJcbiAgICAgICAgdGhpcy5yZW5kZXJlci5hZGRDbGFzcyhidG5fY29weSwgJ2ZhLWNoZWNrJyk7XHJcbiAgICAgICAgc2V0VGltZW91dCgoKSA9PiB7XHJcbiAgICAgICAgICAgIHRoaXMucmVuZGVyZXIucmVtb3ZlQ2xhc3MoYnRuX2NvcHksICdmYS1jaGVjaycpO1xyXG4gICAgICAgICAgICB0aGlzLnJlbmRlcmVyLmFkZENsYXNzKGJ0bl9jb3B5LCAnZmEtY29weScpO1xyXG4gICAgICAgIH0sIDMwMDApO1xyXG4gICAgICAgIFxyXG4gICAgfVxyXG5cclxuICAgIGNvbnN0IGlkID0gdGhpcy5nZW5lcmF0ZUlEKCk7XHJcbiAgICB0aGlzLnJlbmRlcmVyLnNldEF0dHJpYnV0ZSh0aGlzLmVsLm5hdGl2ZUVsZW1lbnQsICdkYXRhLWVsLWNvcHknLCBgJHtpZH1gKTtcclxuXHJcbiAgICBcclxuICAgIHRoaXMucmVuZGVyZXIuc2V0U3R5bGUoYnRuX2NvcHksICdjdXJzb3InLCAncG9pbnRlcicpO1xyXG4gICAgdGhpcy5yZW5kZXJlci5zZXRTdHlsZShidG5fY29weSwgJ21hcmdpbi1sZWZ0JywgJzNweCcpO1xyXG4gICAgdGhpcy5yZW5kZXJlci5hZGRDbGFzcyhidG5fY29weSwgJ2ZhcycpO1xyXG4gICAgdGhpcy5yZW5kZXJlci5hZGRDbGFzcyhidG5fY29weSwgJ2ZhLWNvcHknKTtcclxuXHJcbiAgICB0aGlzLnJlbmRlcmVyLmFkZENsYXNzKGJ0bl9jb3B5LCAndGNsb3VkLXVpLWVsLWNvcHknKTtcclxuICAgIHRoaXMucmVuZGVyZXIuc2V0QXR0cmlidXRlKGJ0bl9jb3B5LCAnaWQnLCBpZCk7XHJcbiAgICB0aGlzLnJlbmRlcmVyLnNldEF0dHJpYnV0ZShidG5fY29weSwgJ3RpdGxlJywgJ0NvcHknKTtcclxuICAgIHRoaXMucmVuZGVyZXIubGlzdGVuKGJ0bl9jb3B5LCAnY2xpY2snLCAoKSA9PiB7IGNvcHlUZXh0KCk7IH0pO1xyXG5cclxuICAgIGlmKCAoKHRoaXMuZWwubmF0aXZlRWxlbWVudCkudGFnTmFtZSkudG9VcHBlckNhc2UoKSA9PT0gJ0lOUFVUJyApe1xyXG4gICAgICBsZXQgY2xhc3NMaXN0ID0gdGhpcy5lbC5uYXRpdmVFbGVtZW50Py5jbGFzc0xpc3QhXHJcbiAgICAgIGlmKCBjbGFzc0xpc3QgJiYgKGNsYXNzTGlzdCkubGVuZ3RoID4gMCAmJiAoJ3RjLWZvcm0tY29udHJvbCcpLmluZGV4T2YoY2xhc3NMaXN0KSA+IC0xICl7XHJcbiAgICAgICAgdGhpcy5yZW5kZXJlci5hZGRDbGFzcyhidG5fY29weSwgJ3RjbG91ZC11aS1lbC1pbnB1dC1jb3B5LXRjLWZvcm0tY29udHJvbCcpO1xyXG4gICAgICB9ZWxzZXtcclxuICAgICAgICB0aGlzLnJlbmRlcmVyLmFkZENsYXNzKGJ0bl9jb3B5LCAndGNsb3VkLXVpLWVsLWlucHV0LWNvcHknKTtcclxuICAgICAgfSAgICAgIFxyXG4gICAgICB0aGlzLnJlbmRlcmVyLmFwcGVuZENoaWxkKHRoaXMuZWwubmF0aXZlRWxlbWVudC5wYXJlbnROb2RlLCBidG5fY29weSk7XHJcbiAgICB9ZWxzZXtcclxuICAgICAgdGhpcy5yZW5kZXJlci5hcHBlbmRDaGlsZCh0aGlzLmVsLm5hdGl2ZUVsZW1lbnQsIGJ0bl9jb3B5KTtcclxuICAgIH1cclxuXHJcbiAgICBcclxuXHJcbiAgICBcclxuICB9XHJcblxyXG4gIGdlbmVyYXRlSUQodGFyZ2V0Pzogc3RyaW5nKTogc3RyaW5ne1xyXG4gICAgY29uc3QgcmVmID0gKHRhcmdldCkgPyBgLSR7dGFyZ2V0fWAgOiAnJztcclxuICAgIHJldHVybiBgdGMtZWwtY29weS0ke01hdGguZmxvb3IoTWF0aC5yYW5kb20oKSAqIE1hdGguZmxvb3IoTWF0aC5yYW5kb20oKSAqIERhdGUubm93KCkpKX0ke3JlZn1gO1xyXG4gIH1cclxuXHJcbn0iXX0=
|
|
@@ -20,38 +20,41 @@ export class TCloudUiTooltipDirective {
|
|
|
20
20
|
}
|
|
21
21
|
};
|
|
22
22
|
hoverOutCallback;
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
const left = `${el_position_x + (width / 2)}px`;
|
|
38
|
-
this.renderer.setStyle(tooltip, 'top', '0px');
|
|
39
|
-
this.renderer.setStyle(tooltip, 'left', '0px');
|
|
40
|
-
this.renderer.setStyle(tooltip, 'opacity', '0');
|
|
41
|
-
this.renderer.addClass(tooltip, 'tc-directive-tooltip');
|
|
42
|
-
this.renderer.addClass(tooltip, `tc-directive-tooltip-${direction}`);
|
|
43
|
-
const id = this.generateID();
|
|
44
|
-
this.renderer.setAttribute(tooltip, 'id', id);
|
|
45
|
-
const textNode = this.info_text;
|
|
46
|
-
if (textNode !== undefined && textNode !== null && textNode !== '') {
|
|
47
|
-
tooltip.innerHTML = textNode;
|
|
48
|
-
this.renderer.appendChild(document.body, tooltip);
|
|
49
|
-
this.start_tooltip(id, height, width, el_position_x, el_position_y, direction);
|
|
50
|
-
if (tooltip) {
|
|
51
|
-
tooltip.addEventListener('mouseenter', hoverInCallback);
|
|
52
|
-
tooltip.addEventListener('mouseleave', hoverOutCallback);
|
|
23
|
+
setTimeout(() => {
|
|
24
|
+
const scrollTop = window.scrollY || window.pageYOffset;
|
|
25
|
+
const tooltip = this.renderer.createElement('div');
|
|
26
|
+
const rect = this.el.nativeElement?.getBoundingClientRect();
|
|
27
|
+
// const direction = this.el.nativeElement?.attributes['ng-reflect--t-cdirection']?.value || 'top';
|
|
28
|
+
const direction = this._direction || 'top';
|
|
29
|
+
const el_position_x = (rect?.left) ? parseInt(rect?.left) : 0;
|
|
30
|
+
const el_position_y = (rect?.top) ? parseInt(rect?.top + scrollTop) : 0;
|
|
31
|
+
let width = 0;
|
|
32
|
+
let height = 0;
|
|
33
|
+
if (event && event.target) {
|
|
34
|
+
const _event = event.target;
|
|
35
|
+
height = _event.offsetHeight;
|
|
36
|
+
width = _event.offsetWidth;
|
|
53
37
|
}
|
|
54
|
-
|
|
38
|
+
const top = `${(el_position_y - ((height / 2) + 10))}px`;
|
|
39
|
+
const left = `${el_position_x + (width / 2)}px`;
|
|
40
|
+
this.renderer.setStyle(tooltip, 'top', '0px');
|
|
41
|
+
this.renderer.setStyle(tooltip, 'left', '0px');
|
|
42
|
+
this.renderer.setStyle(tooltip, 'opacity', '0');
|
|
43
|
+
this.renderer.addClass(tooltip, 'tc-directive-tooltip');
|
|
44
|
+
this.renderer.addClass(tooltip, `tc-directive-tooltip-${direction}`);
|
|
45
|
+
const id = this.generateID();
|
|
46
|
+
this.renderer.setAttribute(tooltip, 'id', id);
|
|
47
|
+
const textNode = this.info_text;
|
|
48
|
+
if (textNode !== undefined && textNode !== null && textNode !== '') {
|
|
49
|
+
tooltip.innerHTML = textNode;
|
|
50
|
+
this.renderer.appendChild(document.body, tooltip);
|
|
51
|
+
this.start_tooltip(id, height, width, el_position_x, el_position_y, direction);
|
|
52
|
+
if (tooltip) {
|
|
53
|
+
tooltip.addEventListener('mouseenter', hoverInCallback);
|
|
54
|
+
tooltip.addEventListener('mouseleave', hoverOutCallback);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
});
|
|
55
58
|
}
|
|
56
59
|
onMouseOut(event) {
|
|
57
60
|
this.remove = true;
|
|
@@ -139,4 +142,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
139
142
|
}], TCdirection: [{
|
|
140
143
|
type: Input
|
|
141
144
|
}] } });
|
|
142
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"","sources":["../../../../../../projects/tcloud-ui/src/lib/_directives/tooltip/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Renderer2, Input, HostListener} from '@angular/core';\r\n\r\n\r\n@Directive({\r\n  selector: '[TCtooltip]'\r\n})\r\nexport class TCloudUiTooltipDirective {\r\n\r\n  remove: boolean = false;\r\n\r\n  info_text: string = '';\r\n\r\n  @HostListener('mouseover', ['$event']) onMouseOver(event: MouseEvent) {\r\n\r\n    let hoverInCallback = () => {\r\n      this.remove = false;\r\n    }\r\n\r\n    let hoverOutCallback = () => {\r\n      this.remove = true;\r\n      const customDiv = <any> document.querySelector('.tc-directive-tooltip');\r\n      if( customDiv ){ customDiv.remove(); }      \r\n    }\r\n\r\n    hoverOutCallback;\r\n\r\n    const scrollTop = window.scrollY || window.pageYOffset;\r\n    const tooltip = this.renderer.createElement('div');\r\n    const rect  = this.el.nativeElement?.getBoundingClientRect();\r\n    const direction = this.el.nativeElement?.attributes['ng-reflect--t-cdirection']?.value || 'top';\r\n    const el_position_x = (rect?.left) ? parseInt(rect?.left) : 0;\r\n    const el_position_y = (rect?.top ) ? parseInt(rect?.top  + scrollTop) : 0;\r\n\r\n    let width = 0;\r\n    let height = 0;\r\n    if( event && event.target ){\r\n      const _event = event.target as any;\r\n      height  = _event.offsetHeight;\r\n      width   = _event.offsetWidth;\r\n    }\r\n\r\n    const top = `${(el_position_y - ((height/2) + 10) )}px`;\r\n    const left = `${el_position_x + (width/2) }px`;\r\n    this.renderer.setStyle(tooltip, 'top', '0px');\r\n    this.renderer.setStyle(tooltip, 'left', '0px');\r\n    this.renderer.setStyle(tooltip, 'opacity', '0');\r\n    this.renderer.addClass(tooltip, 'tc-directive-tooltip');\r\n    this.renderer.addClass(tooltip, `tc-directive-tooltip-${direction}`);\r\n    const id = this.generateID();\r\n    this.renderer.setAttribute(tooltip, 'id', id);\r\n    const textNode = this.info_text;\r\n\r\n    if( textNode !== undefined && textNode !== null && textNode !== '' ){\r\n\r\n      tooltip.innerHTML = textNode;\r\n      this.renderer.appendChild(document.body, tooltip);    \r\n      this.start_tooltip(id, height, width, el_position_x, el_position_y, direction);\r\n\r\n      if (tooltip) {\r\n        tooltip.addEventListener('mouseenter', hoverInCallback);\r\n        tooltip.addEventListener('mouseleave', hoverOutCallback);\r\n      }\r\n    }\r\n\r\n  }  \r\n\r\n  @HostListener('mouseout', ['$event']) onMouseOut(event: MouseEvent) {   \r\n    this.remove = true;\r\n    this.remove_tooltip( document.querySelector('.tc-directive-tooltip') );\r\n  }\r\n\r\n  remove_tooltip(customDiv: any){   \r\n    if (customDiv) {      \r\n      setTimeout(() => {\r\n        if( this.remove ){\r\n          customDiv.remove();\r\n        }\r\n      }, 30);      \r\n    }\r\n  }\r\n\r\n\r\n  @Input() set TCtooltip (tooltip: any){\r\n    if (tooltip){\r\n      if( typeof tooltip === 'object' ){\r\n      }else{\r\n        this.info_text = tooltip;\r\n      }      \r\n    }\r\n  }\r\n\r\n  private _direction: 'top' | 'bottom' | 'left' | 'right' = 'top';\r\n  @Input() set TCdirection (direction: any){\r\n    if (direction){\r\n      this._direction = direction;\r\n    }\r\n  }\r\n  \r\n  constructor(\r\n    private el: ElementRef,\r\n    private renderer: Renderer2\r\n  ) {}\r\n\r\n\r\n  generateID(target?: string): string{\r\n    const ref = (target) ? `-${target}` : '';\r\n    return `tc-tooltip-${Math.floor(Math.random() * Math.floor(Math.random() * Date.now()))}${ref}`;\r\n  }\r\n\r\n  start_tooltip(id: string, height: number, width: number, el_position_x: number, el_position_y: number, direction: string){\r\n    setTimeout(() => {      \r\n      const tooltip: any = document.getElementById(id);\r\n      const tooltip_height = tooltip.clientHeight;\r\n      const tooltip_width = tooltip.clientWidth;\r\n\r\n      /*\r\n      console.log('altura do target: ', height);\r\n      console.log('largura do target: ', width);\r\n      console.log('el_position_x do target: ', el_position_x);\r\n      console.log('el_position_y do target: ', el_position_y);\r\n      console.log('direction do tooltip: ', direction);\r\n      */\r\n\r\n      let p_y = 0;\r\n      let p_x = 0;\r\n      const center_position = (el_position_x + (width/2)) - (tooltip_width/2);\r\n\r\n      if( direction === 'top' ){\r\n        p_y = (el_position_y - tooltip_height) - 15;\r\n        p_x = center_position;\r\n      }\r\n\r\n      if( direction === 'bottom' ){\r\n        p_y = (el_position_y + height) + 15;\r\n        p_x = center_position;\r\n      }\r\n\r\n      if( direction === 'left' ){\r\n        p_y = el_position_y - (tooltip_height/2) + (height/2);\r\n        p_x = center_position - tooltip_width/2 - width/2 - 15;\r\n      }\r\n\r\n      if( direction === 'right' ){\r\n        p_y = el_position_y - (tooltip_height/2) + (height/2);\r\n        p_x = center_position + tooltip_width/2 + width/2 + 15;\r\n      }\r\n\r\n      this.renderer.setStyle(tooltip, 'top', `${p_y}px`);\r\n      this.renderer.setStyle(tooltip, 'left', `${p_x}px`);\r\n      this.renderer.addClass(tooltip, 'tc-tooltip-fade-in');\r\n\r\n    });\r\n  }\r\n\r\n}"]}
|
|
145
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"","sources":["../../../../../../projects/tcloud-ui/src/lib/_directives/tooltip/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, Renderer2, Input, HostListener} from '@angular/core';\r\n\r\n\r\n@Directive({\r\n  selector: '[TCtooltip]'\r\n})\r\nexport class TCloudUiTooltipDirective {\r\n\r\n  remove: boolean = false;\r\n\r\n  info_text: string = '';\r\n\r\n  @HostListener('mouseover', ['$event']) onMouseOver(event: MouseEvent) {\r\n\r\n    let hoverInCallback = () => {\r\n      this.remove = false;\r\n    }\r\n\r\n    let hoverOutCallback = () => {\r\n      this.remove = true;\r\n      const customDiv = <any> document.querySelector('.tc-directive-tooltip');\r\n      if( customDiv ){ customDiv.remove(); }      \r\n    }\r\n\r\n    hoverOutCallback;\r\n\r\n    setTimeout(() => {\r\n      const scrollTop = window.scrollY || window.pageYOffset;\r\n      const tooltip = this.renderer.createElement('div');\r\n      const rect  = this.el.nativeElement?.getBoundingClientRect();\r\n      // const direction = this.el.nativeElement?.attributes['ng-reflect--t-cdirection']?.value || 'top';\r\n      const direction = this._direction || 'top';\r\n      const el_position_x = (rect?.left) ? parseInt(rect?.left) : 0;\r\n      const el_position_y = (rect?.top ) ? parseInt(rect?.top  + scrollTop) : 0;\r\n\r\n      let width = 0;\r\n      let height = 0;\r\n      if( event && event.target ){\r\n        const _event = event.target as any;\r\n        height  = _event.offsetHeight;\r\n        width   = _event.offsetWidth;\r\n      }\r\n\r\n      const top = `${(el_position_y - ((height/2) + 10) )}px`;\r\n      const left = `${el_position_x + (width/2) }px`;\r\n      this.renderer.setStyle(tooltip, 'top', '0px');\r\n      this.renderer.setStyle(tooltip, 'left', '0px');\r\n      this.renderer.setStyle(tooltip, 'opacity', '0');\r\n      this.renderer.addClass(tooltip, 'tc-directive-tooltip');\r\n      this.renderer.addClass(tooltip, `tc-directive-tooltip-${direction}`);\r\n      const id = this.generateID();\r\n      this.renderer.setAttribute(tooltip, 'id', id);\r\n      const textNode = this.info_text;\r\n\r\n      if( textNode !== undefined && textNode !== null && textNode !== '' ){\r\n\r\n        tooltip.innerHTML = textNode;\r\n        this.renderer.appendChild(document.body, tooltip);    \r\n        this.start_tooltip(id, height, width, el_position_x, el_position_y, direction);\r\n\r\n        if (tooltip) {\r\n          tooltip.addEventListener('mouseenter', hoverInCallback);\r\n          tooltip.addEventListener('mouseleave', hoverOutCallback);\r\n        }\r\n      }\r\n\r\n    });\r\n\r\n  }  \r\n\r\n  @HostListener('mouseout', ['$event']) onMouseOut(event: MouseEvent) {   \r\n    this.remove = true;\r\n    this.remove_tooltip( document.querySelector('.tc-directive-tooltip') );\r\n  }\r\n\r\n  remove_tooltip(customDiv: any){   \r\n    if (customDiv) {      \r\n      setTimeout(() => {\r\n        if( this.remove ){\r\n          customDiv.remove();\r\n        }\r\n      }, 30);      \r\n    }\r\n  }\r\n\r\n\r\n  @Input() set TCtooltip (tooltip: any){\r\n    if (tooltip){\r\n      if( typeof tooltip === 'object' ){\r\n      }else{\r\n        this.info_text = tooltip;\r\n      }      \r\n    }\r\n  }\r\n\r\n  private _direction: 'top' | 'bottom' | 'left' | 'right' = 'top';\r\n  @Input() set TCdirection (direction: any){\r\n    if (direction){\r\n      this._direction = direction;\r\n    }\r\n  }\r\n  \r\n  constructor(\r\n    private el: ElementRef,\r\n    private renderer: Renderer2\r\n  ) {}\r\n\r\n\r\n  generateID(target?: string): string{\r\n    const ref = (target) ? `-${target}` : '';\r\n    return `tc-tooltip-${Math.floor(Math.random() * Math.floor(Math.random() * Date.now()))}${ref}`;\r\n  }\r\n\r\n  start_tooltip(id: string, height: number, width: number, el_position_x: number, el_position_y: number, direction: string){\r\n    setTimeout(() => {      \r\n      const tooltip: any = document.getElementById(id);\r\n      const tooltip_height = tooltip.clientHeight;\r\n      const tooltip_width = tooltip.clientWidth;\r\n\r\n      /*\r\n      console.log('altura do target: ', height);\r\n      console.log('largura do target: ', width);\r\n      console.log('el_position_x do target: ', el_position_x);\r\n      console.log('el_position_y do target: ', el_position_y);\r\n      console.log('direction do tooltip: ', direction);\r\n      */\r\n\r\n      let p_y = 0;\r\n      let p_x = 0;\r\n      const center_position = (el_position_x + (width/2)) - (tooltip_width/2);\r\n\r\n      if( direction === 'top' ){\r\n        p_y = (el_position_y - tooltip_height) - 15;\r\n        p_x = center_position;\r\n      }\r\n\r\n      if( direction === 'bottom' ){\r\n        p_y = (el_position_y + height) + 15;\r\n        p_x = center_position;\r\n      }\r\n\r\n      if( direction === 'left' ){\r\n        p_y = el_position_y - (tooltip_height/2) + (height/2);\r\n        p_x = center_position - tooltip_width/2 - width/2 - 15;\r\n      }\r\n\r\n      if( direction === 'right' ){\r\n        p_y = el_position_y - (tooltip_height/2) + (height/2);\r\n        p_x = center_position + tooltip_width/2 + width/2 + 15;\r\n      }\r\n\r\n      this.renderer.setStyle(tooltip, 'top', `${p_y}px`);\r\n      this.renderer.setStyle(tooltip, 'left', `${p_x}px`);\r\n      this.renderer.addClass(tooltip, 'tc-tooltip-fade-in');\r\n\r\n    });\r\n  }\r\n\r\n}"]}
|
package/esm2020/lib/_modules/tcloud-ui-input-password/tcloud-ui-input-password.component.mjs
CHANGED
|
@@ -12,6 +12,9 @@ const noop = () => {
|
|
|
12
12
|
};
|
|
13
13
|
export class TCloudUiInputPasswordComponent {
|
|
14
14
|
constructor() {
|
|
15
|
+
this.actionView = true;
|
|
16
|
+
this.actionCopy = true;
|
|
17
|
+
this.actionGeneratePassword = true;
|
|
15
18
|
this.numberOfCharacter = 14;
|
|
16
19
|
this.atLeastOneUppercaseLetter = true;
|
|
17
20
|
this.atLeastOneLowercaseLetter = true;
|
|
@@ -113,11 +116,17 @@ export class TCloudUiInputPasswordComponent {
|
|
|
113
116
|
}
|
|
114
117
|
}
|
|
115
118
|
TCloudUiInputPasswordComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiInputPasswordComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
116
|
-
TCloudUiInputPasswordComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: TCloudUiInputPasswordComponent, selector: "tcloud-ui-input-password", inputs: { numberOfCharacter: "numberOfCharacter", atLeastOneUppercaseLetter: "atLeastOneUppercaseLetter", atLeastOneLowercaseLetter: "atLeastOneLowercaseLetter", atLeastOneSpecialCharacter: "atLeastOneSpecialCharacter", ngModel: "ngModel" }, outputs: { ngModelChange: "ngModelChange" }, providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR], ngImport: i0, template: "<div class=\"tcloud-ui-input-password\">\r\n <table>\r\n <tr>\r\n <!-- input password -->\r\n <td>\r\n <form #_form=\"ngForm\">\r\n <ng-container *ngIf=\"passwordRegex\">\r\n <input class=\"tc-form-control\" *ngIf=\"mode == 'password'\" type=\"password\" name=\"tc_password\" [pattern]=\"passwordRegex\" autoComplete=\"new-password\" [(ngModel)]=\"innerValue\" required>\r\n <input class=\"tc-form-control\" *ngIf=\"mode == 'text'\" type=\"text\" name=\"tc_text\" [pattern]=\"passwordRegex\" [(ngModel)]=\"innerValue\" required>\r\n </ng-container>\r\n </form>\r\n </td>\r\n\r\n <!-- action show hide -->\r\n <td>\r\n <button type=\"button\" (click)=\"toggleMode()\" [title]=\"(mode == 'password') ? 'Visualizar Senha' : 'Esconder Senha'\">\r\n <i *ngIf=\"mode == 'password'\" class=\"far fa-eye-slash\"></i>\r\n <i *ngIf=\"mode == 'text'\" class=\"far fa-eye\"></i> \r\n </button>\r\n </td>\r\n\r\n <!-- action generate pass -->\r\n <td>\r\n <button type=\"button\" [title]=\"'Gerar Senha'\" (click)=\"generatePassword()\">\r\n <i class=\"fa-solid fa-key\"></i>\r\n </button>\r\n </td>\r\n\r\n <!-- action copy pass -->\r\n <td>\r\n <button type=\"button\" [title]=\"'Copiar Senha'\" (click)=\"copyText()\">\r\n <i *ngIf=\"!isCopy\" class=\"fa-regular fa-copy\"></i>\r\n <i *ngIf=\"isCopy\" class=\"fa-solid fa-check\"></i>\r\n </button>\r\n </td>\r\n </tr>\r\n </table>\r\n</div>", styles: [".tcloud-ui-input-password{border:1px solid var(--tc-gray-300);border-radius:3px}.tcloud-ui-input-password table{width:100%}.tcloud-ui-input-password table td:first-child{width:100%!important}.tcloud-ui-input-password table td:first-child input{width:100%;border:none;height:38px;padding-left:8px}.tcloud-ui-input-password table td{width:50px;height:40px;background-color:#fff}.tcloud-ui-input-password table td button{background:transparent;border:none;margin-right:3px;cursor:pointer;color:var(--tc-gray-500)}.tcloud-ui-input-password table td button:hover{color:var(--tc-primary2)}.tcloud-ui-input-password .ng-invalid.ng-touched{border:1px solid var(--red)!important}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i2.PatternValidator, selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: ["pattern"] }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i2.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }] });
|
|
119
|
+
TCloudUiInputPasswordComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: TCloudUiInputPasswordComponent, selector: "tcloud-ui-input-password", inputs: { actionView: "actionView", actionCopy: "actionCopy", actionGeneratePassword: "actionGeneratePassword", numberOfCharacter: "numberOfCharacter", atLeastOneUppercaseLetter: "atLeastOneUppercaseLetter", atLeastOneLowercaseLetter: "atLeastOneLowercaseLetter", atLeastOneSpecialCharacter: "atLeastOneSpecialCharacter", ngModel: "ngModel" }, outputs: { ngModelChange: "ngModelChange" }, providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR], ngImport: i0, template: "<div class=\"tcloud-ui-input-password\">\r\n <table>\r\n <tr>\r\n <!-- input password -->\r\n <td>\r\n <form #_form=\"ngForm\">\r\n <ng-container *ngIf=\"passwordRegex\">\r\n <input class=\"tc-form-control\" *ngIf=\"mode == 'password'\" type=\"password\" name=\"tc_password\" [pattern]=\"passwordRegex\" autoComplete=\"new-password\" [(ngModel)]=\"innerValue\" required>\r\n <input class=\"tc-form-control\" *ngIf=\"mode == 'text'\" type=\"text\" name=\"tc_text\" [pattern]=\"passwordRegex\" [(ngModel)]=\"innerValue\" required>\r\n </ng-container>\r\n </form>\r\n </td>\r\n\r\n <!-- action show hide -->\r\n <td *ngIf=\"actionView\">\r\n <button type=\"button\" (click)=\"toggleMode()\" [title]=\"(mode == 'password') ? 'Visualizar Senha' : 'Esconder Senha'\">\r\n <i *ngIf=\"mode == 'password'\" class=\"far fa-eye-slash\"></i>\r\n <i *ngIf=\"mode == 'text'\" class=\"far fa-eye\"></i> \r\n </button>\r\n </td>\r\n\r\n <!-- action generate pass -->\r\n <td *ngIf=\"actionGeneratePassword\">\r\n <button type=\"button\" [title]=\"'Gerar Senha'\" (click)=\"generatePassword()\">\r\n <i class=\"fa-solid fa-key\"></i>\r\n </button>\r\n </td>\r\n\r\n <!-- action copy pass -->\r\n <td *ngIf=\"actionCopy\">\r\n <button type=\"button\" [title]=\"'Copiar Senha'\" (click)=\"copyText()\">\r\n <i *ngIf=\"!isCopy\" class=\"fa-regular fa-copy\"></i>\r\n <i *ngIf=\"isCopy\" class=\"fa-solid fa-check\"></i>\r\n </button>\r\n </td>\r\n </tr>\r\n </table>\r\n</div>", styles: [".tcloud-ui-input-password{border:1px solid var(--tc-gray-300);border-radius:3px}.tcloud-ui-input-password table{width:100%}.tcloud-ui-input-password table td:first-child{width:100%!important}.tcloud-ui-input-password table td:first-child input{width:100%;border:none;height:38px;padding-left:8px}.tcloud-ui-input-password table td{width:50px;height:40px;background-color:#fff}.tcloud-ui-input-password table td button{background:transparent;border:none;margin-right:3px;cursor:pointer;color:var(--tc-gray-500)}.tcloud-ui-input-password table td button:hover{color:var(--tc-primary2)}.tcloud-ui-input-password .ng-invalid.ng-touched{border:1px solid var(--red)!important}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i2.PatternValidator, selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: ["pattern"] }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i2.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }] });
|
|
117
120
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiInputPasswordComponent, decorators: [{
|
|
118
121
|
type: Component,
|
|
119
|
-
args: [{ selector: 'tcloud-ui-input-password', providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR], template: "<div class=\"tcloud-ui-input-password\">\r\n <table>\r\n <tr>\r\n <!-- input password -->\r\n <td>\r\n <form #_form=\"ngForm\">\r\n <ng-container *ngIf=\"passwordRegex\">\r\n <input class=\"tc-form-control\" *ngIf=\"mode == 'password'\" type=\"password\" name=\"tc_password\" [pattern]=\"passwordRegex\" autoComplete=\"new-password\" [(ngModel)]=\"innerValue\" required>\r\n <input class=\"tc-form-control\" *ngIf=\"mode == 'text'\" type=\"text\" name=\"tc_text\" [pattern]=\"passwordRegex\" [(ngModel)]=\"innerValue\" required>\r\n </ng-container>\r\n </form>\r\n </td>\r\n\r\n <!-- action show hide -->\r\n <td>\r\n <button type=\"button\" (click)=\"toggleMode()\" [title]=\"(mode == 'password') ? 'Visualizar Senha' : 'Esconder Senha'\">\r\n <i *ngIf=\"mode == 'password'\" class=\"far fa-eye-slash\"></i>\r\n <i *ngIf=\"mode == 'text'\" class=\"far fa-eye\"></i> \r\n </button>\r\n </td>\r\n\r\n <!-- action generate pass -->\r\n <td>\r\n <button type=\"button\" [title]=\"'Gerar Senha'\" (click)=\"generatePassword()\">\r\n <i class=\"fa-solid fa-key\"></i>\r\n </button>\r\n </td>\r\n\r\n <!-- action copy pass -->\r\n <td>\r\n <button type=\"button\" [title]=\"'Copiar Senha'\" (click)=\"copyText()\">\r\n <i *ngIf=\"!isCopy\" class=\"fa-regular fa-copy\"></i>\r\n <i *ngIf=\"isCopy\" class=\"fa-solid fa-check\"></i>\r\n </button>\r\n </td>\r\n </tr>\r\n </table>\r\n</div>", styles: [".tcloud-ui-input-password{border:1px solid var(--tc-gray-300);border-radius:3px}.tcloud-ui-input-password table{width:100%}.tcloud-ui-input-password table td:first-child{width:100%!important}.tcloud-ui-input-password table td:first-child input{width:100%;border:none;height:38px;padding-left:8px}.tcloud-ui-input-password table td{width:50px;height:40px;background-color:#fff}.tcloud-ui-input-password table td button{background:transparent;border:none;margin-right:3px;cursor:pointer;color:var(--tc-gray-500)}.tcloud-ui-input-password table td button:hover{color:var(--tc-primary2)}.tcloud-ui-input-password .ng-invalid.ng-touched{border:1px solid var(--red)!important}\n"] }]
|
|
120
|
-
}], ctorParameters: function () { return []; }, propDecorators: {
|
|
122
|
+
args: [{ selector: 'tcloud-ui-input-password', providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR], template: "<div class=\"tcloud-ui-input-password\">\r\n <table>\r\n <tr>\r\n <!-- input password -->\r\n <td>\r\n <form #_form=\"ngForm\">\r\n <ng-container *ngIf=\"passwordRegex\">\r\n <input class=\"tc-form-control\" *ngIf=\"mode == 'password'\" type=\"password\" name=\"tc_password\" [pattern]=\"passwordRegex\" autoComplete=\"new-password\" [(ngModel)]=\"innerValue\" required>\r\n <input class=\"tc-form-control\" *ngIf=\"mode == 'text'\" type=\"text\" name=\"tc_text\" [pattern]=\"passwordRegex\" [(ngModel)]=\"innerValue\" required>\r\n </ng-container>\r\n </form>\r\n </td>\r\n\r\n <!-- action show hide -->\r\n <td *ngIf=\"actionView\">\r\n <button type=\"button\" (click)=\"toggleMode()\" [title]=\"(mode == 'password') ? 'Visualizar Senha' : 'Esconder Senha'\">\r\n <i *ngIf=\"mode == 'password'\" class=\"far fa-eye-slash\"></i>\r\n <i *ngIf=\"mode == 'text'\" class=\"far fa-eye\"></i> \r\n </button>\r\n </td>\r\n\r\n <!-- action generate pass -->\r\n <td *ngIf=\"actionGeneratePassword\">\r\n <button type=\"button\" [title]=\"'Gerar Senha'\" (click)=\"generatePassword()\">\r\n <i class=\"fa-solid fa-key\"></i>\r\n </button>\r\n </td>\r\n\r\n <!-- action copy pass -->\r\n <td *ngIf=\"actionCopy\">\r\n <button type=\"button\" [title]=\"'Copiar Senha'\" (click)=\"copyText()\">\r\n <i *ngIf=\"!isCopy\" class=\"fa-regular fa-copy\"></i>\r\n <i *ngIf=\"isCopy\" class=\"fa-solid fa-check\"></i>\r\n </button>\r\n </td>\r\n </tr>\r\n </table>\r\n</div>", styles: [".tcloud-ui-input-password{border:1px solid var(--tc-gray-300);border-radius:3px}.tcloud-ui-input-password table{width:100%}.tcloud-ui-input-password table td:first-child{width:100%!important}.tcloud-ui-input-password table td:first-child input{width:100%;border:none;height:38px;padding-left:8px}.tcloud-ui-input-password table td{width:50px;height:40px;background-color:#fff}.tcloud-ui-input-password table td button{background:transparent;border:none;margin-right:3px;cursor:pointer;color:var(--tc-gray-500)}.tcloud-ui-input-password table td button:hover{color:var(--tc-primary2)}.tcloud-ui-input-password .ng-invalid.ng-touched{border:1px solid var(--red)!important}\n"] }]
|
|
123
|
+
}], ctorParameters: function () { return []; }, propDecorators: { actionView: [{
|
|
124
|
+
type: Input
|
|
125
|
+
}], actionCopy: [{
|
|
126
|
+
type: Input
|
|
127
|
+
}], actionGeneratePassword: [{
|
|
128
|
+
type: Input
|
|
129
|
+
}], numberOfCharacter: [{
|
|
121
130
|
type: Input
|
|
122
131
|
}], atLeastOneUppercaseLetter: [{
|
|
123
132
|
type: Input
|
|
@@ -130,4 +139,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
130
139
|
}], ngModelChange: [{
|
|
131
140
|
type: Output
|
|
132
141
|
}] } });
|
|
133
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tcloud-ui-input-password.component.js","sourceRoot":"","sources":["../../../../../../projects/tcloud-ui/src/lib/_modules/tcloud-ui-input-password/tcloud-ui-input-password.component.ts","../../../../../../projects/tcloud-ui/src/lib/_modules/tcloud-ui-input-password/tcloud-ui-input-password.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, forwardRef } from '@angular/core';\r\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\r\n\r\nexport const CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR: any = {\r\n  provide: NG_VALUE_ACCESSOR,\r\n  useExisting: forwardRef(() => TCloudUiInputPasswordComponent),\r\n  multi: true\r\n};\r\n\r\nconst noop = () => {\r\n};\r\n\r\n@Component({\r\n  selector: 'tcloud-ui-input-password',\r\n  templateUrl: './tcloud-ui-input-password.component.html',\r\n  styleUrls: ['./tcloud-ui-input-password.component.scss'],\r\n  providers: [ CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR ],\r\n})\r\nexport class TCloudUiInputPasswordComponent implements OnInit {\r\n\r\n    @Input() numberOfCharacter: number = 14;\r\n\r\n    @Input() atLeastOneUppercaseLetter: boolean = true;\r\n    @Input() atLeastOneLowercaseLetter: boolean = true;\r\n    @Input() atLeastOneSpecialCharacter: boolean = true;\r\n\r\n  \r\n    innerValue: string = '';\r\n\r\n    private _ngModel: any | undefined;\r\n    @Input() set ngModel(v: any){\r\n        this.innerValue = v;      \r\n    }\r\n    @Output() ngModelChange = new EventEmitter<any>();\r\n\r\n    mode: string = 'password';\r\n    isCopy: boolean = false;\r\n    passwordRegex: any | undefined;\r\n\r\n    constructor() { }\r\n\r\n    ngOnInit(): void {\r\n        this.passwordRegex = this.getRegexValidation();\r\n    }\r\n\r\n    toggleMode(){\r\n        if( this.mode === 'password' ){\r\n            this.mode = 'text';\r\n        }else{\r\n            this.mode = 'password';\r\n        }\r\n    }\r\n\r\n    copyText(): void {\r\n        this.isCopy = true;\r\n        navigator.clipboard.writeText(this.innerValue);\r\n        setTimeout(() => { this.isCopy = false; }, 3000);\r\n    }\r\n\r\n    generatePassword(){\r\n        this.innerValue = this.createNewPass();\r\n    }\r\n\r\n    private createNewPass() {\r\n        const uppercaseLetters = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ';\r\n        const lowercaseLetters = 'abcdefghijklmnopqrstuvwxyz';\r\n        const numbers = '0123456789';\r\n        const specialCharacters = '!@#$%^&*()_+{}[]:;<>,.?/~';\r\n    \r\n        const allCharacters = uppercaseLetters + lowercaseLetters + numbers + specialCharacters;\r\n    \r\n        const getRandomCharacter = (characters: string) => {\r\n        const randomIndex = Math.floor(Math.random() * characters.length);\r\n        return characters[randomIndex];\r\n        };\r\n    \r\n        let password = '';\r\n        password += getRandomCharacter(uppercaseLetters);\r\n        password += getRandomCharacter(numbers);\r\n        password += getRandomCharacter(specialCharacters);\r\n    \r\n        const remainingLength = this.numberOfCharacter - password.length;  \r\n        for (let i = 0; i < remainingLength; i++) {\r\n        password += getRandomCharacter(allCharacters);\r\n        }  \r\n        password = password.split('').sort(() => Math.random() - 0.5).join('');  \r\n        return password;\r\n    }\r\n  \r\n\r\n    getRegexValidation() {\r\n        /*\r\n        (?=.*[A-Z]): Pelo menos uma letra maiúscula.\r\n        (?=.*[0-9]): Pelo menos um número.\r\n        (?=.*[!@#$%^&*()_+{}[\\]:;<>,.?\\/~]): Pelo menos um caractere especial.\r\n        (?!.*\\s): Não contém espaços em branco.\r\n        .{14,}: Pelo menos 14 caracteres no total.\r\n        */\r\n\r\n        const maiusculas = (this.atLeastOneUppercaseLetter) ? `(?=.*[A-Z])` : '';\r\n        const minusculas = (this.atLeastOneLowercaseLetter) ? `(?=.*[a-z])` : '';\r\n        const especiais  = (this.atLeastOneSpecialCharacter) ? `(?=.*[!@#$%^&*\\\\(\\\\)_+\\\\{\\\\}\\\\[\\\\]:;<>,.?\\\\/~])(?!.*\\\\s)`: '';\r\n\r\n        return `^${maiusculas}${minusculas}${especiais}.{${this.numberOfCharacter},}$`;\r\n    }\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n  \r\n  //Placeholders for the callbacks which are later providesd\r\n    //by the Control Value Accessor\r\n    private onTouchedCallback: () => void = noop;\r\n    private onChangeCallback: (_: any) => void = noop;\r\n\r\n    //get accessor\r\n    get value(): any {\r\n        return this.innerValue;\r\n    };\r\n\r\n    //set accessor including call the onchange callback\r\n    set value(v: any) {\r\n        if (v !== this.innerValue) {\r\n            this.innerValue = v;\r\n            this.onChangeCallback(v);\r\n        }\r\n    }\r\n\r\n    //Set touched on blur\r\n    onBlur() {\r\n        this.onTouchedCallback();\r\n    }\r\n\r\n    //From ControlValueAccessor interface\r\n    writeValue(value: any) {\r\n        if (value !== this.innerValue) {\r\n            this.innerValue = value;\r\n        }\r\n    }\r\n\r\n    //From ControlValueAccessor interface\r\n    registerOnChange(fn: any) {\r\n        this.onChangeCallback = fn;\r\n    }\r\n\r\n    //From ControlValueAccessor interface\r\n    registerOnTouched(fn: any) {\r\n        this.onTouchedCallback = fn;\r\n    }\r\n}\r\n","<div class=\"tcloud-ui-input-password\">\r\n    <table>\r\n        <tr>\r\n            <!-- input password -->\r\n            <td>\r\n                <form #_form=\"ngForm\">\r\n                    <ng-container *ngIf=\"passwordRegex\">\r\n                        <input class=\"tc-form-control\" *ngIf=\"mode == 'password'\" type=\"password\" name=\"tc_password\" [pattern]=\"passwordRegex\" autoComplete=\"new-password\" [(ngModel)]=\"innerValue\" required>\r\n                        <input class=\"tc-form-control\" *ngIf=\"mode == 'text'\" type=\"text\" name=\"tc_text\" [pattern]=\"passwordRegex\" [(ngModel)]=\"innerValue\" required>\r\n                    </ng-container>\r\n                </form>\r\n            </td>\r\n\r\n            <!-- action show hide -->\r\n            <td>\r\n                <button type=\"button\" (click)=\"toggleMode()\" [title]=\"(mode == 'password') ? 'Visualizar Senha' : 'Esconder Senha'\">\r\n                    <i *ngIf=\"mode == 'password'\" class=\"far fa-eye-slash\"></i>\r\n                    <i *ngIf=\"mode == 'text'\" class=\"far fa-eye\"></i> \r\n                </button>\r\n            </td>\r\n\r\n            <!-- action generate pass -->\r\n            <td>\r\n                <button type=\"button\" [title]=\"'Gerar Senha'\" (click)=\"generatePassword()\">\r\n                    <i class=\"fa-solid fa-key\"></i>\r\n                </button>\r\n            </td>\r\n\r\n            <!-- action copy pass -->\r\n            <td>\r\n                <button type=\"button\" [title]=\"'Copiar Senha'\" (click)=\"copyText()\">\r\n                    <i *ngIf=\"!isCopy\" class=\"fa-regular fa-copy\"></i>\r\n                    <i *ngIf=\"isCopy\" class=\"fa-solid fa-check\"></i>\r\n                </button>\r\n            </td>\r\n        </tr>\r\n    </table>\r\n</div>"]}
|
|
142
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tcloud-ui-input-password.component.js","sourceRoot":"","sources":["../../../../../../projects/tcloud-ui/src/lib/_modules/tcloud-ui-input-password/tcloud-ui-input-password.component.ts","../../../../../../projects/tcloud-ui/src/lib/_modules/tcloud-ui-input-password/tcloud-ui-input-password.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, forwardRef } from '@angular/core';\r\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\r\n\r\nexport const CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR: any = {\r\n  provide: NG_VALUE_ACCESSOR,\r\n  useExisting: forwardRef(() => TCloudUiInputPasswordComponent),\r\n  multi: true\r\n};\r\n\r\nconst noop = () => {\r\n};\r\n\r\n@Component({\r\n  selector: 'tcloud-ui-input-password',\r\n  templateUrl: './tcloud-ui-input-password.component.html',\r\n  styleUrls: ['./tcloud-ui-input-password.component.scss'],\r\n  providers: [ CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR ],\r\n})\r\nexport class TCloudUiInputPasswordComponent implements OnInit {\r\n\r\n    @Input() actionView: boolean = true;\r\n    @Input() actionCopy: boolean = true;\r\n    @Input() actionGeneratePassword: boolean = true;\r\n\r\n    @Input() numberOfCharacter: number = 14;\r\n\r\n    @Input() atLeastOneUppercaseLetter: boolean = true;\r\n    @Input() atLeastOneLowercaseLetter: boolean = true;\r\n    @Input() atLeastOneSpecialCharacter: boolean = true;\r\n\r\n  \r\n    innerValue: string = '';\r\n\r\n    private _ngModel: any | undefined;\r\n    @Input() set ngModel(v: any){\r\n        this.innerValue = v;      \r\n    }\r\n    @Output() ngModelChange = new EventEmitter<any>();\r\n\r\n    mode: string = 'password';\r\n    isCopy: boolean = false;\r\n    passwordRegex: any | undefined;\r\n\r\n    constructor() { }\r\n\r\n    ngOnInit(): void {\r\n        this.passwordRegex = this.getRegexValidation();\r\n    }\r\n\r\n    toggleMode(){\r\n        if( this.mode === 'password' ){\r\n            this.mode = 'text';\r\n        }else{\r\n            this.mode = 'password';\r\n        }\r\n    }\r\n\r\n    copyText(): void {\r\n        this.isCopy = true;\r\n        navigator.clipboard.writeText(this.innerValue);\r\n        setTimeout(() => { this.isCopy = false; }, 3000);\r\n    }\r\n\r\n    generatePassword(){\r\n        this.innerValue = this.createNewPass();\r\n    }\r\n\r\n    private createNewPass() {\r\n        const uppercaseLetters = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ';\r\n        const lowercaseLetters = 'abcdefghijklmnopqrstuvwxyz';\r\n        const numbers = '0123456789';\r\n        const specialCharacters = '!@#$%^&*()_+{}[]:;<>,.?/~';\r\n    \r\n        const allCharacters = uppercaseLetters + lowercaseLetters + numbers + specialCharacters;\r\n    \r\n        const getRandomCharacter = (characters: string) => {\r\n        const randomIndex = Math.floor(Math.random() * characters.length);\r\n        return characters[randomIndex];\r\n        };\r\n    \r\n        let password = '';\r\n        password += getRandomCharacter(uppercaseLetters);\r\n        password += getRandomCharacter(numbers);\r\n        password += getRandomCharacter(specialCharacters);\r\n    \r\n        const remainingLength = this.numberOfCharacter - password.length;  \r\n        for (let i = 0; i < remainingLength; i++) {\r\n        password += getRandomCharacter(allCharacters);\r\n        }  \r\n        password = password.split('').sort(() => Math.random() - 0.5).join('');  \r\n        return password;\r\n    }\r\n  \r\n\r\n    getRegexValidation() {\r\n        /*\r\n        (?=.*[A-Z]): Pelo menos uma letra maiúscula.\r\n        (?=.*[0-9]): Pelo menos um número.\r\n        (?=.*[!@#$%^&*()_+{}[\\]:;<>,.?\\/~]): Pelo menos um caractere especial.\r\n        (?!.*\\s): Não contém espaços em branco.\r\n        .{14,}: Pelo menos 14 caracteres no total.\r\n        */\r\n\r\n        const maiusculas = (this.atLeastOneUppercaseLetter) ? `(?=.*[A-Z])` : '';\r\n        const minusculas = (this.atLeastOneLowercaseLetter) ? `(?=.*[a-z])` : '';\r\n        const especiais  = (this.atLeastOneSpecialCharacter) ? `(?=.*[!@#$%^&*\\\\(\\\\)_+\\\\{\\\\}\\\\[\\\\]:;<>,.?\\\\/~])(?!.*\\\\s)`: '';\r\n\r\n        return `^${maiusculas}${minusculas}${especiais}.{${this.numberOfCharacter},}$`;\r\n    }\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n  \r\n  //Placeholders for the callbacks which are later providesd\r\n    //by the Control Value Accessor\r\n    private onTouchedCallback: () => void = noop;\r\n    private onChangeCallback: (_: any) => void = noop;\r\n\r\n    //get accessor\r\n    get value(): any {\r\n        return this.innerValue;\r\n    };\r\n\r\n    //set accessor including call the onchange callback\r\n    set value(v: any) {\r\n        if (v !== this.innerValue) {\r\n            this.innerValue = v;\r\n            this.onChangeCallback(v);\r\n        }\r\n    }\r\n\r\n    //Set touched on blur\r\n    onBlur() {\r\n        this.onTouchedCallback();\r\n    }\r\n\r\n    //From ControlValueAccessor interface\r\n    writeValue(value: any) {\r\n        if (value !== this.innerValue) {\r\n            this.innerValue = value;\r\n        }\r\n    }\r\n\r\n    //From ControlValueAccessor interface\r\n    registerOnChange(fn: any) {\r\n        this.onChangeCallback = fn;\r\n    }\r\n\r\n    //From ControlValueAccessor interface\r\n    registerOnTouched(fn: any) {\r\n        this.onTouchedCallback = fn;\r\n    }\r\n}\r\n","<div class=\"tcloud-ui-input-password\">\r\n    <table>\r\n        <tr>\r\n            <!-- input password -->\r\n            <td>\r\n                <form #_form=\"ngForm\">\r\n                    <ng-container *ngIf=\"passwordRegex\">\r\n                        <input class=\"tc-form-control\" *ngIf=\"mode == 'password'\" type=\"password\" name=\"tc_password\" [pattern]=\"passwordRegex\" autoComplete=\"new-password\" [(ngModel)]=\"innerValue\" required>\r\n                        <input class=\"tc-form-control\" *ngIf=\"mode == 'text'\" type=\"text\" name=\"tc_text\" [pattern]=\"passwordRegex\" [(ngModel)]=\"innerValue\" required>\r\n                    </ng-container>\r\n                </form>\r\n            </td>\r\n\r\n            <!-- action show hide -->\r\n            <td *ngIf=\"actionView\">\r\n                <button type=\"button\" (click)=\"toggleMode()\" [title]=\"(mode == 'password') ? 'Visualizar Senha' : 'Esconder Senha'\">\r\n                    <i *ngIf=\"mode == 'password'\" class=\"far fa-eye-slash\"></i>\r\n                    <i *ngIf=\"mode == 'text'\" class=\"far fa-eye\"></i> \r\n                </button>\r\n            </td>\r\n\r\n            <!-- action generate pass -->\r\n            <td *ngIf=\"actionGeneratePassword\">\r\n                <button type=\"button\" [title]=\"'Gerar Senha'\" (click)=\"generatePassword()\">\r\n                    <i class=\"fa-solid fa-key\"></i>\r\n                </button>\r\n            </td>\r\n\r\n            <!-- action copy pass -->\r\n            <td *ngIf=\"actionCopy\">\r\n                <button type=\"button\" [title]=\"'Copiar Senha'\" (click)=\"copyText()\">\r\n                    <i *ngIf=\"!isCopy\" class=\"fa-regular fa-copy\"></i>\r\n                    <i *ngIf=\"isCopy\" class=\"fa-solid fa-check\"></i>\r\n                </button>\r\n            </td>\r\n        </tr>\r\n    </table>\r\n</div>"]}
|
|
@@ -9,7 +9,15 @@ export class BytesPipe {
|
|
|
9
9
|
const c = 0 > b ? 0 : b, d = Math.floor(Math.log(a) / Math.log(1024));
|
|
10
10
|
return parseFloat((a / Math.pow(1024, d)).toFixed(c)) + ' ' + ["Bytes", "KB", "MB", "GB", "TB", "PB", "EB", "ZB", "YB"][d];
|
|
11
11
|
}
|
|
12
|
-
transform(value) {
|
|
12
|
+
transform(value, typeValue) {
|
|
13
|
+
if (typeValue !== undefined && typeValue !== null && typeValue !== '') {
|
|
14
|
+
if ((typeValue).toLowerCase() === 'kb') {
|
|
15
|
+
value = value * 1024;
|
|
16
|
+
}
|
|
17
|
+
if ((typeValue).toLowerCase() === 'mb') {
|
|
18
|
+
value = (value * 1024) * 1024;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
13
21
|
const b = +value;
|
|
14
22
|
return this.formatBytes(b);
|
|
15
23
|
}
|
|
@@ -20,4 +28,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImpo
|
|
|
20
28
|
type: Pipe,
|
|
21
29
|
args: [{ name: 'bytes' }]
|
|
22
30
|
}] });
|
|
23
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnl0ZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90Y2xvdWQtdWkvc3JjL2xpYi9fcGlwZXMvYnl0ZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUM7O0FBR3BELE1BQU0sT0FBTyxTQUFTO0lBRXBCLFdBQVcsQ0FBQyxDQUFTLEVBQUUsQ0FBQyxHQUFHLENBQUM7UUFDMUIsSUFBSSxDQUFDLENBQUM7WUFBRSxPQUFPLEtBQUssQ0FBQztRQUNyQixJQUFJLENBQUMsS0FBSyxDQUFDO1lBQUUsT0FBTyxTQUFTLENBQUM7UUFDOUIsTUFBTSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7UUFDdEUsT0FBTyxVQUFVLENBQUMsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxHQUFHLEdBQUcsQ0FBQyxPQUFPLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQzdILENBQUM7SUFFRCxTQUFTLENBQUMsS0FBVSxFQUFFLFNBQWtCO1FBRXRDLElBQUksU0FBUyxLQUFLLFNBQVMsSUFBSSxTQUFTLEtBQUssSUFBSSxJQUFJLFNBQVMsS0FBSyxFQUFFLEVBQUU7WUFFckUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLFdBQVcsRUFBRSxLQUFLLElBQUksRUFBRTtnQkFDdEMsS0FBSyxHQUFHLEtBQUssR0FBRyxJQUFJLENBQUE7YUFDckI7WUFFRCxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsV0FBVyxFQUFFLEtBQUssSUFBSSxFQUFFO2dCQUN0QyxLQUFLLEdBQUcsQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLEdBQUcsSUFBSSxDQUFBO2FBQzlCO1NBQ0Y7UUFFRCxNQUFNLENBQUMsR0FBVyxDQUFDLEtBQUssQ0FBQztRQUN2QixPQUFPLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDL0IsQ0FBQzs7dUdBeEJVLFNBQVM7cUdBQVQsU0FBUzs0RkFBVCxTQUFTO2tCQURyQixJQUFJO21CQUFDLEVBQUUsSUFBSSxFQUFFLE9BQU8sRUFBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBQaXBlKHsgbmFtZTogJ2J5dGVzJ30pXHJcbmV4cG9ydCBjbGFzcyBCeXRlc1BpcGUgaW1wbGVtZW50cyBQaXBlVHJhbnNmb3JtIHtcclxuXHJcbiAgZm9ybWF0Qnl0ZXMoYTogbnVtYmVyLCBiID0gMik6IHN0cmluZyB7XHJcbiAgICBpZiAoIWEpIHJldHVybiAnLS0tJztcclxuICAgIGlmICgwID09PSBhKSByZXR1cm4gJzAgQnl0ZXMnO1xyXG4gICAgY29uc3QgYyA9IDAgPiBiID8gMCA6IGIsIGQgPSBNYXRoLmZsb29yKE1hdGgubG9nKGEpIC8gTWF0aC5sb2coMTAyNCkpO1xyXG4gICAgcmV0dXJuIHBhcnNlRmxvYXQoKGEgLyBNYXRoLnBvdygxMDI0LCBkKSkudG9GaXhlZChjKSkgKyAnICcgKyBbXCJCeXRlc1wiLCBcIktCXCIsIFwiTUJcIiwgXCJHQlwiLCBcIlRCXCIsIFwiUEJcIiwgXCJFQlwiLCBcIlpCXCIsIFwiWUJcIl1bZF07XHJcbiAgfVxyXG4gIFxyXG4gIHRyYW5zZm9ybSh2YWx1ZTogYW55LCB0eXBlVmFsdWU/OiBzdHJpbmcpOiBzdHJpbmd7ICAgXHJcbiAgICBcclxuICAgIGlmKCB0eXBlVmFsdWUgIT09IHVuZGVmaW5lZCAmJiB0eXBlVmFsdWUgIT09IG51bGwgJiYgdHlwZVZhbHVlICE9PSAnJyApe1xyXG4gICAgICBcclxuICAgICAgaWYoICh0eXBlVmFsdWUpLnRvTG93ZXJDYXNlKCkgPT09ICdrYicgKXtcclxuICAgICAgICB2YWx1ZSA9IHZhbHVlICogMTAyNFxyXG4gICAgICB9XHJcblxyXG4gICAgICBpZiggKHR5cGVWYWx1ZSkudG9Mb3dlckNhc2UoKSA9PT0gJ21iJyApe1xyXG4gICAgICAgIHZhbHVlID0gKHZhbHVlICogMTAyNCkgKiAxMDI0XHJcbiAgICAgIH1cclxuICAgIH1cclxuICAgIFxyXG4gICAgY29uc3QgYjogbnVtYmVyID0gK3ZhbHVlOyAgICAgIFxyXG4gICAgICByZXR1cm4gdGhpcy5mb3JtYXRCeXRlcyhiKTtcclxuICB9XHJcbn0iXX0=
|
|
@@ -2118,7 +2118,15 @@ class BytesPipe {
|
|
|
2118
2118
|
const c = 0 > b ? 0 : b, d = Math.floor(Math.log(a) / Math.log(1024));
|
|
2119
2119
|
return parseFloat((a / Math.pow(1024, d)).toFixed(c)) + ' ' + ["Bytes", "KB", "MB", "GB", "TB", "PB", "EB", "ZB", "YB"][d];
|
|
2120
2120
|
}
|
|
2121
|
-
transform(value) {
|
|
2121
|
+
transform(value, typeValue) {
|
|
2122
|
+
if (typeValue !== undefined && typeValue !== null && typeValue !== '') {
|
|
2123
|
+
if ((typeValue).toLowerCase() === 'kb') {
|
|
2124
|
+
value = value * 1024;
|
|
2125
|
+
}
|
|
2126
|
+
if ((typeValue).toLowerCase() === 'mb') {
|
|
2127
|
+
value = (value * 1024) * 1024;
|
|
2128
|
+
}
|
|
2129
|
+
}
|
|
2122
2130
|
const b = +value;
|
|
2123
2131
|
return this.formatBytes(b);
|
|
2124
2132
|
}
|
|
@@ -4413,7 +4421,6 @@ class TCloudUiTooltipDirective {
|
|
|
4413
4421
|
this._direction = 'top';
|
|
4414
4422
|
}
|
|
4415
4423
|
onMouseOver(event) {
|
|
4416
|
-
var _a, _b, _c;
|
|
4417
4424
|
let hoverInCallback = () => {
|
|
4418
4425
|
this.remove = false;
|
|
4419
4426
|
};
|
|
@@ -4425,38 +4432,42 @@ class TCloudUiTooltipDirective {
|
|
|
4425
4432
|
}
|
|
4426
4433
|
};
|
|
4427
4434
|
hoverOutCallback;
|
|
4428
|
-
|
|
4429
|
-
|
|
4430
|
-
|
|
4431
|
-
|
|
4432
|
-
|
|
4433
|
-
|
|
4434
|
-
|
|
4435
|
-
|
|
4436
|
-
|
|
4437
|
-
|
|
4438
|
-
height =
|
|
4439
|
-
|
|
4440
|
-
|
|
4441
|
-
|
|
4442
|
-
|
|
4443
|
-
this.renderer.setStyle(tooltip, 'top', '0px');
|
|
4444
|
-
this.renderer.setStyle(tooltip, 'left', '0px');
|
|
4445
|
-
this.renderer.setStyle(tooltip, 'opacity', '0');
|
|
4446
|
-
this.renderer.addClass(tooltip, 'tc-directive-tooltip');
|
|
4447
|
-
this.renderer.addClass(tooltip, `tc-directive-tooltip-${direction}`);
|
|
4448
|
-
const id = this.generateID();
|
|
4449
|
-
this.renderer.setAttribute(tooltip, 'id', id);
|
|
4450
|
-
const textNode = this.info_text;
|
|
4451
|
-
if (textNode !== undefined && textNode !== null && textNode !== '') {
|
|
4452
|
-
tooltip.innerHTML = textNode;
|
|
4453
|
-
this.renderer.appendChild(document.body, tooltip);
|
|
4454
|
-
this.start_tooltip(id, height, width, el_position_x, el_position_y, direction);
|
|
4455
|
-
if (tooltip) {
|
|
4456
|
-
tooltip.addEventListener('mouseenter', hoverInCallback);
|
|
4457
|
-
tooltip.addEventListener('mouseleave', hoverOutCallback);
|
|
4435
|
+
setTimeout(() => {
|
|
4436
|
+
var _a;
|
|
4437
|
+
const scrollTop = window.scrollY || window.pageYOffset;
|
|
4438
|
+
const tooltip = this.renderer.createElement('div');
|
|
4439
|
+
const rect = (_a = this.el.nativeElement) === null || _a === void 0 ? void 0 : _a.getBoundingClientRect();
|
|
4440
|
+
// const direction = this.el.nativeElement?.attributes['ng-reflect--t-cdirection']?.value || 'top';
|
|
4441
|
+
const direction = this._direction || 'top';
|
|
4442
|
+
const el_position_x = (rect === null || rect === void 0 ? void 0 : rect.left) ? parseInt(rect === null || rect === void 0 ? void 0 : rect.left) : 0;
|
|
4443
|
+
const el_position_y = (rect === null || rect === void 0 ? void 0 : rect.top) ? parseInt((rect === null || rect === void 0 ? void 0 : rect.top) + scrollTop) : 0;
|
|
4444
|
+
let width = 0;
|
|
4445
|
+
let height = 0;
|
|
4446
|
+
if (event && event.target) {
|
|
4447
|
+
const _event = event.target;
|
|
4448
|
+
height = _event.offsetHeight;
|
|
4449
|
+
width = _event.offsetWidth;
|
|
4458
4450
|
}
|
|
4459
|
-
|
|
4451
|
+
const top = `${(el_position_y - ((height / 2) + 10))}px`;
|
|
4452
|
+
const left = `${el_position_x + (width / 2)}px`;
|
|
4453
|
+
this.renderer.setStyle(tooltip, 'top', '0px');
|
|
4454
|
+
this.renderer.setStyle(tooltip, 'left', '0px');
|
|
4455
|
+
this.renderer.setStyle(tooltip, 'opacity', '0');
|
|
4456
|
+
this.renderer.addClass(tooltip, 'tc-directive-tooltip');
|
|
4457
|
+
this.renderer.addClass(tooltip, `tc-directive-tooltip-${direction}`);
|
|
4458
|
+
const id = this.generateID();
|
|
4459
|
+
this.renderer.setAttribute(tooltip, 'id', id);
|
|
4460
|
+
const textNode = this.info_text;
|
|
4461
|
+
if (textNode !== undefined && textNode !== null && textNode !== '') {
|
|
4462
|
+
tooltip.innerHTML = textNode;
|
|
4463
|
+
this.renderer.appendChild(document.body, tooltip);
|
|
4464
|
+
this.start_tooltip(id, height, width, el_position_x, el_position_y, direction);
|
|
4465
|
+
if (tooltip) {
|
|
4466
|
+
tooltip.addEventListener('mouseenter', hoverInCallback);
|
|
4467
|
+
tooltip.addEventListener('mouseleave', hoverOutCallback);
|
|
4468
|
+
}
|
|
4469
|
+
}
|
|
4470
|
+
});
|
|
4460
4471
|
}
|
|
4461
4472
|
onMouseOut(event) {
|
|
4462
4473
|
this.remove = true;
|
|
@@ -4556,10 +4567,17 @@ class TCloudUiElCopyDirective {
|
|
|
4556
4567
|
this.setItemFuncCopy();
|
|
4557
4568
|
}
|
|
4558
4569
|
setItemFuncCopy() {
|
|
4570
|
+
var _a;
|
|
4559
4571
|
const btn_copy = this.renderer.createElement('i');
|
|
4560
4572
|
var copyText = () => {
|
|
4561
4573
|
const elementWithCopyAttribute = document.querySelector(`[data-el-copy="${id}"]`);
|
|
4562
|
-
|
|
4574
|
+
let copyText = '';
|
|
4575
|
+
if (elementWithCopyAttribute && elementWithCopyAttribute.tagName && (elementWithCopyAttribute.tagName).toUpperCase() === 'INPUT') {
|
|
4576
|
+
copyText = elementWithCopyAttribute === null || elementWithCopyAttribute === void 0 ? void 0 : elementWithCopyAttribute.value;
|
|
4577
|
+
}
|
|
4578
|
+
else {
|
|
4579
|
+
copyText = elementWithCopyAttribute === null || elementWithCopyAttribute === void 0 ? void 0 : elementWithCopyAttribute.textContent;
|
|
4580
|
+
}
|
|
4563
4581
|
navigator.clipboard.writeText(copyText);
|
|
4564
4582
|
this.renderer.removeClass(btn_copy, 'fa-copy');
|
|
4565
4583
|
this.renderer.addClass(btn_copy, 'fa-check');
|
|
@@ -4578,7 +4596,19 @@ class TCloudUiElCopyDirective {
|
|
|
4578
4596
|
this.renderer.setAttribute(btn_copy, 'id', id);
|
|
4579
4597
|
this.renderer.setAttribute(btn_copy, 'title', 'Copy');
|
|
4580
4598
|
this.renderer.listen(btn_copy, 'click', () => { copyText(); });
|
|
4581
|
-
|
|
4599
|
+
if (((this.el.nativeElement).tagName).toUpperCase() === 'INPUT') {
|
|
4600
|
+
let classList = (_a = this.el.nativeElement) === null || _a === void 0 ? void 0 : _a.classList;
|
|
4601
|
+
if (classList && (classList).length > 0 && ('tc-form-control').indexOf(classList) > -1) {
|
|
4602
|
+
this.renderer.addClass(btn_copy, 'tcloud-ui-el-input-copy-tc-form-control');
|
|
4603
|
+
}
|
|
4604
|
+
else {
|
|
4605
|
+
this.renderer.addClass(btn_copy, 'tcloud-ui-el-input-copy');
|
|
4606
|
+
}
|
|
4607
|
+
this.renderer.appendChild(this.el.nativeElement.parentNode, btn_copy);
|
|
4608
|
+
}
|
|
4609
|
+
else {
|
|
4610
|
+
this.renderer.appendChild(this.el.nativeElement, btn_copy);
|
|
4611
|
+
}
|
|
4582
4612
|
}
|
|
4583
4613
|
generateID(target) {
|
|
4584
4614
|
const ref = (target) ? `-${target}` : '';
|
|
@@ -5138,6 +5168,9 @@ const noop = () => {
|
|
|
5138
5168
|
};
|
|
5139
5169
|
class TCloudUiInputPasswordComponent {
|
|
5140
5170
|
constructor() {
|
|
5171
|
+
this.actionView = true;
|
|
5172
|
+
this.actionCopy = true;
|
|
5173
|
+
this.actionGeneratePassword = true;
|
|
5141
5174
|
this.numberOfCharacter = 14;
|
|
5142
5175
|
this.atLeastOneUppercaseLetter = true;
|
|
5143
5176
|
this.atLeastOneLowercaseLetter = true;
|
|
@@ -5239,11 +5272,17 @@ class TCloudUiInputPasswordComponent {
|
|
|
5239
5272
|
}
|
|
5240
5273
|
}
|
|
5241
5274
|
TCloudUiInputPasswordComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiInputPasswordComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
5242
|
-
TCloudUiInputPasswordComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: TCloudUiInputPasswordComponent, selector: "tcloud-ui-input-password", inputs: { numberOfCharacter: "numberOfCharacter", atLeastOneUppercaseLetter: "atLeastOneUppercaseLetter", atLeastOneLowercaseLetter: "atLeastOneLowercaseLetter", atLeastOneSpecialCharacter: "atLeastOneSpecialCharacter", ngModel: "ngModel" }, outputs: { ngModelChange: "ngModelChange" }, providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR], ngImport: i0, template: "<div class=\"tcloud-ui-input-password\">\r\n <table>\r\n <tr>\r\n <!-- input password -->\r\n <td>\r\n <form #_form=\"ngForm\">\r\n <ng-container *ngIf=\"passwordRegex\">\r\n <input class=\"tc-form-control\" *ngIf=\"mode == 'password'\" type=\"password\" name=\"tc_password\" [pattern]=\"passwordRegex\" autoComplete=\"new-password\" [(ngModel)]=\"innerValue\" required>\r\n <input class=\"tc-form-control\" *ngIf=\"mode == 'text'\" type=\"text\" name=\"tc_text\" [pattern]=\"passwordRegex\" [(ngModel)]=\"innerValue\" required>\r\n </ng-container>\r\n </form>\r\n </td>\r\n\r\n <!-- action show hide -->\r\n <td>\r\n <button type=\"button\" (click)=\"toggleMode()\" [title]=\"(mode == 'password') ? 'Visualizar Senha' : 'Esconder Senha'\">\r\n <i *ngIf=\"mode == 'password'\" class=\"far fa-eye-slash\"></i>\r\n <i *ngIf=\"mode == 'text'\" class=\"far fa-eye\"></i> \r\n </button>\r\n </td>\r\n\r\n <!-- action generate pass -->\r\n <td>\r\n <button type=\"button\" [title]=\"'Gerar Senha'\" (click)=\"generatePassword()\">\r\n <i class=\"fa-solid fa-key\"></i>\r\n </button>\r\n </td>\r\n\r\n <!-- action copy pass -->\r\n <td>\r\n <button type=\"button\" [title]=\"'Copiar Senha'\" (click)=\"copyText()\">\r\n <i *ngIf=\"!isCopy\" class=\"fa-regular fa-copy\"></i>\r\n <i *ngIf=\"isCopy\" class=\"fa-solid fa-check\"></i>\r\n </button>\r\n </td>\r\n </tr>\r\n </table>\r\n</div>", styles: [".tcloud-ui-input-password{border:1px solid var(--tc-gray-300);border-radius:3px}.tcloud-ui-input-password table{width:100%}.tcloud-ui-input-password table td:first-child{width:100%!important}.tcloud-ui-input-password table td:first-child input{width:100%;border:none;height:38px;padding-left:8px}.tcloud-ui-input-password table td{width:50px;height:40px;background-color:#fff}.tcloud-ui-input-password table td button{background:transparent;border:none;margin-right:3px;cursor:pointer;color:var(--tc-gray-500)}.tcloud-ui-input-password table td button:hover{color:var(--tc-primary2)}.tcloud-ui-input-password .ng-invalid.ng-touched{border:1px solid var(--red)!important}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i2.PatternValidator, selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: ["pattern"] }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i2.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }] });
|
|
5275
|
+
TCloudUiInputPasswordComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: TCloudUiInputPasswordComponent, selector: "tcloud-ui-input-password", inputs: { actionView: "actionView", actionCopy: "actionCopy", actionGeneratePassword: "actionGeneratePassword", numberOfCharacter: "numberOfCharacter", atLeastOneUppercaseLetter: "atLeastOneUppercaseLetter", atLeastOneLowercaseLetter: "atLeastOneLowercaseLetter", atLeastOneSpecialCharacter: "atLeastOneSpecialCharacter", ngModel: "ngModel" }, outputs: { ngModelChange: "ngModelChange" }, providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR], ngImport: i0, template: "<div class=\"tcloud-ui-input-password\">\r\n <table>\r\n <tr>\r\n <!-- input password -->\r\n <td>\r\n <form #_form=\"ngForm\">\r\n <ng-container *ngIf=\"passwordRegex\">\r\n <input class=\"tc-form-control\" *ngIf=\"mode == 'password'\" type=\"password\" name=\"tc_password\" [pattern]=\"passwordRegex\" autoComplete=\"new-password\" [(ngModel)]=\"innerValue\" required>\r\n <input class=\"tc-form-control\" *ngIf=\"mode == 'text'\" type=\"text\" name=\"tc_text\" [pattern]=\"passwordRegex\" [(ngModel)]=\"innerValue\" required>\r\n </ng-container>\r\n </form>\r\n </td>\r\n\r\n <!-- action show hide -->\r\n <td *ngIf=\"actionView\">\r\n <button type=\"button\" (click)=\"toggleMode()\" [title]=\"(mode == 'password') ? 'Visualizar Senha' : 'Esconder Senha'\">\r\n <i *ngIf=\"mode == 'password'\" class=\"far fa-eye-slash\"></i>\r\n <i *ngIf=\"mode == 'text'\" class=\"far fa-eye\"></i> \r\n </button>\r\n </td>\r\n\r\n <!-- action generate pass -->\r\n <td *ngIf=\"actionGeneratePassword\">\r\n <button type=\"button\" [title]=\"'Gerar Senha'\" (click)=\"generatePassword()\">\r\n <i class=\"fa-solid fa-key\"></i>\r\n </button>\r\n </td>\r\n\r\n <!-- action copy pass -->\r\n <td *ngIf=\"actionCopy\">\r\n <button type=\"button\" [title]=\"'Copiar Senha'\" (click)=\"copyText()\">\r\n <i *ngIf=\"!isCopy\" class=\"fa-regular fa-copy\"></i>\r\n <i *ngIf=\"isCopy\" class=\"fa-solid fa-check\"></i>\r\n </button>\r\n </td>\r\n </tr>\r\n </table>\r\n</div>", styles: [".tcloud-ui-input-password{border:1px solid var(--tc-gray-300);border-radius:3px}.tcloud-ui-input-password table{width:100%}.tcloud-ui-input-password table td:first-child{width:100%!important}.tcloud-ui-input-password table td:first-child input{width:100%;border:none;height:38px;padding-left:8px}.tcloud-ui-input-password table td{width:50px;height:40px;background-color:#fff}.tcloud-ui-input-password table td button{background:transparent;border:none;margin-right:3px;cursor:pointer;color:var(--tc-gray-500)}.tcloud-ui-input-password table td button:hover{color:var(--tc-primary2)}.tcloud-ui-input-password .ng-invalid.ng-touched{border:1px solid var(--red)!important}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i2.PatternValidator, selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: ["pattern"] }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i2.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }] });
|
|
5243
5276
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: TCloudUiInputPasswordComponent, decorators: [{
|
|
5244
5277
|
type: Component,
|
|
5245
|
-
args: [{ selector: 'tcloud-ui-input-password', providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR], template: "<div class=\"tcloud-ui-input-password\">\r\n <table>\r\n <tr>\r\n <!-- input password -->\r\n <td>\r\n <form #_form=\"ngForm\">\r\n <ng-container *ngIf=\"passwordRegex\">\r\n <input class=\"tc-form-control\" *ngIf=\"mode == 'password'\" type=\"password\" name=\"tc_password\" [pattern]=\"passwordRegex\" autoComplete=\"new-password\" [(ngModel)]=\"innerValue\" required>\r\n <input class=\"tc-form-control\" *ngIf=\"mode == 'text'\" type=\"text\" name=\"tc_text\" [pattern]=\"passwordRegex\" [(ngModel)]=\"innerValue\" required>\r\n </ng-container>\r\n </form>\r\n </td>\r\n\r\n <!-- action show hide -->\r\n <td>\r\n <button type=\"button\" (click)=\"toggleMode()\" [title]=\"(mode == 'password') ? 'Visualizar Senha' : 'Esconder Senha'\">\r\n <i *ngIf=\"mode == 'password'\" class=\"far fa-eye-slash\"></i>\r\n <i *ngIf=\"mode == 'text'\" class=\"far fa-eye\"></i> \r\n </button>\r\n </td>\r\n\r\n <!-- action generate pass -->\r\n <td>\r\n <button type=\"button\" [title]=\"'Gerar Senha'\" (click)=\"generatePassword()\">\r\n <i class=\"fa-solid fa-key\"></i>\r\n </button>\r\n </td>\r\n\r\n <!-- action copy pass -->\r\n <td>\r\n <button type=\"button\" [title]=\"'Copiar Senha'\" (click)=\"copyText()\">\r\n <i *ngIf=\"!isCopy\" class=\"fa-regular fa-copy\"></i>\r\n <i *ngIf=\"isCopy\" class=\"fa-solid fa-check\"></i>\r\n </button>\r\n </td>\r\n </tr>\r\n </table>\r\n</div>", styles: [".tcloud-ui-input-password{border:1px solid var(--tc-gray-300);border-radius:3px}.tcloud-ui-input-password table{width:100%}.tcloud-ui-input-password table td:first-child{width:100%!important}.tcloud-ui-input-password table td:first-child input{width:100%;border:none;height:38px;padding-left:8px}.tcloud-ui-input-password table td{width:50px;height:40px;background-color:#fff}.tcloud-ui-input-password table td button{background:transparent;border:none;margin-right:3px;cursor:pointer;color:var(--tc-gray-500)}.tcloud-ui-input-password table td button:hover{color:var(--tc-primary2)}.tcloud-ui-input-password .ng-invalid.ng-touched{border:1px solid var(--red)!important}\n"] }]
|
|
5246
|
-
}], ctorParameters: function () { return []; }, propDecorators: {
|
|
5278
|
+
args: [{ selector: 'tcloud-ui-input-password', providers: [CUSTOM_INPUT_CONTROL_VALUE_ACCESSOR], template: "<div class=\"tcloud-ui-input-password\">\r\n <table>\r\n <tr>\r\n <!-- input password -->\r\n <td>\r\n <form #_form=\"ngForm\">\r\n <ng-container *ngIf=\"passwordRegex\">\r\n <input class=\"tc-form-control\" *ngIf=\"mode == 'password'\" type=\"password\" name=\"tc_password\" [pattern]=\"passwordRegex\" autoComplete=\"new-password\" [(ngModel)]=\"innerValue\" required>\r\n <input class=\"tc-form-control\" *ngIf=\"mode == 'text'\" type=\"text\" name=\"tc_text\" [pattern]=\"passwordRegex\" [(ngModel)]=\"innerValue\" required>\r\n </ng-container>\r\n </form>\r\n </td>\r\n\r\n <!-- action show hide -->\r\n <td *ngIf=\"actionView\">\r\n <button type=\"button\" (click)=\"toggleMode()\" [title]=\"(mode == 'password') ? 'Visualizar Senha' : 'Esconder Senha'\">\r\n <i *ngIf=\"mode == 'password'\" class=\"far fa-eye-slash\"></i>\r\n <i *ngIf=\"mode == 'text'\" class=\"far fa-eye\"></i> \r\n </button>\r\n </td>\r\n\r\n <!-- action generate pass -->\r\n <td *ngIf=\"actionGeneratePassword\">\r\n <button type=\"button\" [title]=\"'Gerar Senha'\" (click)=\"generatePassword()\">\r\n <i class=\"fa-solid fa-key\"></i>\r\n </button>\r\n </td>\r\n\r\n <!-- action copy pass -->\r\n <td *ngIf=\"actionCopy\">\r\n <button type=\"button\" [title]=\"'Copiar Senha'\" (click)=\"copyText()\">\r\n <i *ngIf=\"!isCopy\" class=\"fa-regular fa-copy\"></i>\r\n <i *ngIf=\"isCopy\" class=\"fa-solid fa-check\"></i>\r\n </button>\r\n </td>\r\n </tr>\r\n </table>\r\n</div>", styles: [".tcloud-ui-input-password{border:1px solid var(--tc-gray-300);border-radius:3px}.tcloud-ui-input-password table{width:100%}.tcloud-ui-input-password table td:first-child{width:100%!important}.tcloud-ui-input-password table td:first-child input{width:100%;border:none;height:38px;padding-left:8px}.tcloud-ui-input-password table td{width:50px;height:40px;background-color:#fff}.tcloud-ui-input-password table td button{background:transparent;border:none;margin-right:3px;cursor:pointer;color:var(--tc-gray-500)}.tcloud-ui-input-password table td button:hover{color:var(--tc-primary2)}.tcloud-ui-input-password .ng-invalid.ng-touched{border:1px solid var(--red)!important}\n"] }]
|
|
5279
|
+
}], ctorParameters: function () { return []; }, propDecorators: { actionView: [{
|
|
5280
|
+
type: Input
|
|
5281
|
+
}], actionCopy: [{
|
|
5282
|
+
type: Input
|
|
5283
|
+
}], actionGeneratePassword: [{
|
|
5284
|
+
type: Input
|
|
5285
|
+
}], numberOfCharacter: [{
|
|
5247
5286
|
type: Input
|
|
5248
5287
|
}], atLeastOneUppercaseLetter: [{
|
|
5249
5288
|
type: Input
|