@evotor-dev/ui-kit 7.12.0 → 7.13.0
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/common/evo-base-control.mjs +1 -1
- package/esm2020/lib/components/evo-autocomplete/components/evo-autocomplete/evo-autocomplete.component.mjs +8 -4
- package/esm2020/lib/components/evo-checkbox/evo-checkbox.component.mjs +10 -16
- package/esm2020/lib/components/evo-chip/evo-chip.component.mjs +32 -26
- package/esm2020/lib/components/evo-input/evo-input.component.mjs +28 -25
- package/esm2020/lib/components/evo-textarea/evo-textarea.component.mjs +34 -27
- package/esm2020/lib/components/evo-textarea/evo-textarea.module.mjs +5 -22
- package/esm2020/lib/components/evo-toggle/evo-toggle.component.mjs +14 -16
- package/fesm2015/evotor-dev-ui-kit.mjs +116 -121
- package/fesm2015/evotor-dev-ui-kit.mjs.map +1 -1
- package/fesm2020/evotor-dev-ui-kit.mjs +116 -121
- package/fesm2020/evotor-dev-ui-kit.mjs.map +1 -1
- package/lib/components/evo-autocomplete/components/evo-autocomplete/evo-autocomplete.component.d.ts +1 -0
- package/lib/components/evo-checkbox/evo-checkbox.component.d.ts +3 -5
- package/lib/components/evo-chip/evo-chip.component.d.ts +9 -5
- package/lib/components/evo-input/evo-input.component.d.ts +6 -5
- package/lib/components/evo-textarea/evo-textarea.component.d.ts +10 -8
- package/lib/components/evo-textarea/evo-textarea.module.d.ts +3 -4
- package/lib/components/evo-toggle/evo-toggle.component.d.ts +4 -5
- package/package.json +1 -1
|
@@ -1,7 +1,9 @@
|
|
|
1
|
-
import { Component, EventEmitter, forwardRef, Input, Output } from '@angular/core';
|
|
1
|
+
import { Component, EventEmitter, forwardRef, Input, Output, } from '@angular/core';
|
|
2
2
|
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
+
import { Subject } from 'rxjs';
|
|
3
4
|
import { EvoBaseControl } from '../../common/evo-base-control';
|
|
4
5
|
import { EvoControlStates } from '../../common/evo-control-state-manager/evo-control-states.enum';
|
|
6
|
+
import { takeUntil } from 'rxjs/operators';
|
|
5
7
|
import * as i0 from "@angular/core";
|
|
6
8
|
import * as i1 from "../evo-icon/evo-icon.component";
|
|
7
9
|
import * as i2 from "../../directives/evo-ui-class.directive";
|
|
@@ -19,51 +21,50 @@ export var EvoChipTheme;
|
|
|
19
21
|
EvoChipTheme["white"] = "white";
|
|
20
22
|
})(EvoChipTheme || (EvoChipTheme = {}));
|
|
21
23
|
export class EvoChipComponent extends EvoBaseControl {
|
|
22
|
-
constructor() {
|
|
23
|
-
super(
|
|
24
|
+
constructor(injector, cdr) {
|
|
25
|
+
super(injector);
|
|
26
|
+
this.injector = injector;
|
|
27
|
+
this.cdr = cdr;
|
|
24
28
|
this.closeTitle = '';
|
|
25
29
|
this.close = new EventEmitter();
|
|
26
30
|
this.templateVariables = {
|
|
27
31
|
chipTypes: EvoChipType,
|
|
28
32
|
chipThemes: EvoChipTheme,
|
|
29
33
|
};
|
|
34
|
+
this.destroy$ = new Subject();
|
|
30
35
|
}
|
|
31
36
|
set setInitialValue(value) {
|
|
32
37
|
this.inheritedValue = value;
|
|
33
38
|
}
|
|
34
39
|
get classes() {
|
|
35
40
|
const states = {
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
41
|
+
touched: this.control?.touched,
|
|
42
|
+
valid: this.currentState[EvoControlStates.valid],
|
|
43
|
+
invalid: this.currentState[EvoControlStates.invalid],
|
|
44
|
+
disabled: this.control?.disabled,
|
|
40
45
|
};
|
|
41
|
-
const result = Object.keys(states)
|
|
42
|
-
.filter((key) => states[key]);
|
|
46
|
+
const result = Object.keys(states).filter((key) => states[key]);
|
|
43
47
|
result.push(`theme-${this.theme || EvoChipTheme.grey}`);
|
|
44
48
|
result.push(`type-${this.type}`);
|
|
45
49
|
return result;
|
|
46
50
|
}
|
|
47
|
-
get value() {
|
|
48
|
-
return this._value;
|
|
49
|
-
}
|
|
50
|
-
set value(value) {
|
|
51
|
-
this._value = value;
|
|
52
|
-
this.onChange(value);
|
|
53
|
-
this.onTouched();
|
|
54
|
-
}
|
|
55
51
|
ngOnInit() {
|
|
56
52
|
this.initDefaultParams();
|
|
57
53
|
}
|
|
58
54
|
ngAfterViewInit() {
|
|
59
55
|
if (this.control) {
|
|
60
|
-
this.control.valueChanges.subscribe(() => {
|
|
56
|
+
this.control.valueChanges.pipe(takeUntil(this.destroy$)).subscribe(() => {
|
|
61
57
|
this.writeValue(this.control.value);
|
|
62
58
|
});
|
|
63
59
|
}
|
|
64
60
|
}
|
|
61
|
+
ngOnDestroy() {
|
|
62
|
+
this.destroy$.next();
|
|
63
|
+
this.destroy$.complete();
|
|
64
|
+
}
|
|
65
65
|
writeValue(value) {
|
|
66
|
-
this.
|
|
66
|
+
this.value = value;
|
|
67
|
+
this.cdr.markForCheck();
|
|
67
68
|
}
|
|
68
69
|
registerOnChange(fn) {
|
|
69
70
|
this.onChange = fn;
|
|
@@ -71,8 +72,15 @@ export class EvoChipComponent extends EvoBaseControl {
|
|
|
71
72
|
registerOnTouched(fn) {
|
|
72
73
|
this.onTouched = fn;
|
|
73
74
|
}
|
|
75
|
+
setDisabledState(state) {
|
|
76
|
+
this.disabled = state;
|
|
77
|
+
this.cdr.markForCheck();
|
|
78
|
+
}
|
|
74
79
|
onInputChange(value) {
|
|
75
80
|
this.value = value;
|
|
81
|
+
this.onChange(value);
|
|
82
|
+
this.onTouched();
|
|
83
|
+
this.cdr.markForCheck();
|
|
76
84
|
}
|
|
77
85
|
onCloseClick(e) {
|
|
78
86
|
this.close.emit(e);
|
|
@@ -85,12 +93,10 @@ export class EvoChipComponent extends EvoBaseControl {
|
|
|
85
93
|
this.theme = EvoChipTheme.grey;
|
|
86
94
|
}
|
|
87
95
|
}
|
|
88
|
-
onChange(
|
|
89
|
-
}
|
|
90
|
-
onTouched() {
|
|
91
|
-
}
|
|
96
|
+
onChange(_value) { }
|
|
97
|
+
onTouched() { }
|
|
92
98
|
}
|
|
93
|
-
EvoChipComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: EvoChipComponent, deps:
|
|
99
|
+
EvoChipComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: EvoChipComponent, deps: [{ token: i0.Injector }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
94
100
|
EvoChipComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: EvoChipComponent, selector: "evo-chip", inputs: { type: "type", theme: "theme", counter: "counter", disabled: "disabled", name: "name", closable: "closable", closeTitle: "closeTitle", setInitialValue: ["value", "setInitialValue"] }, outputs: { close: "close" }, providers: [
|
|
95
101
|
{
|
|
96
102
|
provide: NG_VALUE_ACCESSOR,
|
|
@@ -107,7 +113,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
107
113
|
multi: true,
|
|
108
114
|
},
|
|
109
115
|
], template: "<label class=\"chip\" [evoUiClass]=\"classes\">\n <ng-container [ngSwitch]=\"type\">\n <input\n *ngSwitchCase=\"templateVariables?.chipTypes.checkbox\"\n type=\"checkbox\"\n [disabled]=\"disabled\"\n [ngModel]=\"value\"\n [value]=\"inheritedValue\"\n (ngModelChange)=\"onInputChange($event)\"\n [name]=\"name\"\n />\n <input\n *ngSwitchCase=\"templateVariables?.chipTypes.radio\"\n type=\"radio\"\n [disabled]=\"disabled\"\n [ngModel]=\"value\"\n [value]=\"inheritedValue\"\n (ngModelChange)=\"onInputChange($event)\"\n [name]=\"name\"\n />\n </ng-container>\n <div\n class=\"chip__label\"\n [evoUiClass]=\"{'disabled': disabled}\"\n >\n <span class=\"chip__text\">\n <ng-content></ng-content>\n </span>\n <div\n class=\"chip__counter\"\n *ngIf=\"(type !== templateVariables?.chipTypes.label || !closable) && counter !== undefined\"\n >\n <span class=\"chip__counter-value\">\n {{ counter }}\n </span>\n </div>\n <button\n class=\"chip__close\"\n *ngIf=\"closable\"\n [disabled]=\"disabled\"\n [title]=\"closeTitle\"\n (click)=\"onCloseClick($event)\"\n type=\"button\"\n >\n <evo-icon shape=\"decline\"></evo-icon>\n </button>\n </div>\n</label>\n", styles: [".chip{position:relative;display:inline-flex;max-width:100%}.chip__label{display:flex;align-items:center;max-width:inherit;height:32px;margin:0;padding:3px 12px;overflow:hidden;color:#0986e2;font-family:var(--evo-font);font-style:normal;font-size:14px;line-height:24px;font-weight:600;background-color:#f4f6f8;border-radius:16px;cursor:pointer;transition:color .3s,background-color .3s;-webkit-user-select:none;user-select:none}.chip input{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}.chip input:disabled+.chip__label,.chip .chip__label_disabled{color:#fff!important;background-color:#c6c6c6!important}.chip input:checked+.chip__label{color:#fff;background-color:#0986e2}.chip input:checked+.chip__label:focus,.chip input:checked+.chip__label:hover{background-color:#3a9ee8}.chip input:checked+.chip__label:active{background-color:#0879cb}.chip input:not(:checked)+.chip__label{color:#0986e2}.chip_theme-white:not(.chip_type-label) input:not(:checked)+.chip__label{background-color:#fff}.chip_theme-white:not(.chip_type-label) input:not(:checked):focus+.chip__label,.chip_theme-white:not(.chip_type-label) input:not(:checked):hover+.chip__label{background-color:#fdfdfe}.chip_theme-white:not(.chip_type-label) input:not(:checked):active+.chip__label{background-color:#dcdddf}.chip_theme-grey:not(.chip_type-label) input:not(:checked)+.chip__label{background-color:#f4f6f8}.chip_theme-grey:not(.chip_type-label) input:not(:checked):focus+.chip__label,.chip_theme-grey:not(.chip_type-label) input:not(:checked):hover+.chip__label{background-color:#f6f8f9}.chip_theme-grey:not(.chip_type-label) input:not(:checked):active+.chip__label{background-color:#dcdddf}.chip_type-label .chip__label{color:#fff;background-color:#0986e2;cursor:default}.chip__text{display:inline-block;align-items:center;max-width:100%;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.chip__counter{display:flex;justify-content:center;align-items:center;min-width:18px;min-height:18px;margin-right:-5px;margin-left:8px;overflow:hidden;color:#fff;font-weight:700;font-size:12px;background-color:#f05023;border-radius:9px}.chip__counter-value{margin:0 3px;line-height:16px}.chip__close{position:relative;display:block;width:24px;height:24px;margin:0 -9px 0 8px;padding:0;color:#fff;background:none;border:none;cursor:pointer;transition:opacity .3s}.chip__close:not(:disabled):hover{opacity:.8}.chip__close:not(:disabled):active{opacity:.9}.chip__close evo-icon{z-index:1;display:block;width:100%;height:100%;fill:currentColor}:host{display:inline-block;max-width:100%}\n"] }]
|
|
110
|
-
}], propDecorators: { type: [{
|
|
116
|
+
}], ctorParameters: function () { return [{ type: i0.Injector }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { type: [{
|
|
111
117
|
type: Input
|
|
112
118
|
}], theme: [{
|
|
113
119
|
type: Input
|
|
@@ -127,4 +133,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
127
133
|
}], close: [{
|
|
128
134
|
type: Output
|
|
129
135
|
}] } });
|
|
130
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"evo-chip.component.js","sourceRoot":"","sources":["../../../../../../projects/evo-ui-kit/src/lib/components/evo-chip/evo-chip.component.ts","../../../../../../projects/evo-ui-kit/src/lib/components/evo-chip/evo-chip.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAiB,SAAS,EAAE,YAAY,EAAE,UAAU,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAC1G,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACzE,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAC/D,OAAO,EAAE,gBAAgB,EAAE,MAAM,gEAAgE,CAAC;;;;;;AAElG,MAAM,CAAN,IAAY,WAIX;AAJD,WAAY,WAAW;IACnB,8BAAe,CAAA;IACf,oCAAqB,CAAA;IACrB,8BAAe,CAAA;AACnB,CAAC,EAJW,WAAW,KAAX,WAAW,QAItB;AAED,MAAM,CAAN,IAAY,YAGX;AAHD,WAAY,YAAY;IACpB,6BAAa,CAAA;IACb,+BAAe,CAAA;AACnB,CAAC,EAHW,YAAY,KAAZ,YAAY,QAGvB;AAgBD,MAAM,OAAO,gBAAiB,SAAQ,cAAc;IAdpD;;QAsBa,eAAU,GAAG,EAAE,CAAC;QAMf,UAAK,GAAG,IAAI,YAAY,EAAS,CAAC;QAI5C,sBAAiB,GAAG;YAChB,SAAS,EAAE,WAAW;YACtB,UAAU,EAAE,YAAY;SAC3B,CAAC;KA8EL;IAzFG,IAAoB,eAAe,CAAC,KAAU;QAC1C,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;IAChC,CAAC;IAaD,IAAI,OAAO;QACP,MAAM,MAAM,GAAG;YACX,SAAS,EAAE,IAAI,CAAC,OAAO,EAAE,OAAO;YAChC,OAAO,EAAE,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,KAAK,CAAC;YAClD,SAAS,EAAE,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,OAAO,CAAC;YACtD,UAAU,EAAE,IAAI,CAAC,OAAO,EAAE,QAAQ;SACrC,CAAC;QAEF,MAAM,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC;aAC7B,MAAM,CAAC,CAAC,GAAW,EAAE,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;QAE1C,MAAM,CAAC,IAAI,CAAC,SAAU,IAAI,CAAC,KAAK,IAAI,YAAY,CAAC,IAAK,EAAE,CAAC,CAAC;QAE1D,MAAM,CAAC,IAAI,CAAC,QAAS,IAAI,CAAC,IAAK,EAAE,CAAC,CAAC;QAEnC,OAAO,MAAM,CAAC;IAClB,CAAC;IAED,IAAI,KAAK;QACL,OAAO,IAAI,CAAC,MAAM,CAAC;IACvB,CAAC;IAED,IAAI,KAAK,CAAC,KAAU;QAChB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACrB,IAAI,CAAC,SAAS,EAAE,CAAC;IACrB,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC7B,CAAC;IAED,eAAe;QACX,IAAI,IAAI,CAAC,OAAO,EAAE;YACd,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,SAAS,CAAC,GAAG,EAAE;gBACrC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;YACxC,CAAC,CAAC,CAAC;SACN;IACL,CAAC;IAED,UAAU,CAAC,KAAU;QACjB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;IACxB,CAAC;IAED,gBAAgB,CAAC,EAAO;QACpB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACvB,CAAC;IAED,iBAAiB,CAAC,EAAO;QACrB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACxB,CAAC;IAED,aAAa,CAAC,KAAK;QACf,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACvB,CAAC;IAED,YAAY,CAAC,CAAQ;QACjB,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACvB,CAAC;IAEO,iBAAiB;QACrB,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE;YACZ,IAAI,CAAC,IAAI,GAAG,WAAW,CAAC,KAAK,CAAC;SACjC;QACD,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;YACb,IAAI,CAAC,KAAK,GAAG,YAAY,CAAC,IAAI,CAAC;SAClC;IACL,CAAC;IAEO,QAAQ,CAAC,KAAK;IACtB,CAAC;IAEO,SAAS;IACjB,CAAC;;6GAlGQ,gBAAgB;iGAAhB,gBAAgB,iQARd;QACP;YACI,OAAO,EAAE,iBAAiB;YAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,gBAAgB,CAAC;YAC/C,KAAK,EAAE,IAAI;SACd;KACJ,iDC5BL,4hDAgDA;2FDlBa,gBAAgB;kBAd5B,SAAS;+BACI,UAAU,aAKT;wBACP;4BACI,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,iBAAiB,CAAC;4BAC/C,KAAK,EAAE,IAAI;yBACd;qBACJ;8BAIQ,IAAI;sBAAZ,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBAEc,eAAe;sBAAlC,KAAK;uBAAC,OAAO;gBAIJ,KAAK;sBAAd,MAAM","sourcesContent":["import { AfterViewInit, Component, EventEmitter, forwardRef, Input, OnInit, Output } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { EvoBaseControl } from '../../common/evo-base-control';\nimport { EvoControlStates } from '../../common/evo-control-state-manager/evo-control-states.enum';\n\nexport enum EvoChipType {\n    radio = 'radio', // default\n    checkbox = 'checkbox',\n    label = 'label',\n}\n\nexport enum EvoChipTheme {\n    grey = 'grey', // default\n    white = 'white',\n}\n\n@Component({\n    selector: 'evo-chip',\n    templateUrl: 'evo-chip.component.html',\n    styleUrls: [\n        'evo-chip.component.scss',\n    ],\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => EvoChipComponent),\n            multi: true,\n        },\n    ],\n})\nexport class EvoChipComponent extends EvoBaseControl implements ControlValueAccessor, OnInit, AfterViewInit {\n\n    @Input() type: EvoChipType | string;\n    @Input() theme: EvoChipTheme | string;\n    @Input() counter: number;\n    @Input() disabled: boolean;\n    @Input() name: string;\n    @Input() closable: boolean;\n    @Input() closeTitle = '';\n\n    @Input('value') set setInitialValue(value: any) {\n        this.inheritedValue = value;\n    }\n\n    @Output() close = new EventEmitter<Event>();\n\n    inheritedValue: any;\n\n    templateVariables = {\n        chipTypes: EvoChipType,\n        chipThemes: EvoChipTheme,\n    };\n\n    private _value: any;\n\n    get classes(): string[] {\n        const states = {\n            'touched': this.control?.touched,\n            'valid': this.currentState[EvoControlStates.valid],\n            'invalid': this.currentState[EvoControlStates.invalid],\n            'disabled': this.control?.disabled,\n        };\n\n        const result = Object.keys(states)\n            .filter((key: string) => states[key]);\n\n        result.push(`theme-${ this.theme || EvoChipTheme.grey }`);\n\n        result.push(`type-${ this.type }`);\n\n        return result;\n    }\n\n    get value(): any {\n        return this._value;\n    }\n\n    set value(value: any) {\n        this._value = value;\n        this.onChange(value);\n        this.onTouched();\n    }\n\n    ngOnInit(): void {\n        this.initDefaultParams();\n    }\n\n    ngAfterViewInit() {\n        if (this.control) {\n            this.control.valueChanges.subscribe(() => {\n                this.writeValue(this.control.value);\n            });\n        }\n    }\n\n    writeValue(value: any): void {\n        this._value = value;\n    }\n\n    registerOnChange(fn: any): void {\n        this.onChange = fn;\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouched = fn;\n    }\n\n    onInputChange(value): void {\n        this.value = value;\n    }\n\n    onCloseClick(e: Event): void {\n        this.close.emit(e);\n    }\n\n    private initDefaultParams(): void {\n        if (!this.type) {\n            this.type = EvoChipType.radio;\n        }\n        if (!this.theme) {\n            this.theme = EvoChipTheme.grey;\n        }\n    }\n\n    private onChange(value): void {\n    }\n\n    private onTouched(): void {\n    }\n}\n","<label class=\"chip\" [evoUiClass]=\"classes\">\n    <ng-container [ngSwitch]=\"type\">\n        <input\n            *ngSwitchCase=\"templateVariables?.chipTypes.checkbox\"\n            type=\"checkbox\"\n            [disabled]=\"disabled\"\n            [ngModel]=\"value\"\n            [value]=\"inheritedValue\"\n            (ngModelChange)=\"onInputChange($event)\"\n            [name]=\"name\"\n        />\n        <input\n            *ngSwitchCase=\"templateVariables?.chipTypes.radio\"\n            type=\"radio\"\n            [disabled]=\"disabled\"\n            [ngModel]=\"value\"\n            [value]=\"inheritedValue\"\n            (ngModelChange)=\"onInputChange($event)\"\n            [name]=\"name\"\n        />\n    </ng-container>\n    <div\n        class=\"chip__label\"\n        [evoUiClass]=\"{'disabled': disabled}\"\n    >\n        <span class=\"chip__text\">\n            <ng-content></ng-content>\n        </span>\n        <div\n            class=\"chip__counter\"\n            *ngIf=\"(type !== templateVariables?.chipTypes.label || !closable) && counter !== undefined\"\n        >\n            <span class=\"chip__counter-value\">\n                {{ counter }}\n            </span>\n        </div>\n        <button\n            class=\"chip__close\"\n            *ngIf=\"closable\"\n            [disabled]=\"disabled\"\n            [title]=\"closeTitle\"\n            (click)=\"onCloseClick($event)\"\n            type=\"button\"\n        >\n            <evo-icon shape=\"decline\"></evo-icon>\n        </button>\n    </div>\n</label>\n"]}
|
|
136
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"evo-chip.component.js","sourceRoot":"","sources":["../../../../../../projects/evo-ui-kit/src/lib/components/evo-chip/evo-chip.component.ts","../../../../../../projects/evo-ui-kit/src/lib/components/evo-chip/evo-chip.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectorRef,\n    Component,\n    EventEmitter,\n    forwardRef,\n    Injector,\n    Input,\n    OnInit,\n    OnDestroy,\n    Output,\n} from '@angular/core';\nimport {ControlValueAccessor, NG_VALUE_ACCESSOR} from '@angular/forms';\nimport {Subject} from 'rxjs';\nimport {EvoBaseControl} from '../../common/evo-base-control';\nimport {EvoControlStates} from '../../common/evo-control-state-manager/evo-control-states.enum';\nimport {takeUntil} from 'rxjs/operators';\n\nexport enum EvoChipType {\n    radio = 'radio', // default\n    checkbox = 'checkbox',\n    label = 'label',\n}\n\nexport enum EvoChipTheme {\n    grey = 'grey', // default\n    white = 'white',\n}\n\n@Component({\n    selector: 'evo-chip',\n    templateUrl: 'evo-chip.component.html',\n    styleUrls: ['evo-chip.component.scss'],\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => EvoChipComponent),\n            multi: true,\n        },\n    ],\n})\nexport class EvoChipComponent extends EvoBaseControl implements ControlValueAccessor, OnInit, AfterViewInit, OnDestroy {\n    @Input() type: EvoChipType | string;\n    @Input() theme: EvoChipTheme | string;\n    @Input() counter: number;\n    @Input() disabled: boolean;\n    @Input() name: string;\n    @Input() closable: boolean;\n    @Input() closeTitle = '';\n\n    @Input('value') set setInitialValue(value: any) {\n        this.inheritedValue = value;\n    }\n\n    @Output() close = new EventEmitter<Event>();\n\n    inheritedValue: any;\n    value: any;\n\n    templateVariables = {\n        chipTypes: EvoChipType,\n        chipThemes: EvoChipTheme,\n    };\n\n    private readonly destroy$ = new Subject<void>();\n\n    constructor(protected injector: Injector, private readonly cdr: ChangeDetectorRef) {\n        super(injector);\n    }\n\n    get classes(): string[] {\n        const states = {\n            touched: this.control?.touched,\n            valid: this.currentState[EvoControlStates.valid],\n            invalid: this.currentState[EvoControlStates.invalid],\n            disabled: this.control?.disabled,\n        };\n\n        const result = Object.keys(states).filter((key: string) => states[key]);\n\n        result.push(`theme-${this.theme || EvoChipTheme.grey}`);\n\n        result.push(`type-${this.type}`);\n\n        return result;\n    }\n\n    ngOnInit(): void {\n        this.initDefaultParams();\n    }\n\n    ngAfterViewInit(): void {\n        if (this.control) {\n            this.control.valueChanges.pipe(takeUntil(this.destroy$)).subscribe(() => {\n                this.writeValue(this.control.value);\n            });\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n\n    writeValue(value: any): void {\n        this.value = value;\n        this.cdr.markForCheck();\n    }\n\n    registerOnChange(fn: any): void {\n        this.onChange = fn;\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouched = fn;\n    }\n\n    setDisabledState(state: boolean): void {\n        this.disabled = state;\n        this.cdr.markForCheck();\n    }\n\n    onInputChange(value: any): void {\n        this.value = value;\n        this.onChange(value);\n        this.onTouched();\n        this.cdr.markForCheck();\n    }\n\n    onCloseClick(e: Event): void {\n        this.close.emit(e);\n    }\n\n    private initDefaultParams(): void {\n        if (!this.type) {\n            this.type = EvoChipType.radio;\n        }\n        if (!this.theme) {\n            this.theme = EvoChipTheme.grey;\n        }\n    }\n\n    private onChange(_value: any): void {}\n    private onTouched(): void {}\n}\n","<label class=\"chip\" [evoUiClass]=\"classes\">\n    <ng-container [ngSwitch]=\"type\">\n        <input\n            *ngSwitchCase=\"templateVariables?.chipTypes.checkbox\"\n            type=\"checkbox\"\n            [disabled]=\"disabled\"\n            [ngModel]=\"value\"\n            [value]=\"inheritedValue\"\n            (ngModelChange)=\"onInputChange($event)\"\n            [name]=\"name\"\n        />\n        <input\n            *ngSwitchCase=\"templateVariables?.chipTypes.radio\"\n            type=\"radio\"\n            [disabled]=\"disabled\"\n            [ngModel]=\"value\"\n            [value]=\"inheritedValue\"\n            (ngModelChange)=\"onInputChange($event)\"\n            [name]=\"name\"\n        />\n    </ng-container>\n    <div\n        class=\"chip__label\"\n        [evoUiClass]=\"{'disabled': disabled}\"\n    >\n        <span class=\"chip__text\">\n            <ng-content></ng-content>\n        </span>\n        <div\n            class=\"chip__counter\"\n            *ngIf=\"(type !== templateVariables?.chipTypes.label || !closable) && counter !== undefined\"\n        >\n            <span class=\"chip__counter-value\">\n                {{ counter }}\n            </span>\n        </div>\n        <button\n            class=\"chip__close\"\n            *ngIf=\"closable\"\n            [disabled]=\"disabled\"\n            [title]=\"closeTitle\"\n            (click)=\"onCloseClick($event)\"\n            type=\"button\"\n        >\n            <evo-icon shape=\"decline\"></evo-icon>\n        </button>\n    </div>\n</label>\n"]}
|
|
@@ -51,6 +51,8 @@ export class EvoInputComponent extends EvoBaseControl {
|
|
|
51
51
|
this.destroy$ = new Subject();
|
|
52
52
|
/** Whether the user is creating a composition string (IME events). */
|
|
53
53
|
this._composing = false;
|
|
54
|
+
this.onChange = (_value) => { };
|
|
55
|
+
this.onTouched = () => { };
|
|
54
56
|
}
|
|
55
57
|
set setValue(value) {
|
|
56
58
|
this._value = value;
|
|
@@ -77,16 +79,15 @@ export class EvoInputComponent extends EvoBaseControl {
|
|
|
77
79
|
set value(value) {
|
|
78
80
|
if (value || this._value) {
|
|
79
81
|
this._value = this.removePrefix(value);
|
|
80
|
-
this.onChange(this.prefix + (this._value || ''));
|
|
81
82
|
this.changeDetector.markForCheck();
|
|
82
83
|
}
|
|
83
84
|
}
|
|
84
85
|
get inputClass() {
|
|
85
86
|
return {
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
87
|
+
focused: this.uiStates.isFocused,
|
|
88
|
+
disabled: this.isDisabled,
|
|
89
|
+
valid: this.currentState[EvoControlStates.valid],
|
|
90
|
+
invalid: this.currentState[EvoControlStates.invalid],
|
|
90
91
|
[`size-${this.size}`]: this.size !== EvoInputSizes.normal,
|
|
91
92
|
[`theme-${this.theme}`]: true,
|
|
92
93
|
};
|
|
@@ -139,8 +140,9 @@ export class EvoInputComponent extends EvoBaseControl {
|
|
|
139
140
|
}
|
|
140
141
|
return e.target.value;
|
|
141
142
|
}), enterZone(this.zone), tap((value) => {
|
|
142
|
-
this.value
|
|
143
|
-
}), takeUntil(this.destroy$))
|
|
143
|
+
this.onInputChange(value);
|
|
144
|
+
}), takeUntil(this.destroy$))
|
|
145
|
+
.subscribe();
|
|
144
146
|
});
|
|
145
147
|
}
|
|
146
148
|
ngOnDestroy() {
|
|
@@ -170,12 +172,6 @@ export class EvoInputComponent extends EvoBaseControl {
|
|
|
170
172
|
}
|
|
171
173
|
}
|
|
172
174
|
}
|
|
173
|
-
onChange(value) {
|
|
174
|
-
// this is intentional
|
|
175
|
-
}
|
|
176
|
-
onTouched() {
|
|
177
|
-
// this is intentional
|
|
178
|
-
}
|
|
179
175
|
ngAfterViewInit() {
|
|
180
176
|
if (this.autoFocus) {
|
|
181
177
|
this.inputElement.nativeElement.focus();
|
|
@@ -207,6 +203,13 @@ export class EvoInputComponent extends EvoBaseControl {
|
|
|
207
203
|
this.disabled = state;
|
|
208
204
|
this.changeDetector.detectChanges();
|
|
209
205
|
}
|
|
206
|
+
onInputChange(value) {
|
|
207
|
+
if (value || this._value) {
|
|
208
|
+
this._value = this.removePrefix(value);
|
|
209
|
+
this.onChange(this.prefix + (this._value || ''));
|
|
210
|
+
this.changeDetector.markForCheck();
|
|
211
|
+
}
|
|
212
|
+
}
|
|
210
213
|
onFocus() {
|
|
211
214
|
if (!this.uiStates.isFocused) {
|
|
212
215
|
this.uiStates.isFocused = true;
|
|
@@ -247,9 +250,14 @@ export class EvoInputComponent extends EvoBaseControl {
|
|
|
247
250
|
this.value = value;
|
|
248
251
|
}
|
|
249
252
|
}
|
|
253
|
+
validate() {
|
|
254
|
+
if (this.maskValidation && this.mask && !this.iMask.masked.isComplete) {
|
|
255
|
+
return { mask: true };
|
|
256
|
+
}
|
|
257
|
+
return null;
|
|
258
|
+
}
|
|
250
259
|
removePrefix(value) {
|
|
251
|
-
if (typeof value === 'string' &&
|
|
252
|
-
value.indexOf(this.prefix) === 0) {
|
|
260
|
+
if (typeof value === 'string' && value.indexOf(this.prefix) === 0) {
|
|
253
261
|
return value.replace(this.prefix, '');
|
|
254
262
|
}
|
|
255
263
|
return value;
|
|
@@ -262,18 +270,13 @@ export class EvoInputComponent extends EvoBaseControl {
|
|
|
262
270
|
this.iMask = null;
|
|
263
271
|
}
|
|
264
272
|
checkCustomTooltip() {
|
|
265
|
-
this.uiStates.hasCustomTooltip =
|
|
266
|
-
this.tooltipElement
|
|
267
|
-
|
|
273
|
+
this.uiStates.hasCustomTooltip =
|
|
274
|
+
this.tooltipElement &&
|
|
275
|
+
this.tooltipElement.nativeElement &&
|
|
276
|
+
this.tooltipElement.nativeElement.children.length > 0;
|
|
268
277
|
this.customTooltipChecked = true;
|
|
269
278
|
this.changeDetector.detectChanges();
|
|
270
279
|
}
|
|
271
|
-
validate() {
|
|
272
|
-
if (this.maskValidation && this.mask && !this.iMask.masked.isComplete) {
|
|
273
|
-
return { mask: true };
|
|
274
|
-
}
|
|
275
|
-
return null;
|
|
276
|
-
}
|
|
277
280
|
}
|
|
278
281
|
EvoInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: EvoInputComponent, deps: [{ token: i0.NgZone }, { token: i0.ChangeDetectorRef }, { token: i0.Renderer2 }, { token: COMPOSITION_BUFFER_MODE, optional: true }, { token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component });
|
|
279
282
|
EvoInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: EvoInputComponent, selector: "evo-input", inputs: { autoFocus: "autoFocus", dataCp: ["data-cp", "dataCp"], icon: "icon", mask: "mask", placeholder: "placeholder", tooltip: "tooltip", type: "type", disabled: "disabled", loading: "loading", prefix: "prefix", autocomplete: "autocomplete", inputDebounce: "inputDebounce", unmask: "unmask", clearable: "clearable", maskValidation: "maskValidation", setValue: ["value", "setValue"], setSize: ["size", "setSize"], setTheme: ["theme", "setTheme"] }, outputs: { blur: "blur" }, providers: [
|
|
@@ -356,4 +359,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImpor
|
|
|
356
359
|
type: Input,
|
|
357
360
|
args: ['theme']
|
|
358
361
|
}] } });
|
|
359
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"evo-input.component.js","sourceRoot":"","sources":["../../../../../../projects/evo-ui-kit/src/lib/components/evo-input/evo-input.component.ts","../../../../../../projects/evo-ui-kit/src/lib/components/evo-input/evo-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    Inject,\n    Injector,\n    Input,\n    NgZone,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Optional,\n    Output,\n    Renderer2,\n    SimpleChanges,\n    ViewChild,\n} from '@angular/core';\nimport {\n    COMPOSITION_BUFFER_MODE,\n    ControlValueAccessor,\n    NG_VALIDATORS,\n    NG_VALUE_ACCESSOR,\n    Validator,\n} from '@angular/forms';\nimport {EvoControlStates} from '../../common/evo-control-state-manager/evo-control-states.enum';\nimport {EvoBaseControl} from '../../common/evo-base-control';\nimport {fromEvent, Subject} from 'rxjs';\nimport {debounceTime, map, takeUntil, tap} from 'rxjs/operators';\nimport {enterZone} from '../../operators';\nimport * as IMask from 'imask';\n\nexport enum EvoInputSizes {\n    small = 'small',\n    normal = 'normal',\n}\n\nexport enum EvoInputTheme {\n    default = 'default',\n    rounded = 'rounded',\n}\n\n@Component({\n    selector: 'evo-input',\n    templateUrl: './evo-input.component.html',\n    styleUrls: ['./evo-input.component.scss'],\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => EvoInputComponent),\n            multi: true,\n        },\n        {\n            provide: NG_VALIDATORS,\n            useExisting: forwardRef(() => EvoInputComponent),\n            multi: true,\n          },\n    ],\n})\nexport class EvoInputComponent\n    extends EvoBaseControl\n    implements ControlValueAccessor, OnInit, AfterViewInit, OnChanges, OnDestroy, Validator {\n\n    @Input() autoFocus: boolean;\n    // tslint:disable-next-line\n    @Input('data-cp') dataCp: string;\n    @Input() icon: string;\n    @Input() mask: any;\n    @Input() placeholder: string;\n    @Input() tooltip: string;\n    @Input() type = 'text';\n    @Input() disabled = false;\n    @Input() loading = false;\n    @Input() prefix = '';\n    @Input() autocomplete: string;\n    @Input() inputDebounce = 50;\n    @Input() unmask: boolean | 'typed' = false;\n    @Input() clearable = false;\n    @Input() maskValidation = false;\n\n    @Output() blur: EventEmitter<any> = new EventEmitter<any>();\n\n    @ViewChild('input', {static: true}) inputElement: ElementRef;\n    @ViewChild('tooltipContainer', {static: true}) tooltipElement: ElementRef;\n\n    size: EvoInputSizes = EvoInputSizes.normal;\n    theme: EvoInputTheme = EvoInputTheme.default;\n    _value: string;\n    customTooltipChecked = false;\n    uiStates = {\n        hasCustomTooltip: false,\n        isTooltipVisible: false,\n        isFocused: false,\n    };\n\n    private iMask: IMask.InputMask<any>;\n\n    private tooltipVisibilityTimeout = false;\n\n    private destroy$ = new Subject<void>();\n\n    /** Whether the user is creating a composition string (IME events). */\n    private _composing = false;\n\n    constructor(\n        private zone: NgZone,\n        private changeDetector: ChangeDetectorRef,\n        private _renderer: Renderer2,\n        @Optional() @Inject(COMPOSITION_BUFFER_MODE) private _compositionMode: boolean,\n        protected injector: Injector,\n    ) {\n        super(injector);\n    }\n\n    @Input('value') set setValue(value) {\n        this._value = value;\n    }\n\n    @Input('size') set setSize(size: EvoInputSizes | string) {\n        if (EvoInputSizes[size]) {\n            this.size = EvoInputSizes[size];\n        }\n    }\n\n    @Input('theme') set setTheme(theme: string | EvoInputTheme) {\n        if (EvoInputTheme[theme]) {\n            this.theme = EvoInputTheme[theme];\n        }\n    }\n\n    get isDisabled() {\n        if (this.loading) {\n            return true;\n        }\n        return this.disabled;\n    }\n\n    get value(): any {\n        return this._value;\n    }\n\n    set value(value: any) {\n        if (value || this._value) {\n            this._value = this.removePrefix(value);\n            this.onChange(this.prefix + (this._value || ''));\n            this.changeDetector.markForCheck();\n        }\n    }\n\n    get inputClass(): { [cssClass: string]: boolean } {\n        return {\n            'focused': this.uiStates.isFocused,\n            'disabled': this.isDisabled,\n            'valid': this.currentState[EvoControlStates.valid],\n            'invalid': this.currentState[EvoControlStates.invalid],\n            [`size-${this.size}`]: this.size !== EvoInputSizes.normal,\n            [`theme-${this.theme}`]: true,\n        };\n    }\n\n    get hasAdditional(): boolean {\n        return !!this.tooltip || this.uiStates.hasCustomTooltip || !!this.icon;\n    }\n\n    set maskValue(value: any) {\n        const normalizedValue = value ?? '';\n        if (this.iMask) {\n            if (this.unmask === 'typed') {\n                this.iMask.typedValue = normalizedValue;\n            } else if (this.unmask) {\n                this.iMask.unmaskedValue = normalizedValue;\n            } else {\n                this.iMask.value = normalizedValue;\n            }\n        } else {\n            this.writeToElement(normalizedValue);\n        }\n    }\n\n    get maskValue(): any {\n        if (!this.iMask) {\n            return this.inputElement.nativeElement.value;\n        }\n        if (this.unmask === 'typed') {\n            return this.iMask.typedValue;\n        }\n        if (this.unmask) {\n            return this.iMask.unmaskedValue;\n        }\n        return this.iMask.value;\n    }\n\n    get isClearable(): boolean {\n        return this.clearable && !this.disabled;\n    }\n\n    ngOnInit() {\n\n        const inputEl = this.inputElement.nativeElement;\n\n        this.zone.runOutsideAngular(() => {\n\n            if (this.mask) {\n                this.createMaskInstance(this.mask);\n            }\n\n            fromEvent(inputEl, 'input')\n                .pipe(\n                    debounceTime(this.inputDebounce),\n                    map((e: InputEvent) => {\n                        if (this.iMask) {\n                            return this.maskValue;\n                        }\n                        return (e.target as HTMLInputElement).value;\n                    }),\n                    enterZone(this.zone),\n                    tap((value: string) => {\n                        this.value = value;\n                    }),\n                    takeUntil(this.destroy$),\n                ).subscribe();\n        });\n    }\n\n    ngOnDestroy() {\n        this.destroy$.next();\n        this.destroy$.complete();\n        if (this.iMask) {\n            this.destroyMask();\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges) {\n        if (!changes) {\n            return;\n        }\n\n        const {mask} = changes;\n\n        if (mask && !mask.firstChange) {\n            const newMaskOptions = mask.currentValue;\n            if (newMaskOptions) {\n                if (this.iMask) {\n                    this.iMask.updateOptions(newMaskOptions);\n                } else {\n                    this.createMaskInstance(newMaskOptions);\n                }\n            } else {\n                this.destroyMask();\n            }\n        }\n    }\n\n    onChange(value) {\n        // this is intentional\n    }\n\n    onTouched() {\n        // this is intentional\n    }\n\n    ngAfterViewInit() {\n        if (this.autoFocus) {\n            this.inputElement.nativeElement.focus();\n        }\n        this.checkCustomTooltip();\n    }\n\n    writeToElement(value: any) {\n        this._renderer.setProperty(this.inputElement.nativeElement, 'value', value);\n    }\n\n    writeValue(value: any): void {\n        if (value === this._value) {\n            return;\n        }\n\n        this.value = value;\n\n        if (this.mask) {\n            this.maskValue = value;\n        } else {\n            this.writeToElement(value);\n        }\n    }\n\n    registerOnChange(fn: any): void {\n        this.onChange = fn;\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouched = fn;\n    }\n\n    setDisabledState(state: boolean): void {\n        this.disabled = state;\n        this.changeDetector.detectChanges();\n    }\n\n    onFocus(): void {\n        if (!this.uiStates.isFocused) {\n            this.uiStates.isFocused = true;\n        }\n    }\n\n    onBlur(): void {\n        this.uiStates.isFocused = false;\n        this.onTouched();\n        this.blur.emit();\n    }\n\n    onTooltipClick(event: any): void {\n        event.preventDefault();\n        event.stopPropagation();\n    }\n\n    onClear(): void {\n        this.writeValue('');\n    }\n\n    hideTooltip() {\n        this.tooltipVisibilityTimeout = true;\n\n        setTimeout(() => {\n            if (this.tooltipVisibilityTimeout) {\n                this.uiStates.isTooltipVisible = false;\n            }\n        }, 25);\n    }\n\n    showTooltip() {\n        this.uiStates.isTooltipVisible = true;\n        this.tooltipVisibilityTimeout = false;\n    }\n\n    // Composition handling is taken from:\n    // https://github.com/angular/angular/blob/11.0.3/packages/forms/src/directives/default_value_accessor.ts#L152\n    _compositionStart(): void {\n        this._composing = true;\n    }\n\n    _compositionEnd(value: any): void {\n        this._composing = false;\n        if (this._compositionMode) {\n            this.value = value;\n        }\n    }\n\n    private removePrefix(value: any): any {\n        if (\n            typeof value === 'string' &&\n            value.indexOf(this.prefix) === 0\n        ) {\n            return value.replace(this.prefix, '');\n        }\n        return value;\n    }\n\n    private createMaskInstance(opts: any) {\n        this.iMask = new IMask.InputMask(\n            this.inputElement.nativeElement,\n            opts\n        );\n    }\n\n    private destroyMask() {\n        this.iMask?.destroy();\n        this.iMask = null;\n    }\n\n    private checkCustomTooltip() {\n        this.uiStates.hasCustomTooltip = this.tooltipElement &&\n            this.tooltipElement.nativeElement &&\n            this.tooltipElement.nativeElement.children.length > 0;\n        this.customTooltipChecked = true;\n        this.changeDetector.detectChanges();\n    }\n\n    validate() {\n        if (this.maskValidation && this.mask && !this.iMask.masked.isComplete) {\n            return { mask: true };\n        }\n        return null;\n    }\n}\n","<label class=\"evo-input\" [evoUiClass]=\"inputClass\">\n    <div class=\"evo-input__prefix-content\">\n        <ng-content select=\"[evoInputPrefixContent]\"></ng-content>\n    </div>\n    <div class=\"evo-input__prefix-icon\">\n        <ng-content select=\"[evoInputIcon]\"></ng-content>\n    </div>\n    <span\n        class=\"evo-input__prefix\" *ngIf=\"prefix\"\n        [evoUiClass]=\"{focused: !isDisabled && !!value || uiStates.isFocused }\"\n    >{{prefix}}</span>\n    <input\n        #input\n        class=\"evo-input__field\"\n        (focus)=\"onFocus()\"\n        (blur)=\"onBlur()\"\n        (compositionstart)=\"_compositionStart()\"\n        (compositionend)=\"_compositionEnd($event.target.value)\"\n        type=\"{{ type }}\"\n        [attr.autocomplete]=\"autocomplete\"\n        placeholder=\"{{ placeholder }}\"\n        [attr.data-cp]=\"dataCp\"\n        [disabled]=\"isDisabled\"\n    >\n    <ng-container *ngIf=\"loading; else sideBlock\">\n        <evo-circular-loader  class=\"evo-input__loading-spinner\"></evo-circular-loader>\n    </ng-container>\n    <ng-template #sideBlock>\n        <div\n            *ngIf=\"isClearable\"\n            class=\"evo-input__clearable\"\n            (click)=\"onClear()\">\n            <evo-icon shape=\"decline\" class=\"evo-input__icon-clear\"></evo-icon>\n        </div>\n        <div class=\"evo-input__additional\" *ngIf=\"hasAdditional\">\n            <evo-icon\n                shape=\"help\" class=\"evo-input__tooltip\"\n                *ngIf=\"tooltip || uiStates.hasCustomTooltip\"\n                (mouseenter)=\"showTooltip()\"\n                (mouseleave)=\"hideTooltip()\"\n                (click)=\"onTooltipClick($event)\"\n            ></evo-icon>\n            <div class=\"evo-input__icon\" *ngIf=\"icon\">\n                <img [attr.src]=\"icon\">\n            </div>\n        </div>\n    </ng-template>\n    <div\n        *ngIf=\"!customTooltipChecked || uiStates.isTooltipVisible\"\n        [hidden]=\"!customTooltipChecked\"\n        (click)=\"onTooltipClick($event)\"\n        (mouseenter)=\"showTooltip()\"\n        (mouseleave)=\"hideTooltip()\"\n        #tooltipContainer\n        [ngClass]=\"{'evo-input__tooltip-container': tooltip}\"\n    >\n        {{ tooltip }}\n        <ng-content select=\"[tooltip]\"></ng-content>\n    </div>\n</label>\n<evo-control-error\n    *ngIf=\"showErrors\"\n    [errors]=\"control.errors\"\n    [errorsMessages]=\"errorsMessages\"\n></evo-control-error>\n"]}
|
|
362
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"evo-input.component.js","sourceRoot":"","sources":["../../../../../../projects/evo-ui-kit/src/lib/components/evo-input/evo-input.component.ts","../../../../../../projects/evo-ui-kit/src/lib/components/evo-input/evo-input.component.html"],"names":[],"mappings":"AAAA,OAAO,EAGH,SAAS,EAET,YAAY,EACZ,UAAU,EACV,MAAM,EAEN,KAAK,EAKL,QAAQ,EACR,MAAM,EAGN,SAAS,GACZ,MAAM,eAAe,CAAC;AACvB,OAAO,EACH,uBAAuB,EAEvB,aAAa,EACb,iBAAiB,GAEpB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAC,gBAAgB,EAAC,MAAM,gEAAgE,CAAC;AAChG,OAAO,EAAC,cAAc,EAAC,MAAM,+BAA+B,CAAC;AAC7D,OAAO,EAAC,SAAS,EAAE,OAAO,EAAC,MAAM,MAAM,CAAC;AACxC,OAAO,EAAC,YAAY,EAAE,GAAG,EAAE,SAAS,EAAE,GAAG,EAAC,MAAM,gBAAgB,CAAC;AACjE,OAAO,EAAC,SAAS,EAAC,MAAM,iBAAiB,CAAC;AAC1C,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;;;;;;;AAE/B,MAAM,CAAN,IAAY,aAGX;AAHD,WAAY,aAAa;IACrB,gCAAe,CAAA;IACf,kCAAiB,CAAA;AACrB,CAAC,EAHW,aAAa,KAAb,aAAa,QAGxB;AAED,MAAM,CAAN,IAAY,aAGX;AAHD,WAAY,aAAa;IACrB,oCAAmB,CAAA;IACnB,oCAAmB,CAAA;AACvB,CAAC,EAHW,aAAa,KAAb,aAAa,QAGxB;AAmBD,MAAM,OAAO,iBACT,SAAQ,cAAc;IA4CtB,YACY,IAAY,EACZ,cAAiC,EACjC,SAAoB,EACyB,gBAAyB,EACpE,QAAkB;QAE5B,KAAK,CAAC,QAAQ,CAAC,CAAC;QANR,SAAI,GAAJ,IAAI,CAAQ;QACZ,mBAAc,GAAd,cAAc,CAAmB;QACjC,cAAS,GAAT,SAAS,CAAW;QACyB,qBAAgB,GAAhB,gBAAgB,CAAS;QACpE,aAAQ,GAAR,QAAQ,CAAU;QAvCvB,SAAI,GAAG,MAAM,CAAC;QACd,aAAQ,GAAG,KAAK,CAAC;QACjB,YAAO,GAAG,KAAK,CAAC;QAChB,WAAM,GAAG,EAAE,CAAC;QAEZ,kBAAa,GAAG,EAAE,CAAC;QACnB,WAAM,GAAsB,KAAK,CAAC;QAClC,cAAS,GAAG,KAAK,CAAC;QAClB,mBAAc,GAAG,KAAK,CAAC;QAEtB,SAAI,GAAsB,IAAI,YAAY,EAAO,CAAC;QAK5D,SAAI,GAAkB,aAAa,CAAC,MAAM,CAAC;QAC3C,UAAK,GAAkB,aAAa,CAAC,OAAO,CAAC;QAE7C,yBAAoB,GAAG,KAAK,CAAC;QAC7B,aAAQ,GAAG;YACP,gBAAgB,EAAE,KAAK;YACvB,gBAAgB,EAAE,KAAK;YACvB,SAAS,EAAE,KAAK;SACnB,CAAC;QAIM,6BAAwB,GAAG,KAAK,CAAC;QAEjC,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;QAEvC,sEAAsE;QAC9D,eAAU,GAAG,KAAK,CAAC;QAqJ3B,aAAQ,GAAG,CAAC,MAAW,EAAQ,EAAE,GAAE,CAAC,CAAC;QACrC,cAAS,GAAG,GAAS,EAAE,GAAE,CAAC,CAAC;IA5I3B,CAAC;IAED,IAAoB,QAAQ,CAAC,KAAK;QAC9B,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;IACxB,CAAC;IAED,IAAmB,OAAO,CAAC,IAA4B;QACnD,IAAI,aAAa,CAAC,IAAI,CAAC,EAAE;YACrB,IAAI,CAAC,IAAI,GAAG,aAAa,CAAC,IAAI,CAAC,CAAC;SACnC;IACL,CAAC;IAED,IAAoB,QAAQ,CAAC,KAA6B;QACtD,IAAI,aAAa,CAAC,KAAK,CAAC,EAAE;YACtB,IAAI,CAAC,KAAK,GAAG,aAAa,CAAC,KAAK,CAAC,CAAC;SACrC;IACL,CAAC;IAED,IAAI,UAAU;QACV,IAAI,IAAI,CAAC,OAAO,EAAE;YACd,OAAO,IAAI,CAAC;SACf;QACD,OAAO,IAAI,CAAC,QAAQ,CAAC;IACzB,CAAC;IAED,IAAI,KAAK;QACL,OAAO,IAAI,CAAC,MAAM,CAAC;IACvB,CAAC;IAED,IAAI,KAAK,CAAC,KAAU;QAChB,IAAI,KAAK,IAAI,IAAI,CAAC,MAAM,EAAE;YACtB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;YACvC,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC;SACtC;IACL,CAAC;IAED,IAAI,UAAU;QACV,OAAO;YACH,OAAO,EAAE,IAAI,CAAC,QAAQ,CAAC,SAAS;YAChC,QAAQ,EAAE,IAAI,CAAC,UAAU;YACzB,KAAK,EAAE,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,KAAK,CAAC;YAChD,OAAO,EAAE,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,OAAO,CAAC;YACpD,CAAC,QAAQ,IAAI,CAAC,IAAI,EAAE,CAAC,EAAE,IAAI,CAAC,IAAI,KAAK,aAAa,CAAC,MAAM;YACzD,CAAC,SAAS,IAAI,CAAC,KAAK,EAAE,CAAC,EAAE,IAAI;SAChC,CAAC;IACN,CAAC;IAED,IAAI,aAAa;QACb,OAAO,CAAC,CAAC,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,QAAQ,CAAC,gBAAgB,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC;IAC3E,CAAC;IAED,IAAI,SAAS,CAAC,KAAU;QACpB,MAAM,eAAe,GAAG,KAAK,IAAI,EAAE,CAAC;QACpC,IAAI,IAAI,CAAC,KAAK,EAAE;YACZ,IAAI,IAAI,CAAC,MAAM,KAAK,OAAO,EAAE;gBACzB,IAAI,CAAC,KAAK,CAAC,UAAU,GAAG,eAAe,CAAC;aAC3C;iBAAM,IAAI,IAAI,CAAC,MAAM,EAAE;gBACpB,IAAI,CAAC,KAAK,CAAC,aAAa,GAAG,eAAe,CAAC;aAC9C;iBAAM;gBACH,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,eAAe,CAAC;aACtC;SACJ;aAAM;YACH,IAAI,CAAC,cAAc,CAAC,eAAe,CAAC,CAAC;SACxC;IACL,CAAC;IAED,IAAI,SAAS;QACT,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;YACb,OAAO,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,KAAK,CAAC;SAChD;QACD,IAAI,IAAI,CAAC,MAAM,KAAK,OAAO,EAAE;YACzB,OAAO,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC;SAChC;QACD,IAAI,IAAI,CAAC,MAAM,EAAE;YACb,OAAO,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC;SACnC;QACD,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC;IAC5B,CAAC;IAED,IAAI,WAAW;QACX,OAAO,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC;IAC5C,CAAC;IAED,QAAQ;QACJ,MAAM,OAAO,GAAG,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC;QAEhD,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,GAAG,EAAE;YAC7B,IAAI,IAAI,CAAC,IAAI,EAAE;gBACX,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;aACtC;YAED,SAAS,CAAC,OAAO,EAAE,OAAO,CAAC;iBACtB,IAAI,CACD,YAAY,CAAC,IAAI,CAAC,aAAa,CAAC,EAChC,GAAG,CAAC,CAAC,CAAa,EAAE,EAAE;gBAClB,IAAI,IAAI,CAAC,KAAK,EAAE;oBACZ,OAAO,IAAI,CAAC,SAAS,CAAC;iBACzB;gBACD,OAAQ,CAAC,CAAC,MAA2B,CAAC,KAAK,CAAC;YAChD,CAAC,CAAC,EACF,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,EACpB,GAAG,CAAC,CAAC,KAAa,EAAE,EAAE;gBAClB,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YAC9B,CAAC,CAAC,EACF,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAC3B;iBACA,SAAS,EAAE,CAAC;QACrB,CAAC,CAAC,CAAC;IACP,CAAC;IAED,WAAW;QACP,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;QACzB,IAAI,IAAI,CAAC,KAAK,EAAE;YACZ,IAAI,CAAC,WAAW,EAAE,CAAC;SACtB;IACL,CAAC;IAED,WAAW,CAAC,OAAsB;QAC9B,IAAI,CAAC,OAAO,EAAE;YACV,OAAO;SACV;QAED,MAAM,EAAC,IAAI,EAAC,GAAG,OAAO,CAAC;QAEvB,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;YAC3B,MAAM,cAAc,GAAG,IAAI,CAAC,YAAY,CAAC;YACzC,IAAI,cAAc,EAAE;gBAChB,IAAI,IAAI,CAAC,KAAK,EAAE;oBACZ,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,cAAc,CAAC,CAAC;iBAC5C;qBAAM;oBACH,IAAI,CAAC,kBAAkB,CAAC,cAAc,CAAC,CAAC;iBAC3C;aACJ;iBAAM;gBACH,IAAI,CAAC,WAAW,EAAE,CAAC;aACtB;SACJ;IACL,CAAC;IAKD,eAAe;QACX,IAAI,IAAI,CAAC,SAAS,EAAE;YAChB,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;SAC3C;QACD,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC9B,CAAC;IAED,cAAc,CAAC,KAAU;QACrB,IAAI,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,EAAE,OAAO,EAAE,KAAK,CAAC,CAAC;IAChF,CAAC;IAED,UAAU,CAAC,KAAU;QACjB,IAAI,KAAK,KAAK,IAAI,CAAC,MAAM,EAAE;YACvB,OAAO;SACV;QAED,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QAEnB,IAAI,IAAI,CAAC,IAAI,EAAE;YACX,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;SAC1B;aAAM;YACH,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;SAC9B;IACL,CAAC;IAED,gBAAgB,CAAC,EAAO;QACpB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACvB,CAAC;IAED,iBAAiB,CAAC,EAAO;QACrB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACxB,CAAC;IAED,gBAAgB,CAAC,KAAc;QAC3B,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,CAAC;IACxC,CAAC;IAED,aAAa,CAAC,KAAa;QACvB,IAAI,KAAK,IAAI,IAAI,CAAC,MAAM,EAAE;YACtB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;YACvC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC,CAAC;YACjD,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC;SACtC;IACL,CAAC;IAED,OAAO;QACH,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE;YAC1B,IAAI,CAAC,QAAQ,CAAC,SAAS,GAAG,IAAI,CAAC;SAClC;IACL,CAAC;IAED,MAAM;QACF,IAAI,CAAC,QAAQ,CAAC,SAAS,GAAG,KAAK,CAAC;QAChC,IAAI,CAAC,SAAS,EAAE,CAAC;QACjB,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;IACrB,CAAC;IAED,cAAc,CAAC,KAAU;QACrB,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;IAC5B,CAAC;IAED,OAAO;QACH,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;IACxB,CAAC;IAED,WAAW;QACP,IAAI,CAAC,wBAAwB,GAAG,IAAI,CAAC;QAErC,UAAU,CAAC,GAAG,EAAE;YACZ,IAAI,IAAI,CAAC,wBAAwB,EAAE;gBAC/B,IAAI,CAAC,QAAQ,CAAC,gBAAgB,GAAG,KAAK,CAAC;aAC1C;QACL,CAAC,EAAE,EAAE,CAAC,CAAC;IACX,CAAC;IAED,WAAW;QACP,IAAI,CAAC,QAAQ,CAAC,gBAAgB,GAAG,IAAI,CAAC;QACtC,IAAI,CAAC,wBAAwB,GAAG,KAAK,CAAC;IAC1C,CAAC;IAED,sCAAsC;IACtC,8GAA8G;IAC9G,iBAAiB;QACb,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;IAC3B,CAAC;IAED,eAAe,CAAC,KAAU;QACtB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACvB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;SACtB;IACL,CAAC;IAED,QAAQ;QACJ,IAAI,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,UAAU,EAAE;YACnE,OAAO,EAAC,IAAI,EAAE,IAAI,EAAC,CAAC;SACvB;QACD,OAAO,IAAI,CAAC;IAChB,CAAC;IAEO,YAAY,CAAC,KAAU;QAC3B,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE;YAC/D,OAAO,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;SACzC;QACD,OAAO,KAAK,CAAC;IACjB,CAAC;IAEO,kBAAkB,CAAC,IAAS;QAChC,IAAI,CAAC,KAAK,GAAG,IAAI,KAAK,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC;IAC5E,CAAC;IAEO,WAAW;QACf,IAAI,CAAC,KAAK,EAAE,OAAO,EAAE,CAAC;QACtB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;IACtB,CAAC;IAEO,kBAAkB;QACtB,IAAI,CAAC,QAAQ,CAAC,gBAAgB;YAC1B,IAAI,CAAC,cAAc;gBACnB,IAAI,CAAC,cAAc,CAAC,aAAa;gBACjC,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC;QAC1D,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC;QACjC,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,CAAC;IACxC,CAAC;;8GAhUQ,iBAAiB,kGAiDF,uBAAuB;kGAjDtC,iBAAiB,kgBAbf;QACP;YACI,OAAO,EAAE,iBAAiB;YAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC;YAChD,KAAK,EAAE,IAAI;SACd;QACD;YACI,OAAO,EAAE,aAAa;YACtB,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC;YAChD,KAAK,EAAE,IAAI;SACd;KACJ,8SC3DL,o7EAiEA;2FDJa,iBAAiB;kBAjB7B,SAAS;+BACI,WAAW,aAGV;wBACP;4BACI,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,kBAAkB,CAAC;4BAChD,KAAK,EAAE,IAAI;yBACd;wBACD;4BACI,OAAO,EAAE,aAAa;4BACtB,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,kBAAkB,CAAC;4BAChD,KAAK,EAAE,IAAI;yBACd;qBACJ;;0BAmDI,QAAQ;;0BAAI,MAAM;2BAAC,uBAAuB;mEA7CtC,SAAS;sBAAjB,KAAK;gBAEY,MAAM;sBAAvB,KAAK;uBAAC,SAAS;gBACP,IAAI;sBAAZ,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBAEI,IAAI;sBAAb,MAAM;gBAE6B,YAAY;sBAA/C,SAAS;uBAAC,OAAO,EAAE,EAAC,MAAM,EAAE,IAAI,EAAC;gBACa,cAAc;sBAA5D,SAAS;uBAAC,kBAAkB,EAAE,EAAC,MAAM,EAAE,IAAI,EAAC;gBA+BzB,QAAQ;sBAA3B,KAAK;uBAAC,OAAO;gBAIK,OAAO;sBAAzB,KAAK;uBAAC,MAAM;gBAMO,QAAQ;sBAA3B,KAAK;uBAAC,OAAO","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    Inject,\n    Injector,\n    Input,\n    NgZone,\n    OnChanges,\n    OnDestroy,\n    OnInit,\n    Optional,\n    Output,\n    Renderer2,\n    SimpleChanges,\n    ViewChild,\n} from '@angular/core';\nimport {\n    COMPOSITION_BUFFER_MODE,\n    ControlValueAccessor,\n    NG_VALIDATORS,\n    NG_VALUE_ACCESSOR,\n    Validator,\n} from '@angular/forms';\nimport {EvoControlStates} from '../../common/evo-control-state-manager/evo-control-states.enum';\nimport {EvoBaseControl} from '../../common/evo-base-control';\nimport {fromEvent, Subject} from 'rxjs';\nimport {debounceTime, map, takeUntil, tap} from 'rxjs/operators';\nimport {enterZone} from '../../operators';\nimport * as IMask from 'imask';\n\nexport enum EvoInputSizes {\n    small = 'small',\n    normal = 'normal',\n}\n\nexport enum EvoInputTheme {\n    default = 'default',\n    rounded = 'rounded',\n}\n\n@Component({\n    selector: 'evo-input',\n    templateUrl: './evo-input.component.html',\n    styleUrls: ['./evo-input.component.scss'],\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => EvoInputComponent),\n            multi: true,\n        },\n        {\n            provide: NG_VALIDATORS,\n            useExisting: forwardRef(() => EvoInputComponent),\n            multi: true,\n        },\n    ],\n})\nexport class EvoInputComponent\n    extends EvoBaseControl\n    implements ControlValueAccessor, OnInit, AfterViewInit, OnChanges, OnDestroy, Validator\n{\n    @Input() autoFocus: boolean;\n    // tslint:disable-next-line\n    @Input('data-cp') dataCp: string;\n    @Input() icon: string;\n    @Input() mask: any;\n    @Input() placeholder: string;\n    @Input() tooltip: string;\n    @Input() type = 'text';\n    @Input() disabled = false;\n    @Input() loading = false;\n    @Input() prefix = '';\n    @Input() autocomplete: string;\n    @Input() inputDebounce = 50;\n    @Input() unmask: boolean | 'typed' = false;\n    @Input() clearable = false;\n    @Input() maskValidation = false;\n\n    @Output() blur: EventEmitter<any> = new EventEmitter<any>();\n\n    @ViewChild('input', {static: true}) inputElement: ElementRef;\n    @ViewChild('tooltipContainer', {static: true}) tooltipElement: ElementRef;\n\n    size: EvoInputSizes = EvoInputSizes.normal;\n    theme: EvoInputTheme = EvoInputTheme.default;\n    _value: string;\n    customTooltipChecked = false;\n    uiStates = {\n        hasCustomTooltip: false,\n        isTooltipVisible: false,\n        isFocused: false,\n    };\n\n    private iMask: IMask.InputMask<any>;\n\n    private tooltipVisibilityTimeout = false;\n\n    private destroy$ = new Subject<void>();\n\n    /** Whether the user is creating a composition string (IME events). */\n    private _composing = false;\n\n    constructor(\n        private zone: NgZone,\n        private changeDetector: ChangeDetectorRef,\n        private _renderer: Renderer2,\n        @Optional() @Inject(COMPOSITION_BUFFER_MODE) private _compositionMode: boolean,\n        protected injector: Injector,\n    ) {\n        super(injector);\n    }\n\n    @Input('value') set setValue(value) {\n        this._value = value;\n    }\n\n    @Input('size') set setSize(size: EvoInputSizes | string) {\n        if (EvoInputSizes[size]) {\n            this.size = EvoInputSizes[size];\n        }\n    }\n\n    @Input('theme') set setTheme(theme: string | EvoInputTheme) {\n        if (EvoInputTheme[theme]) {\n            this.theme = EvoInputTheme[theme];\n        }\n    }\n\n    get isDisabled() {\n        if (this.loading) {\n            return true;\n        }\n        return this.disabled;\n    }\n\n    get value(): any {\n        return this._value;\n    }\n\n    set value(value: any) {\n        if (value || this._value) {\n            this._value = this.removePrefix(value);\n            this.changeDetector.markForCheck();\n        }\n    }\n\n    get inputClass(): {[cssClass: string]: boolean} {\n        return {\n            focused: this.uiStates.isFocused,\n            disabled: this.isDisabled,\n            valid: this.currentState[EvoControlStates.valid],\n            invalid: this.currentState[EvoControlStates.invalid],\n            [`size-${this.size}`]: this.size !== EvoInputSizes.normal,\n            [`theme-${this.theme}`]: true,\n        };\n    }\n\n    get hasAdditional(): boolean {\n        return !!this.tooltip || this.uiStates.hasCustomTooltip || !!this.icon;\n    }\n\n    set maskValue(value: any) {\n        const normalizedValue = value ?? '';\n        if (this.iMask) {\n            if (this.unmask === 'typed') {\n                this.iMask.typedValue = normalizedValue;\n            } else if (this.unmask) {\n                this.iMask.unmaskedValue = normalizedValue;\n            } else {\n                this.iMask.value = normalizedValue;\n            }\n        } else {\n            this.writeToElement(normalizedValue);\n        }\n    }\n\n    get maskValue(): any {\n        if (!this.iMask) {\n            return this.inputElement.nativeElement.value;\n        }\n        if (this.unmask === 'typed') {\n            return this.iMask.typedValue;\n        }\n        if (this.unmask) {\n            return this.iMask.unmaskedValue;\n        }\n        return this.iMask.value;\n    }\n\n    get isClearable(): boolean {\n        return this.clearable && !this.disabled;\n    }\n\n    ngOnInit() {\n        const inputEl = this.inputElement.nativeElement;\n\n        this.zone.runOutsideAngular(() => {\n            if (this.mask) {\n                this.createMaskInstance(this.mask);\n            }\n\n            fromEvent(inputEl, 'input')\n                .pipe(\n                    debounceTime(this.inputDebounce),\n                    map((e: InputEvent) => {\n                        if (this.iMask) {\n                            return this.maskValue;\n                        }\n                        return (e.target as HTMLInputElement).value;\n                    }),\n                    enterZone(this.zone),\n                    tap((value: string) => {\n                        this.onInputChange(value);\n                    }),\n                    takeUntil(this.destroy$),\n                )\n                .subscribe();\n        });\n    }\n\n    ngOnDestroy() {\n        this.destroy$.next();\n        this.destroy$.complete();\n        if (this.iMask) {\n            this.destroyMask();\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges) {\n        if (!changes) {\n            return;\n        }\n\n        const {mask} = changes;\n\n        if (mask && !mask.firstChange) {\n            const newMaskOptions = mask.currentValue;\n            if (newMaskOptions) {\n                if (this.iMask) {\n                    this.iMask.updateOptions(newMaskOptions);\n                } else {\n                    this.createMaskInstance(newMaskOptions);\n                }\n            } else {\n                this.destroyMask();\n            }\n        }\n    }\n\n    onChange = (_value: any): void => {};\n    onTouched = (): void => {};\n\n    ngAfterViewInit() {\n        if (this.autoFocus) {\n            this.inputElement.nativeElement.focus();\n        }\n        this.checkCustomTooltip();\n    }\n\n    writeToElement(value: any) {\n        this._renderer.setProperty(this.inputElement.nativeElement, 'value', value);\n    }\n\n    writeValue(value: any): void {\n        if (value === this._value) {\n            return;\n        }\n\n        this.value = value;\n\n        if (this.mask) {\n            this.maskValue = value;\n        } else {\n            this.writeToElement(value);\n        }\n    }\n\n    registerOnChange(fn: any): void {\n        this.onChange = fn;\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouched = fn;\n    }\n\n    setDisabledState(state: boolean): void {\n        this.disabled = state;\n        this.changeDetector.detectChanges();\n    }\n\n    onInputChange(value: string): void {\n        if (value || this._value) {\n            this._value = this.removePrefix(value);\n            this.onChange(this.prefix + (this._value || ''));\n            this.changeDetector.markForCheck();\n        }\n    }\n\n    onFocus(): void {\n        if (!this.uiStates.isFocused) {\n            this.uiStates.isFocused = true;\n        }\n    }\n\n    onBlur(): void {\n        this.uiStates.isFocused = false;\n        this.onTouched();\n        this.blur.emit();\n    }\n\n    onTooltipClick(event: any): void {\n        event.preventDefault();\n        event.stopPropagation();\n    }\n\n    onClear(): void {\n        this.writeValue('');\n    }\n\n    hideTooltip(): void {\n        this.tooltipVisibilityTimeout = true;\n\n        setTimeout(() => {\n            if (this.tooltipVisibilityTimeout) {\n                this.uiStates.isTooltipVisible = false;\n            }\n        }, 25);\n    }\n\n    showTooltip(): void {\n        this.uiStates.isTooltipVisible = true;\n        this.tooltipVisibilityTimeout = false;\n    }\n\n    // Composition handling is taken from:\n    // https://github.com/angular/angular/blob/11.0.3/packages/forms/src/directives/default_value_accessor.ts#L152\n    _compositionStart(): void {\n        this._composing = true;\n    }\n\n    _compositionEnd(value: any): void {\n        this._composing = false;\n        if (this._compositionMode) {\n            this.value = value;\n        }\n    }\n\n    validate(): {mask: boolean} | null {\n        if (this.maskValidation && this.mask && !this.iMask.masked.isComplete) {\n            return {mask: true};\n        }\n        return null;\n    }\n\n    private removePrefix(value: any): any {\n        if (typeof value === 'string' && value.indexOf(this.prefix) === 0) {\n            return value.replace(this.prefix, '');\n        }\n        return value;\n    }\n\n    private createMaskInstance(opts: any): void {\n        this.iMask = new IMask.InputMask(this.inputElement.nativeElement, opts);\n    }\n\n    private destroyMask(): void {\n        this.iMask?.destroy();\n        this.iMask = null;\n    }\n\n    private checkCustomTooltip(): void {\n        this.uiStates.hasCustomTooltip =\n            this.tooltipElement &&\n            this.tooltipElement.nativeElement &&\n            this.tooltipElement.nativeElement.children.length > 0;\n        this.customTooltipChecked = true;\n        this.changeDetector.detectChanges();\n    }\n}\n","<label class=\"evo-input\" [evoUiClass]=\"inputClass\">\n    <div class=\"evo-input__prefix-content\">\n        <ng-content select=\"[evoInputPrefixContent]\"></ng-content>\n    </div>\n    <div class=\"evo-input__prefix-icon\">\n        <ng-content select=\"[evoInputIcon]\"></ng-content>\n    </div>\n    <span\n        class=\"evo-input__prefix\" *ngIf=\"prefix\"\n        [evoUiClass]=\"{focused: !isDisabled && !!value || uiStates.isFocused }\"\n    >{{prefix}}</span>\n    <input\n        #input\n        class=\"evo-input__field\"\n        (focus)=\"onFocus()\"\n        (blur)=\"onBlur()\"\n        (compositionstart)=\"_compositionStart()\"\n        (compositionend)=\"_compositionEnd($event.target.value)\"\n        type=\"{{ type }}\"\n        [attr.autocomplete]=\"autocomplete\"\n        placeholder=\"{{ placeholder }}\"\n        [attr.data-cp]=\"dataCp\"\n        [disabled]=\"isDisabled\"\n    >\n    <ng-container *ngIf=\"loading; else sideBlock\">\n        <evo-circular-loader  class=\"evo-input__loading-spinner\"></evo-circular-loader>\n    </ng-container>\n    <ng-template #sideBlock>\n        <div\n            *ngIf=\"isClearable\"\n            class=\"evo-input__clearable\"\n            (click)=\"onClear()\">\n            <evo-icon shape=\"decline\" class=\"evo-input__icon-clear\"></evo-icon>\n        </div>\n        <div class=\"evo-input__additional\" *ngIf=\"hasAdditional\">\n            <evo-icon\n                shape=\"help\" class=\"evo-input__tooltip\"\n                *ngIf=\"tooltip || uiStates.hasCustomTooltip\"\n                (mouseenter)=\"showTooltip()\"\n                (mouseleave)=\"hideTooltip()\"\n                (click)=\"onTooltipClick($event)\"\n            ></evo-icon>\n            <div class=\"evo-input__icon\" *ngIf=\"icon\">\n                <img [attr.src]=\"icon\">\n            </div>\n        </div>\n    </ng-template>\n    <div\n        *ngIf=\"!customTooltipChecked || uiStates.isTooltipVisible\"\n        [hidden]=\"!customTooltipChecked\"\n        (click)=\"onTooltipClick($event)\"\n        (mouseenter)=\"showTooltip()\"\n        (mouseleave)=\"hideTooltip()\"\n        #tooltipContainer\n        [ngClass]=\"{'evo-input__tooltip-container': tooltip}\"\n    >\n        {{ tooltip }}\n        <ng-content select=\"[tooltip]\"></ng-content>\n    </div>\n</label>\n<evo-control-error\n    *ngIf=\"showErrors\"\n    [errors]=\"control.errors\"\n    [errorsMessages]=\"errorsMessages\"\n></evo-control-error>\n"]}
|