ca-components 1.1.4 → 1.1.5

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.
@@ -1,7 +1,6 @@
1
1
  import { Directive, EventEmitter, HostListener, Input, Output, } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
3
  export class CommandVisibleDirective {
4
- //this._inputConfig.commands
5
4
  constructor(el) {
6
5
  this.el = el;
7
6
  this.commandVisible = new EventEmitter(); // ✅ Emit true/false
@@ -11,45 +10,20 @@ export class CommandVisibleDirective {
11
10
  this.emitCommandVisible(false);
12
11
  }
13
12
  }
14
- // ✅ Detect when the browser loses focus (clicking outside)
15
- onWindowBlur(event) {
13
+ onWindowBlur() {
16
14
  this.emitCommandVisible(false);
17
15
  }
18
16
  onFocus() {
19
17
  // Show commands on focus
20
18
  this.emitCommandVisible(true);
21
19
  }
22
- onClick(event) {
23
- if (!this.restrictInput.commands)
24
- return;
25
- const clickedElement = event.target;
26
- const inputParent = this.el.nativeElement.parentNode;
27
- // ✅ Check if clicked element is inside a `<ta-input-commands>` parent
28
- if (!this.isInsideElement(clickedElement, 'APP-CA-INPUT-COMMANDS') &&
29
- !this.el.nativeElement.contains(event.target) &&
30
- inputParent != event.target) {
31
- this.commandVisible.emit(false); // ✅ Trigger event when clicking outside
32
- }
33
- }
34
- /**
35
- * ✅ Recursively checks if an element has a specific parent tag
36
- */
37
- isInsideElement(element, tagName) {
38
- while (element) {
39
- if (element.tagName === tagName) {
40
- return true; // ✅ Found the parent with the specified tag
41
- }
42
- element = element.parentElement; // Move up the DOM tree
43
- }
44
- return false; // ❌ No matching parent found
45
- }
46
20
  emitCommandVisible(status) {
47
21
  if (this.restrictInput.commands) {
48
22
  this.commandVisible.emit(status);
49
23
  }
50
24
  }
51
25
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CommandVisibleDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
52
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: CommandVisibleDirective, isStandalone: true, selector: "[commandVisible]", inputs: { restrictInput: "restrictInput" }, outputs: { commandVisible: "commandVisible" }, host: { listeners: { "keydown": "onKeyDown($event)", "window:blur": "onWindowBlur($event)", "focus": "onFocus()", "document:click": "onClick($event)" } }, ngImport: i0 }); }
26
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.13", type: CommandVisibleDirective, isStandalone: true, selector: "[commandVisible]", inputs: { restrictInput: "restrictInput" }, outputs: { commandVisible: "commandVisible" }, host: { listeners: { "keydown": "onKeyDown($event)", "blur": "onWindowBlur()", "focus": "onFocus()" } }, ngImport: i0 }); }
53
27
  }
54
28
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CommandVisibleDirective, decorators: [{
55
29
  type: Directive,
@@ -66,12 +40,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
66
40
  args: ['keydown', ['$event']]
67
41
  }], onWindowBlur: [{
68
42
  type: HostListener,
69
- args: ['window:blur', ['$event']]
43
+ args: ['blur']
70
44
  }], onFocus: [{
71
45
  type: HostListener,
72
46
  args: ['focus']
73
- }], onClick: [{
74
- type: HostListener,
75
- args: ['document:click', ['$event']]
76
47
  }] } });
77
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbWFuZC12aXNpYmxlLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NhLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2NhLWlucHV0L2RpcmVjdGl2ZXMvY29tbWFuZC12aXNpYmxlLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0gsU0FBUyxFQUVULFlBQVksRUFDWixZQUFZLEVBQ1osS0FBSyxFQUNMLE1BQU0sR0FDVCxNQUFNLGVBQWUsQ0FBQzs7QUFPdkIsTUFBTSxPQUFPLHVCQUF1QjtJQUdoQyw0QkFBNEI7SUFFNUIsWUFBb0IsRUFBYztRQUFkLE9BQUUsR0FBRixFQUFFLENBQVk7UUFKeEIsbUJBQWMsR0FBRyxJQUFJLFlBQVksRUFBVyxDQUFDLENBQUMsb0JBQW9CO0lBSXZDLENBQUM7SUFHdEMsU0FBUyxDQUFDLEtBQW9CO1FBQzFCLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxLQUFLLEtBQUssSUFBSSxLQUFLLENBQUMsUUFBUSxDQUFDLElBQUksS0FBSyxDQUFDLEdBQUcsS0FBSyxLQUFLLEVBQUUsQ0FBQztZQUNqRSxJQUFJLENBQUMsa0JBQWtCLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDbkMsQ0FBQztJQUNMLENBQUM7SUFFRCwyREFBMkQ7SUFFM0QsWUFBWSxDQUFDLEtBQWlCO1FBQzFCLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNuQyxDQUFDO0lBR0QsT0FBTztRQUNILHlCQUF5QjtRQUN6QixJQUFJLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDbEMsQ0FBQztJQUdELE9BQU8sQ0FBQyxLQUFZO1FBQ2hCLElBQUksQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLFFBQVE7WUFBRSxPQUFPO1FBQ3pDLE1BQU0sY0FBYyxHQUFHLEtBQUssQ0FBQyxNQUFxQixDQUFDO1FBQ25ELE1BQU0sV0FBVyxHQUFHLElBQUksQ0FBQyxFQUFFLENBQUMsYUFBYSxDQUFDLFVBQVUsQ0FBQztRQUNyRCxzRUFBc0U7UUFDdEUsSUFDSSxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsY0FBYyxFQUFFLHVCQUF1QixDQUFDO1lBQzlELENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxhQUFhLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUM7WUFDN0MsV0FBVyxJQUFJLEtBQUssQ0FBQyxNQUFNLEVBQzdCLENBQUM7WUFDQyxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLHdDQUF3QztRQUM3RSxDQUFDO0lBQ0wsQ0FBQztJQUVEOztPQUVHO0lBQ0ssZUFBZSxDQUNuQixPQUEyQixFQUMzQixPQUFlO1FBRWYsT0FBTyxPQUFPLEVBQUUsQ0FBQztZQUNiLElBQUksT0FBTyxDQUFDLE9BQU8sS0FBSyxPQUFPLEVBQUUsQ0FBQztnQkFDOUIsT0FBTyxJQUFJLENBQUMsQ0FBQyw0Q0FBNEM7WUFDN0QsQ0FBQztZQUNELE9BQU8sR0FBRyxPQUFPLENBQUMsYUFBYSxDQUFDLENBQUMsdUJBQXVCO1FBQzVELENBQUM7UUFDRCxPQUFPLEtBQUssQ0FBQyxDQUFDLDZCQUE2QjtJQUMvQyxDQUFDO0lBRU8sa0JBQWtCLENBQUMsTUFBZTtRQUN0QyxJQUFJLElBQUksQ0FBQyxhQUFhLENBQUMsUUFBUSxFQUFFLENBQUM7WUFDOUIsSUFBSSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDckMsQ0FBQztJQUNMLENBQUM7K0dBN0RRLHVCQUF1QjttR0FBdkIsdUJBQXVCOzs0RkFBdkIsdUJBQXVCO2tCQUpuQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxrQkFBa0I7b0JBQzVCLFVBQVUsRUFBRSxJQUFJO2lCQUNuQjsrRUFFYSxjQUFjO3NCQUF2QixNQUFNO2dCQUNFLGFBQWE7c0JBQXJCLEtBQUs7Z0JBTU4sU0FBUztzQkFEUixZQUFZO3VCQUFDLFNBQVMsRUFBRSxDQUFDLFFBQVEsQ0FBQztnQkFTbkMsWUFBWTtzQkFEWCxZQUFZO3VCQUFDLGFBQWEsRUFBRSxDQUFDLFFBQVEsQ0FBQztnQkFNdkMsT0FBTztzQkFETixZQUFZO3VCQUFDLE9BQU87Z0JBT3JCLE9BQU87c0JBRE4sWUFBWTt1QkFBQyxnQkFBZ0IsRUFBRSxDQUFDLFFBQVEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gICAgRGlyZWN0aXZlLFxuICAgIEVsZW1lbnRSZWYsXG4gICAgRXZlbnRFbWl0dGVyLFxuICAgIEhvc3RMaXN0ZW5lcixcbiAgICBJbnB1dCxcbiAgICBPdXRwdXQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgSUNhSW5wdXQgfSBmcm9tICcuLi9jb25maWcnO1xuXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogJ1tjb21tYW5kVmlzaWJsZV0nLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG59KVxuZXhwb3J0IGNsYXNzIENvbW1hbmRWaXNpYmxlRGlyZWN0aXZlIHtcbiAgICBAT3V0cHV0KCkgY29tbWFuZFZpc2libGUgPSBuZXcgRXZlbnRFbWl0dGVyPGJvb2xlYW4+KCk7IC8vIOKchSBFbWl0IHRydWUvZmFsc2VcbiAgICBASW5wdXQoKSByZXN0cmljdElucHV0ITogSUNhSW5wdXQ7XG4gICAgLy90aGlzLl9pbnB1dENvbmZpZy5jb21tYW5kc1xuXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBlbDogRWxlbWVudFJlZikge31cblxuICAgIEBIb3N0TGlzdGVuZXIoJ2tleWRvd24nLCBbJyRldmVudCddKVxuICAgIG9uS2V5RG93bihldmVudDogS2V5Ym9hcmRFdmVudCkge1xuICAgICAgICBpZiAoKGV2ZW50LmtleSA9PT0gJ1RhYicgJiYgZXZlbnQuc2hpZnRLZXkpIHx8IGV2ZW50LmtleSA9PT0gJ1RhYicpIHtcbiAgICAgICAgICAgIHRoaXMuZW1pdENvbW1hbmRWaXNpYmxlKGZhbHNlKTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIC8vIOKchSBEZXRlY3Qgd2hlbiB0aGUgYnJvd3NlciBsb3NlcyBmb2N1cyAoY2xpY2tpbmcgb3V0c2lkZSlcbiAgICBASG9zdExpc3RlbmVyKCd3aW5kb3c6Ymx1cicsIFsnJGV2ZW50J10pXG4gICAgb25XaW5kb3dCbHVyKGV2ZW50OiBGb2N1c0V2ZW50KSB7XG4gICAgICAgIHRoaXMuZW1pdENvbW1hbmRWaXNpYmxlKGZhbHNlKTtcbiAgICB9XG5cbiAgICBASG9zdExpc3RlbmVyKCdmb2N1cycpXG4gICAgb25Gb2N1cygpIHtcbiAgICAgICAgLy8gU2hvdyBjb21tYW5kcyBvbiBmb2N1c1xuICAgICAgICB0aGlzLmVtaXRDb21tYW5kVmlzaWJsZSh0cnVlKTtcbiAgICB9XG5cbiAgICBASG9zdExpc3RlbmVyKCdkb2N1bWVudDpjbGljaycsIFsnJGV2ZW50J10pXG4gICAgb25DbGljayhldmVudDogRXZlbnQpIHtcbiAgICAgICAgaWYgKCF0aGlzLnJlc3RyaWN0SW5wdXQuY29tbWFuZHMpIHJldHVybjtcbiAgICAgICAgY29uc3QgY2xpY2tlZEVsZW1lbnQgPSBldmVudC50YXJnZXQgYXMgSFRNTEVsZW1lbnQ7XG4gICAgICAgIGNvbnN0IGlucHV0UGFyZW50ID0gdGhpcy5lbC5uYXRpdmVFbGVtZW50LnBhcmVudE5vZGU7XG4gICAgICAgIC8vIOKchSBDaGVjayBpZiBjbGlja2VkIGVsZW1lbnQgaXMgaW5zaWRlIGEgYDx0YS1pbnB1dC1jb21tYW5kcz5gIHBhcmVudFxuICAgICAgICBpZiAoXG4gICAgICAgICAgICAhdGhpcy5pc0luc2lkZUVsZW1lbnQoY2xpY2tlZEVsZW1lbnQsICdBUFAtQ0EtSU5QVVQtQ09NTUFORFMnKSAmJlxuICAgICAgICAgICAgIXRoaXMuZWwubmF0aXZlRWxlbWVudC5jb250YWlucyhldmVudC50YXJnZXQpICYmXG4gICAgICAgICAgICBpbnB1dFBhcmVudCAhPSBldmVudC50YXJnZXRcbiAgICAgICAgKSB7XG4gICAgICAgICAgICB0aGlzLmNvbW1hbmRWaXNpYmxlLmVtaXQoZmFsc2UpOyAvLyDinIUgVHJpZ2dlciBldmVudCB3aGVuIGNsaWNraW5nIG91dHNpZGVcbiAgICAgICAgfVxuICAgIH1cblxuICAgIC8qKlxuICAgICAqIOKchSBSZWN1cnNpdmVseSBjaGVja3MgaWYgYW4gZWxlbWVudCBoYXMgYSBzcGVjaWZpYyBwYXJlbnQgdGFnXG4gICAgICovXG4gICAgcHJpdmF0ZSBpc0luc2lkZUVsZW1lbnQoXG4gICAgICAgIGVsZW1lbnQ6IEhUTUxFbGVtZW50IHwgbnVsbCxcbiAgICAgICAgdGFnTmFtZTogc3RyaW5nXG4gICAgKTogYm9vbGVhbiB7XG4gICAgICAgIHdoaWxlIChlbGVtZW50KSB7XG4gICAgICAgICAgICBpZiAoZWxlbWVudC50YWdOYW1lID09PSB0YWdOYW1lKSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIHRydWU7IC8vIOKchSBGb3VuZCB0aGUgcGFyZW50IHdpdGggdGhlIHNwZWNpZmllZCB0YWdcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIGVsZW1lbnQgPSBlbGVtZW50LnBhcmVudEVsZW1lbnQ7IC8vIE1vdmUgdXAgdGhlIERPTSB0cmVlXG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIGZhbHNlOyAvLyDinYwgTm8gbWF0Y2hpbmcgcGFyZW50IGZvdW5kXG4gICAgfVxuXG4gICAgcHJpdmF0ZSBlbWl0Q29tbWFuZFZpc2libGUoc3RhdHVzOiBib29sZWFuKSB7XG4gICAgICAgIGlmICh0aGlzLnJlc3RyaWN0SW5wdXQuY29tbWFuZHMpIHtcbiAgICAgICAgICAgIHRoaXMuY29tbWFuZFZpc2libGUuZW1pdChzdGF0dXMpO1xuICAgICAgICB9XG4gICAgfVxufSJdfQ==
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbWFuZC12aXNpYmxlLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NhLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2NhLWlucHV0L2RpcmVjdGl2ZXMvY29tbWFuZC12aXNpYmxlLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0gsU0FBUyxFQUVULFlBQVksRUFDWixZQUFZLEVBQ1osS0FBSyxFQUNMLE1BQU0sR0FDVCxNQUFNLGVBQWUsQ0FBQzs7QUFPdkIsTUFBTSxPQUFPLHVCQUF1QjtJQUloQyxZQUFvQixFQUFjO1FBQWQsT0FBRSxHQUFGLEVBQUUsQ0FBWTtRQUh4QixtQkFBYyxHQUFHLElBQUksWUFBWSxFQUFXLENBQUMsQ0FBQyxvQkFBb0I7SUFHdkMsQ0FBQztJQUd0QyxTQUFTLENBQUMsS0FBb0I7UUFDMUIsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLEtBQUssS0FBSyxJQUFJLEtBQUssQ0FBQyxRQUFRLENBQUMsSUFBSSxLQUFLLENBQUMsR0FBRyxLQUFLLEtBQUssRUFBRSxDQUFDO1lBQ2pFLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNuQyxDQUFDO0lBQ0wsQ0FBQztJQUdELFlBQVk7UUFDUixJQUFJLENBQUMsa0JBQWtCLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDbkMsQ0FBQztJQUdELE9BQU87UUFDSCx5QkFBeUI7UUFDekIsSUFBSSxDQUFDLGtCQUFrQixDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ2xDLENBQUM7SUFFTyxrQkFBa0IsQ0FBQyxNQUFlO1FBQ3RDLElBQUksSUFBSSxDQUFDLGFBQWEsQ0FBQyxRQUFRLEVBQUUsQ0FBQztZQUM5QixJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUNyQyxDQUFDO0lBQ0wsQ0FBQzsrR0E1QlEsdUJBQXVCO21HQUF2Qix1QkFBdUI7OzRGQUF2Qix1QkFBdUI7a0JBSm5DLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLGtCQUFrQjtvQkFDNUIsVUFBVSxFQUFFLElBQUk7aUJBQ25COytFQUVhLGNBQWM7c0JBQXZCLE1BQU07Z0JBQ0UsYUFBYTtzQkFBckIsS0FBSztnQkFLTixTQUFTO3NCQURSLFlBQVk7dUJBQUMsU0FBUyxFQUFFLENBQUMsUUFBUSxDQUFDO2dCQVFuQyxZQUFZO3NCQURYLFlBQVk7dUJBQUMsTUFBTTtnQkFNcEIsT0FBTztzQkFETixZQUFZO3VCQUFDLE9BQU8iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICAgIERpcmVjdGl2ZSxcbiAgICBFbGVtZW50UmVmLFxuICAgIEV2ZW50RW1pdHRlcixcbiAgICBIb3N0TGlzdGVuZXIsXG4gICAgSW5wdXQsXG4gICAgT3V0cHV0LFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IElDYUlucHV0IH0gZnJvbSAnLi4vY29uZmlnJztcblxuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICdbY29tbWFuZFZpc2libGVdJyxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxufSlcbmV4cG9ydCBjbGFzcyBDb21tYW5kVmlzaWJsZURpcmVjdGl2ZSB7XG4gICAgQE91dHB1dCgpIGNvbW1hbmRWaXNpYmxlID0gbmV3IEV2ZW50RW1pdHRlcjxib29sZWFuPigpOyAvLyDinIUgRW1pdCB0cnVlL2ZhbHNlXG4gICAgQElucHV0KCkgcmVzdHJpY3RJbnB1dCE6IElDYUlucHV0O1xuXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBlbDogRWxlbWVudFJlZikge31cblxuICAgIEBIb3N0TGlzdGVuZXIoJ2tleWRvd24nLCBbJyRldmVudCddKVxuICAgIG9uS2V5RG93bihldmVudDogS2V5Ym9hcmRFdmVudCkge1xuICAgICAgICBpZiAoKGV2ZW50LmtleSA9PT0gJ1RhYicgJiYgZXZlbnQuc2hpZnRLZXkpIHx8IGV2ZW50LmtleSA9PT0gJ1RhYicpIHtcbiAgICAgICAgICAgIHRoaXMuZW1pdENvbW1hbmRWaXNpYmxlKGZhbHNlKTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIEBIb3N0TGlzdGVuZXIoJ2JsdXInKVxuICAgIG9uV2luZG93Qmx1cigpIHtcbiAgICAgICAgdGhpcy5lbWl0Q29tbWFuZFZpc2libGUoZmFsc2UpO1xuICAgIH1cblxuICAgIEBIb3N0TGlzdGVuZXIoJ2ZvY3VzJylcbiAgICBvbkZvY3VzKCkge1xuICAgICAgICAvLyBTaG93IGNvbW1hbmRzIG9uIGZvY3VzXG4gICAgICAgIHRoaXMuZW1pdENvbW1hbmRWaXNpYmxlKHRydWUpO1xuICAgIH1cblxuICAgIHByaXZhdGUgZW1pdENvbW1hbmRWaXNpYmxlKHN0YXR1czogYm9vbGVhbikge1xuICAgICAgICBpZiAodGhpcy5yZXN0cmljdElucHV0LmNvbW1hbmRzKSB7XG4gICAgICAgICAgICB0aGlzLmNvbW1hbmRWaXNpYmxlLmVtaXQoc3RhdHVzKTtcbiAgICAgICAgfVxuICAgIH1cbn1cbiJdfQ==
@@ -33,7 +33,9 @@ export class RestrictInputDirective extends RestrictionPipeMixin(class {
33
33
  ? inputValue.replace(/[^0-9.]/g, '')
34
34
  : inputValue;
35
35
  if (regex.test(inputValueToTestWithRegex)) {
36
+ console.log("WHAT IS HEREEE", inputValueToTestWithRegex);
36
37
  if (maxLength) {
38
+ console.log("WHAT IS MAX VALUE", maxLength);
37
39
  // Allow only numbers and one dot (.)
38
40
  const tempLengthValue = isDecimalAndDotOnly
39
41
  ? inputValue.replace(/[^0-9.]/g, '')
@@ -92,4 +94,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
92
94
  type: HostListener,
93
95
  args: ['input', ['$event']]
94
96
  }] } });
95
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"restrict-input.directive.js","sourceRoot":"","sources":["../../../../../../../projects/ca-components/src/lib/components/ca-input/directives/restrict-input.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Directive,\n    ElementRef,\n    HostListener,\n    Injector,\n    Input,\n} from '@angular/core';\nimport { InputPatternPipe } from '../pipes/input-pattern.pipe';\nimport { ICaInput } from '../config';\nimport { InputTransformStringEnum } from '../enums/input-text-transform.enum';\nimport { RestrictionPipeMixin } from '../mixins/restriction-pipe.mixin';\n\n@Directive({\n    selector: '[restrictInput]',\n    standalone: true,\n    providers: [InputPatternPipe], // Provide the pipe so it can be injected\n})\nexport class RestrictInputDirective extends RestrictionPipeMixin(\n    class {\n        restrictInput!: ICaInput;\n    }\n) {\n    @Input() override restrictInput!: ICaInput;\n    private inputPatternPipe!: InputPatternPipe;\n\n    private lastValidInputValue: string = '';\n\n    constructor(\n        private el: ElementRef,\n        private injector: Injector\n    ) {\n        super();\n        this.inputPatternPipe = this.injector.get(InputPatternPipe); // Inject pipe manually\n    }\n\n    @HostListener('input', ['$event'])\n    onInput(event: InputEvent): void {\n        let inputValue = this.el.nativeElement.value;\n\n        const maxLength = this.restrictInput.maxLength;\n        const configName = this.restrictInput.name.toLowerCase();\n        const {\n            regex,\n            restrictConsecutiveDots,\n            restrictMultipeDots,\n            restrictConsecutiveSpaces,\n            isDecimalAndDotOnly,\n        } = this.inputPatternPipe.transform(configName, this.restrictInput);\n\n        // Prevent first space character\n        if (inputValue.startsWith(' ')) {\n            inputValue = inputValue.trimStart(); // Remove leading space\n        }\n\n        // Allow dots but dont allow on first place...\n        const dotIndex = inputValue.indexOf('.');\n        if (dotIndex == 0) {\n            if (this.restrictInput.priceSeparator) {\n                inputValue = `0${inputValue}`;\n            } else inputValue = '';\n        }\n\n        const inputValueToTestWithRegex = isDecimalAndDotOnly\n            ? inputValue.replace(/[^0-9.]/g, '')\n            : inputValue;\n\n        if (regex.test(inputValueToTestWithRegex)) {\n            if (maxLength) {\n                // Allow only numbers and one dot (.)\n                const tempLengthValue = isDecimalAndDotOnly\n                    ? inputValue.replace(/[^0-9.]/g, '')\n                    : inputValue;\n\n                const [integerPart, decimalPart] = tempLengthValue.split('.');\n\n                // Ensure integer part respects maxLength (excluding thousand separators)\n                if (integerPart.length > maxLength!) {\n                    inputValue =\n                        integerPart.substring(0, maxLength) +\n                        (decimalPart ? '.' + decimalPart : '');\n                }\n            }\n\n            if (restrictConsecutiveSpaces) {\n                inputValue = inputValue.replace(/\\s{2,}/g, ' '); // Replace consecutive spaces with a single space\n            }\n\n            if (restrictConsecutiveDots) {\n                inputValue = inputValue.replace(/\\.{2,}/g, '.'); // Replace consecutive dots with a single dot\n            }\n\n            if (restrictMultipeDots) {\n                inputValue = inputValue.replace(\n                    /^([^.]*)\\.(.*)$/,\n                    (m: any, p1: any, p2: any) =>\n                        p1 + '.' + p2.replace(/\\./g, '')\n                );\n            }\n\n            // console.log(\"WHAT IS INPUT VALUE\", inputValue);\n\n            this.el.nativeElement.value = inputValue;\n\n            // 🔥 Manually trigger max Directive because current one needs to be done first\n            this.el.nativeElement.dispatchEvent(\n                new Event('applyMaxValueDirective')\n            );\n\n            const transformText = this.getTextTransformation(\n                inputValue,\n                this.restrictInput?.textTransform as InputTransformStringEnum\n            );\n\n            if (transformText) this.el.nativeElement.value = transformText;\n\n            if (!this.checkRangeRegex(this.el.nativeElement.value)) {\n                // If entered is not passing regEx then the input value will be last saved...\n                this.el.nativeElement.value = this.lastValidInputValue;\n            } else {\n                // Save last valid value\n                this.lastValidInputValue = inputValue;\n            }\n        } else {\n            // If entered is not passing regEx then the input value will be last saved...\n            this.el.nativeElement.value = this.lastValidInputValue;\n        }\n    }\n}\n"]}
97
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"restrict-input.directive.js","sourceRoot":"","sources":["../../../../../../../projects/ca-components/src/lib/components/ca-input/directives/restrict-input.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Directive,\n    ElementRef,\n    HostListener,\n    Injector,\n    Input,\n} from '@angular/core';\nimport { InputPatternPipe } from '../pipes/input-pattern.pipe';\nimport { ICaInput } from '../config';\nimport { InputTransformStringEnum } from '../enums/input-text-transform.enum';\nimport { RestrictionPipeMixin } from '../mixins/restriction-pipe.mixin';\n\n@Directive({\n    selector: '[restrictInput]',\n    standalone: true,\n    providers: [InputPatternPipe], // Provide the pipe so it can be injected\n})\nexport class RestrictInputDirective extends RestrictionPipeMixin(\n    class {\n        restrictInput!: ICaInput;\n    }\n) {\n    @Input() override restrictInput!: ICaInput;\n    private inputPatternPipe!: InputPatternPipe;\n\n    private lastValidInputValue: string = '';\n\n    constructor(\n        private el: ElementRef,\n        private injector: Injector\n    ) {\n        super();\n        this.inputPatternPipe = this.injector.get(InputPatternPipe); // Inject pipe manually\n    }\n\n    @HostListener('input', ['$event'])\n    onInput(event: InputEvent): void {\n        let inputValue = this.el.nativeElement.value;\n\n        const maxLength = this.restrictInput.maxLength;\n        const configName = this.restrictInput.name.toLowerCase();\n        const {\n            regex,\n            restrictConsecutiveDots,\n            restrictMultipeDots,\n            restrictConsecutiveSpaces,\n            isDecimalAndDotOnly,\n        } = this.inputPatternPipe.transform(configName, this.restrictInput);\n\n        // Prevent first space character\n        if (inputValue.startsWith(' ')) {\n            inputValue = inputValue.trimStart(); // Remove leading space\n        }\n\n        // Allow dots but dont allow on first place...\n        const dotIndex = inputValue.indexOf('.');\n        if (dotIndex == 0) {\n            if (this.restrictInput.priceSeparator) {\n                inputValue = `0${inputValue}`;\n            } else inputValue = '';\n        }\n\n        const inputValueToTestWithRegex = isDecimalAndDotOnly\n            ? inputValue.replace(/[^0-9.]/g, '')\n            : inputValue;\n\n\n            \n\n        if (regex.test(inputValueToTestWithRegex)) {\n\n            console.log(\"WHAT IS HEREEE\", inputValueToTestWithRegex);\n            if (maxLength) {\n                console.log(\"WHAT IS MAX VALUE\", maxLength);\n                // Allow only numbers and one dot (.)\n                const tempLengthValue = isDecimalAndDotOnly\n                    ? inputValue.replace(/[^0-9.]/g, '')\n                    : inputValue;\n\n                const [integerPart, decimalPart] = tempLengthValue.split('.');\n\n                // Ensure integer part respects maxLength (excluding thousand separators)\n                if (integerPart.length > maxLength!) {\n                    inputValue =\n                        integerPart.substring(0, maxLength) +\n                        (decimalPart ? '.' + decimalPart : '');\n                }\n            }\n\n            if (restrictConsecutiveSpaces) {\n                inputValue = inputValue.replace(/\\s{2,}/g, ' '); // Replace consecutive spaces with a single space\n            }\n\n            if (restrictConsecutiveDots) {\n                inputValue = inputValue.replace(/\\.{2,}/g, '.'); // Replace consecutive dots with a single dot\n            }\n\n            if (restrictMultipeDots) {\n                inputValue = inputValue.replace(\n                    /^([^.]*)\\.(.*)$/,\n                    (m: any, p1: any, p2: any) =>\n                        p1 + '.' + p2.replace(/\\./g, '')\n                );\n            }\n\n            // console.log(\"WHAT IS INPUT VALUE\", inputValue);\n\n            this.el.nativeElement.value = inputValue;\n\n            // 🔥 Manually trigger max Directive because current one needs to be done first\n            this.el.nativeElement.dispatchEvent(\n                new Event('applyMaxValueDirective')\n            );\n\n            const transformText = this.getTextTransformation(\n                inputValue,\n                this.restrictInput?.textTransform as InputTransformStringEnum\n            );\n\n            if (transformText) this.el.nativeElement.value = transformText;\n\n            if (!this.checkRangeRegex(this.el.nativeElement.value)) {\n                // If entered is not passing regEx then the input value will be last saved...\n                this.el.nativeElement.value = this.lastValidInputValue;\n            } else {\n                // Save last valid value\n                this.lastValidInputValue = inputValue;\n            }\n        } else {\n            // If entered is not passing regEx then the input value will be last saved...\n            this.el.nativeElement.value = this.lastValidInputValue;\n        }\n    }\n}\n"]}
@@ -106,7 +106,8 @@ export class InputTestComponent extends InputCommandMixin(InputHelperMixin(Input
106
106
  this.onChange(value); // Notify Angular form about the change
107
107
  if (value && this._inputConfig.updateAsTouchedOnEdit)
108
108
  this.onTouched(); // Mark as touched
109
- this.inputElement.nativeElement.value = value;
109
+ if (!this._inputConfig.isDropdown)
110
+ this.inputElement.nativeElement.value = value;
110
111
  this.chdet.detectChanges();
111
112
  }
112
113
  handleInput(event) {
@@ -126,10 +127,12 @@ export class InputTestComponent extends InputCommandMixin(InputHelperMixin(Input
126
127
  }
127
128
  handleChangeInputAndUpdateControl(value) {
128
129
  this.onChange(value);
129
- this.inputElement.nativeElement.value = value;
130
- // Trigger all inputs directives that listen for input Event
131
- const event = new Event('input', { bubbles: true });
132
- this.inputElement.nativeElement.dispatchEvent(event);
130
+ if (!this._inputConfig.isDropdown) {
131
+ this.inputElement.nativeElement.value = value;
132
+ // Trigger all inputs directives that listen for input Event
133
+ const event = new Event('input', { bubbles: true });
134
+ this.inputElement.nativeElement.dispatchEvent(event);
135
+ }
133
136
  }
134
137
  handleInputFocus(event) {
135
138
  this.focusInputEvent.emit(event);
@@ -260,4 +263,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
260
263
  type: Output,
261
264
  args: ['dropDownKeyNavigation']
262
265
  }] } });
263
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-test.component.js","sourceRoot":"","sources":["../../../../../../../projects/ca-components/src/lib/components/ca-input/input-test/input-test.component.ts","../../../../../../../projects/ca-components/src/lib/components/ca-input/input-test/input-test.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    Input,\n    Optional,\n    Output,\n    Self,\n    ViewChild,\n    ViewEncapsulation,\n} from '@angular/core';\n\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport { NgbModule } from '@ng-bootstrap/ng-bootstrap';\nimport { CommonModule } from '@angular/common';\nimport { AngularSvgIconModule } from 'angular-svg-icon';\n\n// models\nimport { ICaInput } from '../config';\nimport { InputChangeValue, InputSvgRoutes } from '../utils';\nimport { CommandsEvent, LabelColor } from '../models';\n\n// emums\nimport { InputCommandsType, InputStringEnum } from '../enums';\nimport { DropdownTemplateTypeEnum } from '../../ca-input-dropdown/enums';\n\n// pipes\nimport {\n    InputClassPipe,\n    InputContainerClassPipe,\n    InputDropdownArrowClassPipe,\n    InputErrorPipe,\n    InputPlaceholderIconRightClassPipe,\n    InputPlaceholderTextClassPipe,\n    InputTypePipe,\n    LabelClassPipe,\n    ShowClearPipe,\n    ShowDropdownArrowPipe,\n    ShowPlaceholderTextPipe,\n    ShowValidCheckPipe,\n} from '../pipes';\nimport {\n    CaSvgPipe,\n    LoadStatusColorPipe,\n    ThousandSeparatorPipe,\n} from '../../../pipes';\n\n// mask\nimport { NgxMaskModule } from 'ngx-mask';\nimport { NgxMaskService } from 'ngx-mask';\n\n// components\nimport { CaInputPasswordComponent } from '../components/ca-input-password/ca-input-password.component';\nimport { CaInputPlaceholderIconComponent } from '../components/ca-input-placeholder-icon/ca-input-placeholder-icon.component';\nimport { CaInputClearComponent } from '../components/ca-input-clear/ca-input-clear.component';\nimport { CaAppTooltipV2Component } from '../../ca-app-tooltip-v2/ca-app-tooltip-v2.component';\nimport { CaInputCommandsComponent } from '../components/ca-input-commands/ca-input-commands.component';\n\n// directives\nimport { CapsLockDirective } from '../directives';\nimport { MaxValueDirective } from '../directives';\nimport { RestrictInputDirective } from '../directives';\nimport { PriceFormatDirective } from '../directives';\nimport { CommandVisibleDirective } from '../directives/command-visible.directive';\n\n// class\nimport { EventInputManager } from '../base-classes/ca-input-event-manager';\n\n// mixins\nimport { InputCommandMixin } from '../mixins/input-command.mixin';\nimport { InputHelperMixin } from '../mixins/input-helper.mixin';\nimport { OptionModel } from '../../ca-input-dropdown/models';\n\nclass InputBase {\n    public inputElement!: ElementRef;\n    public _inputConfig!: ICaInput;\n    public isVisibleCommands: boolean = false;\n    public maskApplier!: NgxMaskService;\n    public thousandSeparatorPipe!: ThousandSeparatorPipe;\n    public isFocusInput: boolean = false;\n    public isEditInput: boolean = false;\n    public isDropdownToggler: boolean = false;\n    public isTouchedInput: boolean = false;\n    public setCommandEvent!: EventInputManager<CommandsEvent>;\n\n    public handleToggleDropdownOptions!: EventEmitter<void>;\n\n    public onTouched = () => {};\n    public onChange(_: any): void {}\n    public handleChangeInputAndUpdateControl(_: InputChangeValue): void {}\n}\n\n@Component({\n    selector: 'ca-input-test',\n    standalone: true,\n    imports: [\n        // Modules\n        CommonModule,\n        NgbModule,\n        AngularSvgIconModule,\n        NgxMaskModule,\n\n        // Pipes\n        InputErrorPipe,\n        InputContainerClassPipe,\n        InputClassPipe,\n        InputPlaceholderTextClassPipe,\n        ShowPlaceholderTextPipe,\n        LabelClassPipe,\n        CaSvgPipe,\n        LoadStatusColorPipe,\n        InputPlaceholderIconRightClassPipe,\n        MaxValueDirective,\n        InputTypePipe,\n        ShowValidCheckPipe,\n        ShowDropdownArrowPipe,\n        InputDropdownArrowClassPipe,\n\n        // Directives\n        RestrictInputDirective,\n        PriceFormatDirective,\n        ShowClearPipe,\n        CapsLockDirective,\n        CommandVisibleDirective,\n\n        // Components\n        CaInputClearComponent,\n        CaAppTooltipV2Component,\n        CaInputPlaceholderIconComponent,\n        CaInputPasswordComponent,\n        CaInputCommandsComponent,\n    ],\n    templateUrl: './input-test.component.html',\n    styleUrl: './input-test.component.scss',\n    encapsulation: ViewEncapsulation.None,\n})\nexport class InputTestComponent\n    extends InputCommandMixin(InputHelperMixin(InputBase))\n    implements ControlValueAccessor, AfterViewInit\n{\n    public inputValue: InputChangeValue = '';\n    public override _inputConfig!: ICaInput;\n\n    public inputSvgRoutes = InputSvgRoutes;\n\n    @ViewChild('input', { static: true }) override inputElement!: ElementRef;\n    @Input() selectedDropdownLabelColor!: LabelColor | null;\n    @Input() template!: string;\n    @Input() incorrectValue!: boolean;\n    @Input() set inputConfig(config: ICaInput) {\n        this._inputConfig = config;\n    }\n\n    @Input() activeItem!: OptionModel | null;\n\n    @Output('handleToggleDropdownOptions')\n    override handleToggleDropdownOptions: EventEmitter<void> =\n        new EventEmitter<void>();\n\n    @Output('incorrectEvent') incorrectInput: EventEmitter<boolean> =\n        new EventEmitter<boolean>();\n\n    @Output('blurInput') blurInput: EventEmitter<boolean> =\n        new EventEmitter<boolean>();\n    @Output('focusInput') focusInputEvent: EventEmitter<FocusEvent> =\n        new EventEmitter<FocusEvent>();\n    @Output('change') changeInput: EventEmitter<InputChangeValue> =\n        new EventEmitter<InputChangeValue>();\n    @Output('commandEvent') commandEvent: EventEmitter<CommandsEvent> =\n        new EventEmitter<CommandsEvent>();\n    @Output('clear') clearInputEvent: EventEmitter<boolean> =\n        new EventEmitter<boolean>();\n\n    // Dropdown\n    @Output('showHideDropdown') showHideDropdownEvent: EventEmitter<boolean> =\n        new EventEmitter<boolean>();\n    @Output('dropDownKeyNavigation') dropDownKeyNavigationEvent: EventEmitter<{\n        keyCode: number;\n        data: ICaInput | null;\n    }> = new EventEmitter<{\n        keyCode: number;\n        data: ICaInput | null;\n    }>();\n\n    // events\n    public override setCommandEvent = new EventInputManager<CommandsEvent>(\n        null,\n        this.commandEvent\n    );\n\n    public isCapsLockOn = false;\n\n    public inputCommandsType = InputCommandsType;\n    public inputStringEnum = InputStringEnum;\n    public dropdownTemplateTypeEnum = DropdownTemplateTypeEnum;\n\n    // Password\n    public isTogglePassword: boolean = false;\n\n    public get inputConfig() {\n        return this._inputConfig;\n    }\n\n    constructor(\n        @Optional() @Self() public ngControl: NgControl,\n        public chdet: ChangeDetectorRef,\n        public override maskApplier: NgxMaskService,\n        public override thousandSeparatorPipe: ThousandSeparatorPipe\n    ) {\n        super();\n        if (this.ngControl) {\n            this.ngControl.valueAccessor = this;\n        }\n    }\n\n    ngAfterViewInit(): void {\n        Promise.resolve().then(() => {\n            this.handleChangeInputAndUpdateControl(this.inputValue);\n\n            if (this._inputConfig.autoFocus)\n                this.inputElement.nativeElement.focus();\n        });\n    }\n\n    get control() {\n        return this.ngControl?.control;\n    }\n\n    public registerOnChange(fn: any): void {\n        this.onChange = fn;\n    }\n\n    registerOnTouched(fn: () => void): void {\n        this.onTouched = fn;\n    }\n\n    public writeValue(obj: InputChangeValue): void {\n        const value = this.transformValue(this._inputConfig, obj); // ✅ Apply mask\n\n        this.inputValue = value;\n        this.onChange(value); // Notify Angular form about the change\n        if (value && this._inputConfig.updateAsTouchedOnEdit) this.onTouched(); // Mark as touched\n        this.inputElement.nativeElement.value = value;\n\n        this.chdet.detectChanges();\n    }\n\n    handleInput(event: Event): void {\n        const value = (event.target as HTMLInputElement).value;\n        this.onChange(value); // Notify Angular form about the change\n        if (value) this.onTouched(); // Mark as touched\n\n        if (this.inputValue === value) {\n            this.control?.markAsUntouched();\n        }\n    }\n\n    public clearInput(event: Event): void {\n        event.preventDefault();\n        event.stopPropagation();\n        this.handleChangeInputAndUpdateControl('');\n        this.clearInputEvent.emit(true);\n    }\n\n    public override handleChangeInputAndUpdateControl(value: InputChangeValue) {\n        this.onChange(value);\n        this.inputElement.nativeElement.value = value;\n        // Trigger all inputs directives that listen for input Event\n        const event = new Event('input', { bubbles: true });\n        this.inputElement.nativeElement.dispatchEvent(event);\n    }\n\n    public handleInputFocus(event: FocusEvent) {\n        this.focusInputEvent.emit(event);\n        this.isFocusInput = true;\n    }\n\n    public handleInputBlur(event: FocusEvent) {\n        this.blurInput.emit(true);\n        this.isFocusInput = false;\n    }\n\n    public onPopoverShown(): void {\n        if (!this._inputConfig.dropdownLabel) {\n            this.isFocusInput = true;\n        }\n    }\n\n    public onPopoverHidden(): void {\n        if (!this._inputConfig.dropdownLabel) {\n            this.isFocusInput = false;\n        }\n    }\n\n    public onTogglePassword(event: Event): void {\n        event.preventDefault();\n        this.isTogglePassword = !this.isTogglePassword;\n    }\n\n    public handleCapsLock(status: boolean) {\n        this.isCapsLockOn = status;\n    }\n\n    public handleCommandVisible(status: boolean) {\n        this.isVisibleCommands = status;\n    }\n\n    public identify(index: number): number {\n        return index;\n    }\n\n    public handleKeyDown(event: KeyboardEvent) {\n        this.dropDownKeyNavigationEvent.emit({\n            keyCode: event.keyCode,\n            data: this.inputConfig,\n        });\n    }\n}\n","<div\n    class=\"input-custom-group {{ _inputConfig.customClass }}\"\n    [ngClass]=\"\n        control\n            | inputContainerClass\n                : isFocusInput\n                : control?.touched!\n                : _inputConfig\n                : control?.value\n    \"\n    ngbTooltip\n    [mainCaTooltip]=\"control?.errors | inputError: _inputConfig.name\"\n    [tooltipBackground]=\"'#DF3C3C'\"\n    [disableTooltip]=\"!_inputConfig.requiredLabel || !!control?.valid\"\n    position=\"bottom\"\n    triggers=\"hover\"\n>\n    <!-- Input Commands -->\n    @if (_inputConfig.commands?.active && isVisibleCommands) {\n        <app-ca-input-commands\n            [inputConfig]=\"_inputConfig\"\n            [isFocusInput]=\"isFocusInput\"\n            [isVisibleCommands]=\"isVisibleCommands\"\n            (onCommandsClick)=\"onCommands($event)\"\n        >\n        </app-ca-input-commands>\n    }\n    <!-- Input Valid Check -->\n    @if (\n        control | showValidCheck: isFocusInput : _inputConfig : control?.value\n    ) {\n        <svg-icon\n            class=\"input-required-check {{ _inputConfig.customClass }}\"\n            [src]=\"inputSvgRoutes.confirmSvg\"\n        ></svg-icon>\n    }\n    <!-- Input Password Caps Lock And Eye -->\n    @if (_inputConfig.type === 'password') {\n        <app-ca-input-password\n            [inputConfig]=\"_inputConfig\"\n            [getSuperControl]=\"control\"\n            [isFocusInput]=\"isFocusInput\"\n            [isTouchedInput]=\"isTouchedInput\"\n            [isCapsLockOn]=\"isCapsLockOn\"\n            [isTogglePassword]=\"isTogglePassword\"\n            (onTogglePasswordClick)=\"onTogglePassword($event)\"\n        >\n        </app-ca-input-password>\n    }\n    <!-- Input Clear -->\n    @if (_inputConfig | showClear) {\n        <app-ca-input-clear\n            [inputConfig]=\"_inputConfig\"\n            [getSuperControl]=\"control\"\n            [isFocusInput]=\"isFocusInput\"\n            [incorrectValue]=\"incorrectValue\"\n            [selectedDropdownLabelColor]=\"selectedDropdownLabelColor\"\n            [template]=\"template\"\n            (clearInputClick)=\"clearInput($event)\"\n        >\n        </app-ca-input-clear>\n    }\n\n    <!-- Input Dropdown Arrow -->\n    @if (_inputConfig | showDropdownArrow) {\n        <svg-icon\n            class=\"input-dropdown-arrow {{ _inputConfig.customClass }}\"\n            [ngClass]=\"\n                control\n                    | inputDropdownArrowClass\n                        : isFocusInput\n                        : _inputConfig\n                        : isTouchedInput\n                        : control?.value\n            \"\n            [src]=\"inputSvgRoutes.inputDropdownArrowSvg\"\n            (click)=\"toggleDropdownOptions()\"\n        ></svg-icon>\n    }\n\n    <!-- Input Placeholder Icon -->\n    @if (_inputConfig.placeholderIcon) {\n        <app-ca-input-placeholder-icon\n            [inputConfig]=\"_inputConfig\"\n            [getSuperControl]=\"control\"\n            [isFocusInput]=\"isFocusInput\"\n            [isTouchedInput]=\"control?.touched!\"\n            [selectedDropdownLabelColor]=\"selectedDropdownLabelColor\"\n            [isEditInput]=\"isEditInput\"\n            (onPlaceholderIconEventEmitter)=\"onPlaceholderIconEvent($event)\"\n            (onPopoverShownEmitter)=\"onPopoverShown()\"\n            (onPopoverHiddenEmitter)=\"onPopoverHidden()\"\n        >\n        </app-ca-input-placeholder-icon>\n    }\n\n    <!-- Input Placeholder Text -->\n    @if (\n        _inputConfig\n            | showPlaceholderText: control : isVisibleCommands : control?.value\n    ) {\n        <span\n            class=\"ca-placeholder-text {{ _inputConfig.customClass }}\"\n            [ngClass]=\"\n                isFocusInput\n                    | inputPlaceholderTextClass\n                        : control?.touched!\n                        : control\n                        : _inputConfig\n                        : isVisibleCommands\n                        : control?.value\n            \"\n            [style.left]=\"\n                _inputConfig.placeholderText?.toLowerCase() ===\n                    inputStringEnum.PERSONS ||\n                _inputConfig.placeholderText?.toLowerCase() ===\n                    inputStringEnum.VEHICLES\n                    ? 30 + (control?.value?.toString()?.length + 1) * 9 + 'px'\n                    : isFocusInput &&\n                        _inputConfig.placeholderText?.toLowerCase() !==\n                            inputCommandsType.MONTHS\n                      ? 'auto'\n                      : (control?.value?.toString()?.length + 1) * 8 + 'px'\n            \"\n            [style.right]=\"\n                isFocusInput &&\n                _inputConfig.placeholderText?.toLowerCase() !==\n                    inputCommandsType.MONTHS\n                    ? '28px'\n                    : 'auto'\n            \"\n        >\n            {{ _inputConfig.placeholderText }}\n        </span>\n    }\n\n    <!-- Input Label Counter -->\n    @if (\n        selectedDropdownLabelColor &&\n        control?.value &&\n        !isFocusInput &&\n        !_inputConfig.isDisabled &&\n        _inputConfig.showCount\n    ) {\n        <p\n            [style.top]=\"'4px'\"\n            [style.left]=\"(control?.value?.toString()?.length + 6.5) * 8 + 'px'\"\n            class=\"input-label-counter\"\n        >\n            {{ selectedDropdownLabelColor.count }}\n        </p>\n    }\n\n    <!-- Special Dropdown Selected SVG with or Without Text -->\n    @if (\n        _inputConfig?.dropdownImageInput?.iconsPath &&\n        activeItem &&\n        !_inputConfig?.hideAllItemsInInputDropdown &&\n        !(!_inputConfig.dropdownImageInput?.withText && isFocusInput) &&\n        !(\n            ['truck', 'trailer'].includes(\n                _inputConfig.dropdownImageInput?.template!\n            ) &&\n            isFocusInput &&\n            _inputConfig.dropdownImageInput?.remove\n        ) &&\n        !_inputConfig?.dropdownImageInput?.nameInitialsInsteadUrl\n    ) {\n        <svg-icon\n            [src]=\"_inputConfig.dropdownImageInput?.iconsPath!\"\n            class=\"dropdown-selected-image {{\n                _inputConfig.dropdownImageInput?.class\n            }}\"\n            [ngClass]=\"{\n                'unset-color':\n                    isFocusInput && _inputConfig.dropdownImageInput?.class,\n            }\"\n            [svgStyle]=\"{\n                fill:\n                    _inputConfig.dropdownImageInput?.color && !isFocusInput\n                        ? _inputConfig.dropdownImageInput?.color\n                        : '#ffffff',\n            }\"\n        >\n        </svg-icon>\n    }\n\n    <!-- Input Label -->\n    @if (!_inputConfig.multiSelectDropdownActive) {\n        <label\n            [for]=\"_inputConfig.name\"\n            class=\"input-label {{ _inputConfig.customClass }} {{\n                _inputConfig.multipleLabel?.customClass\n            }}\"\n            [ngClass]=\"\n                control?.value\n                    | labelClass\n                        : isFocusInput\n                        : _inputConfig\n                        : isTouchedInput\n                        : control?.invalid\n                        : control?.touched\n            \"\n        >\n            @if (_inputConfig.label) {\n                <span>{{ _inputConfig.label }} </span>\n            }\n\n            @if (_inputConfig.multipleLabel?.labels?.length) {\n                <div\n                    [class]=\"_inputConfig.multipleLabel?.customClass!\"\n                    [ngClass]=\"{\n                        'multiple-labels-position-on-focus':\n                            isFocusInput ||\n                            _inputConfig.multipleInputValues?.options?.length,\n                        required:\n                            _inputConfig.isRequired && !_inputConfig.isDisabled,\n                    }\"\n                >\n                    @for (\n                        label of _inputConfig.multipleLabel?.labels;\n                        track $index\n                    ) {\n                        <span>\n                            {{ label }}\n                        </span>\n                    }\n                </div>\n            }\n        </label>\n    }\n\n    <input\n        #input\n        (input)=\"handleInput($event)\"\n        [restrictInput]=\"inputConfig\"\n        priceFormat\n        [priceSeparator]=\"\n            inputConfig.priceSeparator || inputConfig.thousandSeparator\n        \"\n        (focus)=\"handleInputFocus($event)\"\n        (blur)=\"handleInputBlur($event)\"\n        (keydown)=\"handleKeyDown($event)\"\n        [readOnly]=\"_inputConfig.readOnly\"\n        [type]=\"_inputConfig.type | inputType: isTogglePassword\"\n        class=\"input-control\n            {{ _inputConfig.textTransform }}\n            {{ _inputConfig.textAlign }}\n            {{ _inputConfig.customClass }}\n        \"\n        [appMaxValue]=\"inputConfig.max\"\n        appCapsLock\n        (capsLockStatus)=\"handleCapsLock($event)\"\n        commandVisible\n        (commandVisible)=\"handleCommandVisible($event)\"\n        [placeholder]=\"\n            (_inputConfig.placeholderInsteadOfLabel &&\n            _inputConfig.placeholder &&\n            isFocusInput\n                ? _inputConfig.placeholder\n                : '') ||\n            (_inputConfig.placeholder && isFocusInput\n                ? _inputConfig.placeholder\n                : '')\n        \"\n        [mask]=\"_inputConfig.mask\"\n        [ngClass]=\"\n            control\n                | inputClass\n                    : isFocusInput\n                    : control?.touched!\n                    : _inputConfig\n                    : input\n                    : isVisibleCommands\n                    : control?.value\n                    : control?.invalid\n                    : control?.touched\n                    : isDropdownToggler\n                    : isEditInput\n                    : template\n        \"\n    />\n\n    <!-- Placeholder Icon on Right Side -->\n    @if (_inputConfig.placeholderIconRightSide) {\n        <svg-icon\n            class=\"placeholder-icon-right-side {{\n                _inputConfig.placeholderIconColor\n            }}\"\n            [ngClass]=\"\n                isFocusInput\n                    | inputPlaceholderIconRightClass\n                        : control\n                        : _inputConfig\n                        : isTouchedInput\n                        : control?.value\n            \"\n            [src]=\"\n                _inputConfig.placeholderIconRightSide.toLowerCase()\n                    | caSvg: 'common'\n            \"\n        ></svg-icon>\n    }\n\n    <!-- Input Error Message -->\n    @if (\n        !(!control?.value && isFocusInput) &&\n        (isTouchedInput || control?.touched || control?.value) &&\n        control?.invalid &&\n        !_inputConfig.isInvalidSearchInDropdown &&\n        !_inputConfig.isDisabled\n    ) {\n        @if (\n            !(_inputConfig.hideErrorMessage || _inputConfig.errorInsideInput)\n        ) {\n            <span class=\"input-error {{ _inputConfig.customClass }}\">\n                {{ control?.errors | inputError: _inputConfig.name }}\n            </span>\n        }\n\n        <!-- Error Message Inside Input -->\n        @if (_inputConfig.errorInsideInput) {\n            <span class=\"error-inside-input {{ _inputConfig.customClass }}\">\n                {{ control?.errors | inputError: _inputConfig.name }}\n            </span>\n        }\n    }\n\n    @if (_inputConfig.fixedPlacholder && input.value) {\n        <span class=\"input-fixed-placehoder-label\">\n            {{ _inputConfig.fixedPlacholder }}\n        </span>\n    }\n</div>\n"]}
266
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-test.component.js","sourceRoot":"","sources":["../../../../../../../projects/ca-components/src/lib/components/ca-input/input-test/input-test.component.ts","../../../../../../../projects/ca-components/src/lib/components/ca-input/input-test/input-test.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    Input,\n    Optional,\n    Output,\n    Self,\n    ViewChild,\n    ViewEncapsulation,\n} from '@angular/core';\n\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport { NgbModule } from '@ng-bootstrap/ng-bootstrap';\nimport { CommonModule } from '@angular/common';\nimport { AngularSvgIconModule } from 'angular-svg-icon';\n\n// models\nimport { ICaInput } from '../config';\nimport { InputChangeValue, InputSvgRoutes } from '../utils';\nimport { CommandsEvent, LabelColor } from '../models';\n\n// emums\nimport { InputCommandsType, InputStringEnum } from '../enums';\nimport { DropdownTemplateTypeEnum } from '../../ca-input-dropdown/enums';\n\n// pipes\nimport {\n    InputClassPipe,\n    InputContainerClassPipe,\n    InputDropdownArrowClassPipe,\n    InputErrorPipe,\n    InputPlaceholderIconRightClassPipe,\n    InputPlaceholderTextClassPipe,\n    InputTypePipe,\n    LabelClassPipe,\n    ShowClearPipe,\n    ShowDropdownArrowPipe,\n    ShowPlaceholderTextPipe,\n    ShowValidCheckPipe,\n} from '../pipes';\nimport {\n    CaSvgPipe,\n    LoadStatusColorPipe,\n    ThousandSeparatorPipe,\n} from '../../../pipes';\n\n// mask\nimport { NgxMaskModule } from 'ngx-mask';\nimport { NgxMaskService } from 'ngx-mask';\n\n// components\nimport { CaInputPasswordComponent } from '../components/ca-input-password/ca-input-password.component';\nimport { CaInputPlaceholderIconComponent } from '../components/ca-input-placeholder-icon/ca-input-placeholder-icon.component';\nimport { CaInputClearComponent } from '../components/ca-input-clear/ca-input-clear.component';\nimport { CaAppTooltipV2Component } from '../../ca-app-tooltip-v2/ca-app-tooltip-v2.component';\nimport { CaInputCommandsComponent } from '../components/ca-input-commands/ca-input-commands.component';\n\n// directives\nimport { CapsLockDirective } from '../directives';\nimport { MaxValueDirective } from '../directives';\nimport { RestrictInputDirective } from '../directives';\nimport { PriceFormatDirective } from '../directives';\nimport { CommandVisibleDirective } from '../directives/command-visible.directive';\n\n// class\nimport { EventInputManager } from '../base-classes/ca-input-event-manager';\n\n// mixins\nimport { InputCommandMixin } from '../mixins/input-command.mixin';\nimport { InputHelperMixin } from '../mixins/input-helper.mixin';\nimport { OptionModel } from '../../ca-input-dropdown/models';\n\nclass InputBase {\n    public inputElement!: ElementRef;\n    public _inputConfig!: ICaInput;\n    public isVisibleCommands: boolean = false;\n    public maskApplier!: NgxMaskService;\n    public thousandSeparatorPipe!: ThousandSeparatorPipe;\n    public isFocusInput: boolean = false;\n    public isEditInput: boolean = false;\n    public isDropdownToggler: boolean = false;\n    public isTouchedInput: boolean = false;\n    public setCommandEvent!: EventInputManager<CommandsEvent>;\n\n    public handleToggleDropdownOptions!: EventEmitter<void>;\n\n    public onTouched = () => { };\n    public onChange(_: any): void { }\n    public handleChangeInputAndUpdateControl(_: InputChangeValue): void { }\n}\n\n@Component({\n    selector: 'ca-input-test',\n    standalone: true,\n    imports: [\n        // Modules\n        CommonModule,\n        NgbModule,\n        AngularSvgIconModule,\n        NgxMaskModule,\n\n        // Pipes\n        InputErrorPipe,\n        InputContainerClassPipe,\n        InputClassPipe,\n        InputPlaceholderTextClassPipe,\n        ShowPlaceholderTextPipe,\n        LabelClassPipe,\n        CaSvgPipe,\n        LoadStatusColorPipe,\n        InputPlaceholderIconRightClassPipe,\n        MaxValueDirective,\n        InputTypePipe,\n        ShowValidCheckPipe,\n        ShowDropdownArrowPipe,\n        InputDropdownArrowClassPipe,\n\n        // Directives\n        RestrictInputDirective,\n        PriceFormatDirective,\n        ShowClearPipe,\n        CapsLockDirective,\n        CommandVisibleDirective,\n\n        // Components\n        CaInputClearComponent,\n        CaAppTooltipV2Component,\n        CaInputPlaceholderIconComponent,\n        CaInputPasswordComponent,\n        CaInputCommandsComponent,\n    ],\n    templateUrl: './input-test.component.html',\n    styleUrl: './input-test.component.scss',\n    encapsulation: ViewEncapsulation.None,\n})\nexport class InputTestComponent\n    extends InputCommandMixin(InputHelperMixin(InputBase))\n    implements ControlValueAccessor, AfterViewInit {\n    public inputValue: InputChangeValue = '';\n    public override _inputConfig!: ICaInput;\n\n    public inputSvgRoutes = InputSvgRoutes;\n\n    @ViewChild('input', { static: true }) override inputElement!: ElementRef;\n    @Input() selectedDropdownLabelColor!: LabelColor | null;\n    @Input() template!: string;\n    @Input() incorrectValue!: boolean;\n    @Input() set inputConfig(config: ICaInput) {\n        this._inputConfig = config;\n    }\n\n    @Input() activeItem!: OptionModel | null;\n\n    @Output('handleToggleDropdownOptions')\n    override handleToggleDropdownOptions: EventEmitter<void> =\n        new EventEmitter<void>();\n\n    @Output('incorrectEvent') incorrectInput: EventEmitter<boolean> =\n        new EventEmitter<boolean>();\n\n    @Output('blurInput') blurInput: EventEmitter<boolean> =\n        new EventEmitter<boolean>();\n    @Output('focusInput') focusInputEvent: EventEmitter<FocusEvent> =\n        new EventEmitter<FocusEvent>();\n    @Output('change') changeInput: EventEmitter<InputChangeValue> =\n        new EventEmitter<InputChangeValue>();\n    @Output('commandEvent') commandEvent: EventEmitter<CommandsEvent> =\n        new EventEmitter<CommandsEvent>();\n    @Output('clear') clearInputEvent: EventEmitter<boolean> =\n        new EventEmitter<boolean>();\n\n    // Dropdown\n    @Output('showHideDropdown') showHideDropdownEvent: EventEmitter<boolean> =\n        new EventEmitter<boolean>();\n    @Output('dropDownKeyNavigation') dropDownKeyNavigationEvent: EventEmitter<{\n        keyCode: number;\n        data: ICaInput | null;\n    }> = new EventEmitter<{\n        keyCode: number;\n        data: ICaInput | null;\n    }>();\n\n    // events\n    public override setCommandEvent = new EventInputManager<CommandsEvent>(\n        null,\n        this.commandEvent\n    );\n\n    public isCapsLockOn = false;\n\n    public inputCommandsType = InputCommandsType;\n    public inputStringEnum = InputStringEnum;\n    public dropdownTemplateTypeEnum = DropdownTemplateTypeEnum;\n\n    // Password\n    public isTogglePassword: boolean = false;\n\n    public get inputConfig() {\n        return this._inputConfig;\n    }\n\n    constructor(\n        @Optional() @Self() public ngControl: NgControl,\n        public chdet: ChangeDetectorRef,\n        public override maskApplier: NgxMaskService,\n        public override thousandSeparatorPipe: ThousandSeparatorPipe\n    ) {\n        super();\n        if (this.ngControl) {\n            this.ngControl.valueAccessor = this;\n        }\n    }\n\n    ngAfterViewInit(): void {\n        Promise.resolve().then(() => {\n            this.handleChangeInputAndUpdateControl(this.inputValue);\n\n            if (this._inputConfig.autoFocus)\n                this.inputElement.nativeElement.focus();\n        });\n    }\n\n    get control() {\n        return this.ngControl?.control;\n    }\n\n    public registerOnChange(fn: any): void {\n        this.onChange = fn;\n    }\n\n    registerOnTouched(fn: () => void): void {\n        this.onTouched = fn;\n    }\n\n    public writeValue(obj: InputChangeValue): void {\n        const value = this.transformValue(this._inputConfig, obj); // ✅ Apply mask\n\n        this.inputValue = value;\n        this.onChange(value); // Notify Angular form about the change\n        if (value && this._inputConfig.updateAsTouchedOnEdit) this.onTouched(); // Mark as touched\n\n        if (!this._inputConfig.isDropdown)\n            this.inputElement.nativeElement.value = value;\n\n        this.chdet.detectChanges();\n    }\n\n    handleInput(event: Event): void {\n        const value = (event.target as HTMLInputElement).value;\n        this.onChange(value); // Notify Angular form about the change\n        if (value) this.onTouched(); // Mark as touched\n\n        if (this.inputValue === value) {\n            this.control?.markAsUntouched();\n        }\n    }\n\n    public clearInput(event: Event): void {\n        event.preventDefault();\n        event.stopPropagation();\n        this.handleChangeInputAndUpdateControl('');\n        this.clearInputEvent.emit(true);\n    }\n\n    public override handleChangeInputAndUpdateControl(value: InputChangeValue) {\n        this.onChange(value);\n\n        if (!this._inputConfig.isDropdown) {\n            this.inputElement.nativeElement.value = value;\n            // Trigger all inputs directives that listen for input Event\n            const event = new Event('input', { bubbles: true });\n            this.inputElement.nativeElement.dispatchEvent(event);\n        }\n    }\n\n    public handleInputFocus(event: FocusEvent) {\n        this.focusInputEvent.emit(event);\n        this.isFocusInput = true;\n    }\n\n    public handleInputBlur(event: FocusEvent) {\n        this.blurInput.emit(true);\n        this.isFocusInput = false;\n    }\n\n    public onPopoverShown(): void {\n        if (!this._inputConfig.dropdownLabel) {\n            this.isFocusInput = true;\n        }\n    }\n\n    public onPopoverHidden(): void {\n        if (!this._inputConfig.dropdownLabel) {\n            this.isFocusInput = false;\n        }\n    }\n\n    public onTogglePassword(event: Event): void {\n        event.preventDefault();\n        this.isTogglePassword = !this.isTogglePassword;\n    }\n\n    public handleCapsLock(status: boolean) {\n        this.isCapsLockOn = status;\n    }\n\n    public handleCommandVisible(status: boolean) {\n        this.isVisibleCommands = status;\n    }\n\n    public identify(index: number): number {\n        return index;\n    }\n\n    public handleKeyDown(event: KeyboardEvent) {\n        this.dropDownKeyNavigationEvent.emit({\n            keyCode: event.keyCode,\n            data: this.inputConfig,\n        });\n    }\n}\n","<div\n    class=\"input-custom-group {{ _inputConfig.customClass }}\"\n    [ngClass]=\"\n        control\n            | inputContainerClass\n                : isFocusInput\n                : control?.touched!\n                : _inputConfig\n                : control?.value\n    \"\n    ngbTooltip\n    [mainCaTooltip]=\"control?.errors | inputError: _inputConfig.name\"\n    [tooltipBackground]=\"'#DF3C3C'\"\n    [disableTooltip]=\"!_inputConfig.requiredLabel || !!control?.valid\"\n    position=\"bottom\"\n    triggers=\"hover\"\n>\n    <!-- Input Commands -->\n    @if (_inputConfig.commands?.active && isVisibleCommands) {\n        <app-ca-input-commands\n            [inputConfig]=\"_inputConfig\"\n            [isFocusInput]=\"isFocusInput\"\n            [isVisibleCommands]=\"isVisibleCommands\"\n            (onCommandsClick)=\"onCommands($event)\"\n        >\n        </app-ca-input-commands>\n    }\n    <!-- Input Valid Check -->\n    @if (\n        control | showValidCheck: isFocusInput : _inputConfig : control?.value\n    ) {\n        <svg-icon\n            class=\"input-required-check {{ _inputConfig.customClass }}\"\n            [src]=\"inputSvgRoutes.confirmSvg\"\n        ></svg-icon>\n    }\n    <!-- Input Password Caps Lock And Eye -->\n    @if (_inputConfig.type === 'password') {\n        <app-ca-input-password\n            [inputConfig]=\"_inputConfig\"\n            [getSuperControl]=\"control\"\n            [isFocusInput]=\"isFocusInput\"\n            [isTouchedInput]=\"isTouchedInput\"\n            [isCapsLockOn]=\"isCapsLockOn\"\n            [isTogglePassword]=\"isTogglePassword\"\n            (onTogglePasswordClick)=\"onTogglePassword($event)\"\n        >\n        </app-ca-input-password>\n    }\n    <!-- Input Clear -->\n    @if (_inputConfig | showClear) {\n        <app-ca-input-clear\n            [inputConfig]=\"_inputConfig\"\n            [getSuperControl]=\"control\"\n            [isFocusInput]=\"isFocusInput\"\n            [incorrectValue]=\"incorrectValue\"\n            [selectedDropdownLabelColor]=\"selectedDropdownLabelColor\"\n            [template]=\"template\"\n            (clearInputClick)=\"clearInput($event)\"\n        >\n        </app-ca-input-clear>\n    }\n\n    <!-- Input Dropdown Arrow -->\n    @if (_inputConfig | showDropdownArrow) {\n        <svg-icon\n            class=\"input-dropdown-arrow {{ _inputConfig.customClass }}\"\n            [ngClass]=\"\n                control\n                    | inputDropdownArrowClass\n                        : isFocusInput\n                        : _inputConfig\n                        : isTouchedInput\n                        : control?.value\n            \"\n            [src]=\"inputSvgRoutes.inputDropdownArrowSvg\"\n            (click)=\"toggleDropdownOptions()\"\n        ></svg-icon>\n    }\n\n    <!-- Input Placeholder Icon -->\n    @if (_inputConfig.placeholderIcon) {\n        <app-ca-input-placeholder-icon\n            [inputConfig]=\"_inputConfig\"\n            [getSuperControl]=\"control\"\n            [isFocusInput]=\"isFocusInput\"\n            [isTouchedInput]=\"control?.touched!\"\n            [selectedDropdownLabelColor]=\"selectedDropdownLabelColor\"\n            [isEditInput]=\"isEditInput\"\n            (onPlaceholderIconEventEmitter)=\"onPlaceholderIconEvent($event)\"\n            (onPopoverShownEmitter)=\"onPopoverShown()\"\n            (onPopoverHiddenEmitter)=\"onPopoverHidden()\"\n        >\n        </app-ca-input-placeholder-icon>\n    }\n\n    <!-- Input Placeholder Text -->\n    @if (\n        _inputConfig\n            | showPlaceholderText: control : isVisibleCommands : control?.value\n    ) {\n        <span\n            class=\"ca-placeholder-text {{ _inputConfig.customClass }}\"\n            [ngClass]=\"\n                isFocusInput\n                    | inputPlaceholderTextClass\n                        : control?.touched!\n                        : control\n                        : _inputConfig\n                        : isVisibleCommands\n                        : control?.value\n            \"\n            [style.left]=\"\n                _inputConfig.placeholderText?.toLowerCase() ===\n                    inputStringEnum.PERSONS ||\n                _inputConfig.placeholderText?.toLowerCase() ===\n                    inputStringEnum.VEHICLES\n                    ? 30 + (control?.value?.toString()?.length + 1) * 9 + 'px'\n                    : isFocusInput &&\n                        _inputConfig.placeholderText?.toLowerCase() !==\n                            inputCommandsType.MONTHS\n                      ? 'auto'\n                      : (control?.value?.toString()?.length + 1) * 8 + 'px'\n            \"\n            [style.right]=\"\n                isFocusInput &&\n                _inputConfig.placeholderText?.toLowerCase() !==\n                    inputCommandsType.MONTHS\n                    ? '28px'\n                    : 'auto'\n            \"\n        >\n            {{ _inputConfig.placeholderText }}\n        </span>\n    }\n\n    <!-- Input Label Counter -->\n    @if (\n        selectedDropdownLabelColor &&\n        control?.value &&\n        !isFocusInput &&\n        !_inputConfig.isDisabled &&\n        _inputConfig.showCount\n    ) {\n        <p\n            [style.top]=\"'4px'\"\n            [style.left]=\"(control?.value?.toString()?.length + 6.5) * 8 + 'px'\"\n            class=\"input-label-counter\"\n        >\n            {{ selectedDropdownLabelColor.count }}\n        </p>\n    }\n\n    <!-- Special Dropdown Selected SVG with or Without Text -->\n    @if (\n        _inputConfig?.dropdownImageInput?.iconsPath &&\n        activeItem &&\n        !_inputConfig?.hideAllItemsInInputDropdown &&\n        !(!_inputConfig.dropdownImageInput?.withText && isFocusInput) &&\n        !(\n            ['truck', 'trailer'].includes(\n                _inputConfig.dropdownImageInput?.template!\n            ) &&\n            isFocusInput &&\n            _inputConfig.dropdownImageInput?.remove\n        ) &&\n        !_inputConfig?.dropdownImageInput?.nameInitialsInsteadUrl\n    ) {\n        <svg-icon\n            [src]=\"_inputConfig.dropdownImageInput?.iconsPath!\"\n            class=\"dropdown-selected-image {{\n                _inputConfig.dropdownImageInput?.class\n            }}\"\n            [ngClass]=\"{\n                'unset-color':\n                    isFocusInput && _inputConfig.dropdownImageInput?.class,\n            }\"\n            [svgStyle]=\"{\n                fill:\n                    _inputConfig.dropdownImageInput?.color && !isFocusInput\n                        ? _inputConfig.dropdownImageInput?.color\n                        : '#ffffff',\n            }\"\n        >\n        </svg-icon>\n    }\n\n    <!-- Input Label -->\n    @if (!_inputConfig.multiSelectDropdownActive) {\n        <label\n            [for]=\"_inputConfig.name\"\n            class=\"input-label {{ _inputConfig.customClass }} {{\n                _inputConfig.multipleLabel?.customClass\n            }}\"\n            [ngClass]=\"\n                control?.value\n                    | labelClass\n                        : isFocusInput\n                        : _inputConfig\n                        : isTouchedInput\n                        : control?.invalid\n                        : control?.touched\n            \"\n        >\n            @if (_inputConfig.label) {\n                <span>{{ _inputConfig.label }} </span>\n            }\n\n            @if (_inputConfig.multipleLabel?.labels?.length) {\n                <div\n                    [class]=\"_inputConfig.multipleLabel?.customClass!\"\n                    [ngClass]=\"{\n                        'multiple-labels-position-on-focus':\n                            isFocusInput ||\n                            _inputConfig.multipleInputValues?.options?.length,\n                        required:\n                            _inputConfig.isRequired && !_inputConfig.isDisabled,\n                    }\"\n                >\n                    @for (\n                        label of _inputConfig.multipleLabel?.labels;\n                        track $index\n                    ) {\n                        <span>\n                            {{ label }}\n                        </span>\n                    }\n                </div>\n            }\n        </label>\n    }\n\n    <input\n        #input\n        (input)=\"handleInput($event)\"\n        [restrictInput]=\"inputConfig\"\n        priceFormat\n        [priceSeparator]=\"\n            inputConfig.priceSeparator || inputConfig.thousandSeparator\n        \"\n        (focus)=\"handleInputFocus($event)\"\n        (blur)=\"handleInputBlur($event)\"\n        (keydown)=\"handleKeyDown($event)\"\n        [readOnly]=\"_inputConfig.readOnly\"\n        [type]=\"_inputConfig.type | inputType: isTogglePassword\"\n        class=\"input-control\n            {{ _inputConfig.textTransform }}\n            {{ _inputConfig.textAlign }}\n            {{ _inputConfig.customClass }}\n        \"\n        [appMaxValue]=\"inputConfig.max\"\n        appCapsLock\n        (capsLockStatus)=\"handleCapsLock($event)\"\n        commandVisible\n        (commandVisible)=\"handleCommandVisible($event)\"\n        [placeholder]=\"\n            (_inputConfig.placeholderInsteadOfLabel &&\n            _inputConfig.placeholder &&\n            isFocusInput\n                ? _inputConfig.placeholder\n                : '') ||\n            (_inputConfig.placeholder && isFocusInput\n                ? _inputConfig.placeholder\n                : '')\n        \"\n        [mask]=\"_inputConfig.mask\"\n        [ngClass]=\"\n            control\n                | inputClass\n                    : isFocusInput\n                    : control?.touched!\n                    : _inputConfig\n                    : input\n                    : isVisibleCommands\n                    : control?.value\n                    : control?.invalid\n                    : control?.touched\n                    : isDropdownToggler\n                    : isEditInput\n                    : template\n        \"\n    />\n\n    <!-- Placeholder Icon on Right Side -->\n    @if (_inputConfig.placeholderIconRightSide) {\n        <svg-icon\n            class=\"placeholder-icon-right-side {{\n                _inputConfig.placeholderIconColor\n            }}\"\n            [ngClass]=\"\n                isFocusInput\n                    | inputPlaceholderIconRightClass\n                        : control\n                        : _inputConfig\n                        : isTouchedInput\n                        : control?.value\n            \"\n            [src]=\"\n                _inputConfig.placeholderIconRightSide.toLowerCase()\n                    | caSvg: 'common'\n            \"\n        ></svg-icon>\n    }\n\n    <!-- Input Error Message -->\n    @if (\n        !(!control?.value && isFocusInput) &&\n        (isTouchedInput || control?.touched || control?.value) &&\n        control?.invalid &&\n        !_inputConfig.isInvalidSearchInDropdown &&\n        !_inputConfig.isDisabled\n    ) {\n        @if (\n            !(_inputConfig.hideErrorMessage || _inputConfig.errorInsideInput)\n        ) {\n            <span class=\"input-error {{ _inputConfig.customClass }}\">\n                {{ control?.errors | inputError: _inputConfig.name }}\n            </span>\n        }\n\n        <!-- Error Message Inside Input -->\n        @if (_inputConfig.errorInsideInput) {\n            <span class=\"error-inside-input {{ _inputConfig.customClass }}\">\n                {{ control?.errors | inputError: _inputConfig.name }}\n            </span>\n        }\n    }\n\n    @if (_inputConfig.fixedPlacholder && input.value) {\n        <span class=\"input-fixed-placehoder-label\">\n            {{ _inputConfig.fixedPlacholder }}\n        </span>\n    }\n</div>\n"]}
@@ -6,9 +6,6 @@ export function InputCommandMixin(Base) {
6
6
  const { event, type, action } = e;
7
7
  event.stopPropagation();
8
8
  event.preventDefault();
9
- setTimeout(() => {
10
- this.inputElement.nativeElement.focus();
11
- }, 0);
12
9
  switch (type) {
13
10
  case InputCommandsType.PM_INCREMENT_DECREMENT:
14
11
  this.handlePmIncrementDecrement(action);
@@ -127,4 +124,4 @@ export function InputCommandMixin(Base) {
127
124
  }
128
125
  };
129
126
  }
130
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-command.mixin.js","sourceRoot":"","sources":["../../../../../../../projects/ca-components/src/lib/components/ca-input/mixins/input-command.mixin.ts"],"names":[],"mappings":"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","sourcesContent":["import { Constructor } from '../../../models/mixin.model';\nimport { InputCommandsAction, InputCommandsType } from '../enums';\nimport { InputBase } from '../models/base.model';\n\nexport function InputCommandMixin<\n    T extends Constructor<InputBase>,\n>(Base: T) {\n    return class extends Base {\n        // #region OnCommands\n        public onCommands(e: any): void {\n            const { event, type, action } = e;\n            event.stopPropagation();\n            event.preventDefault();\n\n            setTimeout(() => {\n                this.inputElement.nativeElement.focus();\n            }, 0);\n\n            switch (type) {\n                case InputCommandsType.PM_INCREMENT_DECREMENT:\n                    this.handlePmIncrementDecrement(action);\n                    break;\n                case InputCommandsType.CONFIRM_CANCEL:\n                    this.handleConfirmCancel(action);\n                    break;\n                case InputCommandsType.MONTHS:\n                    this.handleMonths(action);\n                    break;\n                default:\n                    break;\n            }\n        }\n\n        // #region\n\n        public handleMonths(action: string): void {\n            //clearTimeout(this.inputCommandsTimeout);\n\n            switch (action) {\n                case InputCommandsAction.MINUS:\n                    this.handleChangeInputAndUpdateControl(\n                        (this.inputElement.nativeElement.value\n                            ? +this.inputElement.nativeElement.value\n                            : 0) - 1\n                    );\n                    break;\n                case InputCommandsAction.PLUS:\n                    this.handleChangeInputAndUpdateControl(\n                        (this.inputElement.nativeElement.value\n                            ? +this.inputElement.nativeElement.value\n                            : 0) + 1\n                    );\n                    break;\n                default:\n                    break;\n            }\n        }\n        // #endregion\n\n        public handleConfirmCancel(action: string): void {\n            switch (action) {\n                case InputCommandsAction.CONFIRM:\n                    this.confirmCommand();\n                    break;\n                case InputCommandsAction.CANCEL:\n                    this.cancelCommand();\n                    break;\n                default:\n                    break;\n            }\n\n            // this.superControl.control?.setErrors(null);\n            // this._inputConfig.dropdownLabelNew = false;\n            // this._inputConfig.commands!.active = false;\n            // this._inputConfig.blackInput = false;\n            // this.isEditInput = false;\n            // this.isVisibleCommands = false\n            // this.isFocusInput = false;\n        }\n\n        public cancelCommand(): void {\n            //this.setCommandEvent.next({ action: InputCommandsAction.CANCEL });\n        }\n\n        public confirmCommand(): void {\n            // this.setCommandEvent.next({\n            //     data: this.superControl.control?.value,\n            //     action: InputCommandsAction.CONFIRM,\n            //     mode:\n            //         !this._inputConfig.dropdownLabelNew &&\n            //         this._inputConfig.name !== 'Input Dropdown Bank Name'\n            //             ? 'edit'\n            //             : 'new',\n            // });\n        }\n\n        // #region HandlePmIncrementDecrement\n        public handlePmIncrementDecrement(action: string): void {\n            const numericValue = this.inputElement.nativeElement.value;\n\n            // Remove thousands separators (`,`) before parsing\n            let value = parseFloat(numericValue.replace(/,/g, ''));\n\n            switch (action) {\n                case InputCommandsAction.DECREMENT:\n                case InputCommandsAction.INCREMENT:\n                    const incdecValue = this.decrementIncrementDecrementPmValue(\n                        value,\n                        action\n                    );\n                    this.handleChangeInputAndUpdateControl(\n                        action === InputCommandsAction.INCREMENT\n                            ? value + incdecValue\n                            : value - incdecValue\n                    );\n                    break;\n                case InputCommandsAction.RESET:\n                    this.resetPmValue();\n                    break;\n                default:\n                    break;\n            }\n        }\n\n        // #region DecrementPmValue\n        public decrementIncrementDecrementPmValue(\n            value: number,\n            action: InputCommandsAction\n        ): number {\n            if (value >= 10000 && value < 20000) {\n                return 1000;\n            } else if (value >= 20000 && value < 50000) {\n                return 5000;\n            } else if (value >= 50000 && value < 100000) {\n                return 10000;\n            } else if (\n                value >= 500000 &&\n                action === InputCommandsAction.INCREMENT\n            ) {\n                return 0;\n            } else if (value >= 100000) {\n                return 20000;\n            } else if (\n                value <= 5000 &&\n                action === InputCommandsAction.DECREMENT\n            ) {\n                return 0;\n            }\n\n            return 500;\n        }\n        // #endregion\n\n        // #region ResetPmValue\n        public resetPmValue(): void {\n            if (this._inputConfig?.defaultValue)\n                this.handleChangeInputAndUpdateControl(\n                    this._inputConfig?.defaultValue!\n                );\n        }\n\n        // #endregion\n    };\n}"]}
127
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-command.mixin.js","sourceRoot":"","sources":["../../../../../../../projects/ca-components/src/lib/components/ca-input/mixins/input-command.mixin.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,mBAAmB,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AAGlE,MAAM,UAAU,iBAAiB,CAAmC,IAAO;IACvE,OAAO,KAAM,SAAQ,IAAI;QACrB,qBAAqB;QACd,UAAU,CAAC,CAAM;YACpB,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,CAAC,CAAC;YAClC,KAAK,CAAC,eAAe,EAAE,CAAC;YACxB,KAAK,CAAC,cAAc,EAAE,CAAC;YAEvB,QAAQ,IAAI,EAAE,CAAC;gBACX,KAAK,iBAAiB,CAAC,sBAAsB;oBACzC,IAAI,CAAC,0BAA0B,CAAC,MAAM,CAAC,CAAC;oBACxC,MAAM;gBACV,KAAK,iBAAiB,CAAC,cAAc;oBACjC,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC;oBACjC,MAAM;gBACV,KAAK,iBAAiB,CAAC,MAAM;oBACzB,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;oBAC1B,MAAM;gBACV;oBACI,MAAM;YACd,CAAC;QACL,CAAC;QAED,UAAU;QAEH,YAAY,CAAC,MAAc;YAC9B,0CAA0C;YAE1C,QAAQ,MAAM,EAAE,CAAC;gBACb,KAAK,mBAAmB,CAAC,KAAK;oBAC1B,IAAI,CAAC,iCAAiC,CAClC,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,KAAK;wBAClC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,KAAK;wBACxC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CACf,CAAC;oBACF,MAAM;gBACV,KAAK,mBAAmB,CAAC,IAAI;oBACzB,IAAI,CAAC,iCAAiC,CAClC,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,KAAK;wBAClC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,KAAK;wBACxC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CACf,CAAC;oBACF,MAAM;gBACV;oBACI,MAAM;YACd,CAAC;QACL,CAAC;QACD,aAAa;QAEN,mBAAmB,CAAC,MAAc;YACrC,QAAQ,MAAM,EAAE,CAAC;gBACb,KAAK,mBAAmB,CAAC,OAAO;oBAC5B,IAAI,CAAC,cAAc,EAAE,CAAC;oBACtB,MAAM;gBACV,KAAK,mBAAmB,CAAC,MAAM;oBAC3B,IAAI,CAAC,aAAa,EAAE,CAAC;oBACrB,MAAM;gBACV;oBACI,MAAM;YACd,CAAC;YAED,8CAA8C;YAC9C,8CAA8C;YAC9C,8CAA8C;YAC9C,wCAAwC;YACxC,4BAA4B;YAC5B,iCAAiC;YACjC,6BAA6B;QACjC,CAAC;QAEM,aAAa;YAChB,oEAAoE;QACxE,CAAC;QAEM,cAAc;YACjB,8BAA8B;YAC9B,8CAA8C;YAC9C,2CAA2C;YAC3C,YAAY;YACZ,iDAAiD;YACjD,gEAAgE;YAChE,uBAAuB;YACvB,uBAAuB;YACvB,MAAM;QACV,CAAC;QAED,qCAAqC;QAC9B,0BAA0B,CAAC,MAAc;YAC5C,MAAM,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,KAAK,CAAC;YAE3D,mDAAmD;YACnD,IAAI,KAAK,GAAG,UAAU,CAAC,YAAY,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC;YAEvD,QAAQ,MAAM,EAAE,CAAC;gBACb,KAAK,mBAAmB,CAAC,SAAS,CAAC;gBACnC,KAAK,mBAAmB,CAAC,SAAS;oBAC9B,MAAM,WAAW,GAAG,IAAI,CAAC,kCAAkC,CACvD,KAAK,EACL,MAAM,CACT,CAAC;oBACF,IAAI,CAAC,iCAAiC,CAClC,MAAM,KAAK,mBAAmB,CAAC,SAAS;wBACpC,CAAC,CAAC,KAAK,GAAG,WAAW;wBACrB,CAAC,CAAC,KAAK,GAAG,WAAW,CAC5B,CAAC;oBACF,MAAM;gBACV,KAAK,mBAAmB,CAAC,KAAK;oBAC1B,IAAI,CAAC,YAAY,EAAE,CAAC;oBACpB,MAAM;gBACV;oBACI,MAAM;YACd,CAAC;QACL,CAAC;QAED,2BAA2B;QACpB,kCAAkC,CACrC,KAAa,EACb,MAA2B;YAE3B,IAAI,KAAK,IAAI,KAAK,IAAI,KAAK,GAAG,KAAK,EAAE,CAAC;gBAClC,OAAO,IAAI,CAAC;YAChB,CAAC;iBAAM,IAAI,KAAK,IAAI,KAAK,IAAI,KAAK,GAAG,KAAK,EAAE,CAAC;gBACzC,OAAO,IAAI,CAAC;YAChB,CAAC;iBAAM,IAAI,KAAK,IAAI,KAAK,IAAI,KAAK,GAAG,MAAM,EAAE,CAAC;gBAC1C,OAAO,KAAK,CAAC;YACjB,CAAC;iBAAM,IACH,KAAK,IAAI,MAAM;gBACf,MAAM,KAAK,mBAAmB,CAAC,SAAS,EAC1C,CAAC;gBACC,OAAO,CAAC,CAAC;YACb,CAAC;iBAAM,IAAI,KAAK,IAAI,MAAM,EAAE,CAAC;gBACzB,OAAO,KAAK,CAAC;YACjB,CAAC;iBAAM,IACH,KAAK,IAAI,IAAI;gBACb,MAAM,KAAK,mBAAmB,CAAC,SAAS,EAC1C,CAAC;gBACC,OAAO,CAAC,CAAC;YACb,CAAC;YAED,OAAO,GAAG,CAAC;QACf,CAAC;QACD,aAAa;QAEb,uBAAuB;QAChB,YAAY;YACf,IAAI,IAAI,CAAC,YAAY,EAAE,YAAY;gBAC/B,IAAI,CAAC,iCAAiC,CAClC,IAAI,CAAC,YAAY,EAAE,YAAa,CACnC,CAAC;QACV,CAAC;KAGJ,CAAC;AACN,CAAC","sourcesContent":["import { Constructor } from '../../../models/mixin.model';\nimport { InputCommandsAction, InputCommandsType } from '../enums';\nimport { InputBase } from '../models/base.model';\n\nexport function InputCommandMixin<T extends Constructor<InputBase>>(Base: T) {\n    return class extends Base {\n        // #region OnCommands\n        public onCommands(e: any): void {\n            const { event, type, action } = e;\n            event.stopPropagation();\n            event.preventDefault();\n\n            switch (type) {\n                case InputCommandsType.PM_INCREMENT_DECREMENT:\n                    this.handlePmIncrementDecrement(action);\n                    break;\n                case InputCommandsType.CONFIRM_CANCEL:\n                    this.handleConfirmCancel(action);\n                    break;\n                case InputCommandsType.MONTHS:\n                    this.handleMonths(action);\n                    break;\n                default:\n                    break;\n            }\n        }\n\n        // #region\n\n        public handleMonths(action: string): void {\n            //clearTimeout(this.inputCommandsTimeout);\n\n            switch (action) {\n                case InputCommandsAction.MINUS:\n                    this.handleChangeInputAndUpdateControl(\n                        (this.inputElement.nativeElement.value\n                            ? +this.inputElement.nativeElement.value\n                            : 0) - 1\n                    );\n                    break;\n                case InputCommandsAction.PLUS:\n                    this.handleChangeInputAndUpdateControl(\n                        (this.inputElement.nativeElement.value\n                            ? +this.inputElement.nativeElement.value\n                            : 0) + 1\n                    );\n                    break;\n                default:\n                    break;\n            }\n        }\n        // #endregion\n\n        public handleConfirmCancel(action: string): void {\n            switch (action) {\n                case InputCommandsAction.CONFIRM:\n                    this.confirmCommand();\n                    break;\n                case InputCommandsAction.CANCEL:\n                    this.cancelCommand();\n                    break;\n                default:\n                    break;\n            }\n\n            // this.superControl.control?.setErrors(null);\n            // this._inputConfig.dropdownLabelNew = false;\n            // this._inputConfig.commands!.active = false;\n            // this._inputConfig.blackInput = false;\n            // this.isEditInput = false;\n            // this.isVisibleCommands = false\n            // this.isFocusInput = false;\n        }\n\n        public cancelCommand(): void {\n            //this.setCommandEvent.next({ action: InputCommandsAction.CANCEL });\n        }\n\n        public confirmCommand(): void {\n            // this.setCommandEvent.next({\n            //     data: this.superControl.control?.value,\n            //     action: InputCommandsAction.CONFIRM,\n            //     mode:\n            //         !this._inputConfig.dropdownLabelNew &&\n            //         this._inputConfig.name !== 'Input Dropdown Bank Name'\n            //             ? 'edit'\n            //             : 'new',\n            // });\n        }\n\n        // #region HandlePmIncrementDecrement\n        public handlePmIncrementDecrement(action: string): void {\n            const numericValue = this.inputElement.nativeElement.value;\n\n            // Remove thousands separators (`,`) before parsing\n            let value = parseFloat(numericValue.replace(/,/g, ''));\n\n            switch (action) {\n                case InputCommandsAction.DECREMENT:\n                case InputCommandsAction.INCREMENT:\n                    const incdecValue = this.decrementIncrementDecrementPmValue(\n                        value,\n                        action\n                    );\n                    this.handleChangeInputAndUpdateControl(\n                        action === InputCommandsAction.INCREMENT\n                            ? value + incdecValue\n                            : value - incdecValue\n                    );\n                    break;\n                case InputCommandsAction.RESET:\n                    this.resetPmValue();\n                    break;\n                default:\n                    break;\n            }\n        }\n\n        // #region DecrementPmValue\n        public decrementIncrementDecrementPmValue(\n            value: number,\n            action: InputCommandsAction\n        ): number {\n            if (value >= 10000 && value < 20000) {\n                return 1000;\n            } else if (value >= 20000 && value < 50000) {\n                return 5000;\n            } else if (value >= 50000 && value < 100000) {\n                return 10000;\n            } else if (\n                value >= 500000 &&\n                action === InputCommandsAction.INCREMENT\n            ) {\n                return 0;\n            } else if (value >= 100000) {\n                return 20000;\n            } else if (\n                value <= 5000 &&\n                action === InputCommandsAction.DECREMENT\n            ) {\n                return 0;\n            }\n\n            return 500;\n        }\n        // #endregion\n\n        // #region ResetPmValue\n        public resetPmValue(): void {\n            if (this._inputConfig?.defaultValue)\n                this.handleChangeInputAndUpdateControl(\n                    this._inputConfig?.defaultValue!\n                );\n        }\n\n        // #endregion\n    };\n}\n"]}
@@ -10,10 +10,8 @@ export function RestrictionPipeMixin(Base) {
10
10
  const min = this.restrictInput.minValue ?? -Infinity;
11
11
  const max = this.restrictInput.maxValue ?? Infinity;
12
12
  // ✅ Ensure the value is a valid number
13
- if (!/^\d+$/.test(value)) {
14
- return false;
15
- }
16
- const numericValue = Number(value);
13
+ const tempValue = value.replace(/[^0-9]/g, '');
14
+ const numericValue = Number(tempValue);
17
15
  // ✅ Check if value is within the valid range
18
16
  return numericValue >= min && numericValue <= max;
19
17
  }
@@ -28,9 +26,9 @@ export function RestrictionPipeMixin(Base) {
28
26
  const capitalizedCaseWords = value.replace(/(^\w{1})|(\s+\w{1})/g, (letter) => letter.toUpperCase());
29
27
  return capitalizedCaseWords;
30
28
  default:
31
- return;
29
+ return value;
32
30
  }
33
31
  }
34
32
  };
35
33
  }
36
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzdHJpY3Rpb24tcGlwZS5taXhpbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NhLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2NhLWlucHV0L21peGlucy9yZXN0cmljdGlvbi1waXBlLm1peGluLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBRTlFLE1BQU0sVUFBVSxvQkFBb0IsQ0FFbEMsSUFBTztJQUNMLE9BQU8sS0FBTSxTQUFRLElBQUk7UUFDZCxlQUFlLENBQUMsS0FBYTtZQUNoQyxJQUNJLENBQUMsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLFFBQVE7Z0JBQ3pCLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxRQUFRLENBQUM7Z0JBQ2pDLENBQUMsS0FBSyxFQUNSLENBQUM7Z0JBQ0MsT0FBTyxJQUFJLENBQUMsQ0FBQyw0QkFBNEI7WUFDN0MsQ0FBQztZQUVELE1BQU0sR0FBRyxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsUUFBUSxJQUFJLENBQUMsUUFBUSxDQUFDO1lBQ3JELE1BQU0sR0FBRyxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsUUFBUSxJQUFJLFFBQVEsQ0FBQztZQUVwRCx1Q0FBdUM7WUFDdkMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQztnQkFDdkIsT0FBTyxLQUFLLENBQUM7WUFDakIsQ0FBQztZQUVELE1BQU0sWUFBWSxHQUFHLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUVuQyw2Q0FBNkM7WUFDN0MsT0FBTyxZQUFZLElBQUksR0FBRyxJQUFJLFlBQVksSUFBSSxHQUFHLENBQUM7UUFDdEQsQ0FBQztRQUVNLHFCQUFxQixDQUN4QixLQUFhLEVBQ2IsYUFBbUQ7WUFFbkQsUUFBUSxhQUFhLEVBQUUsQ0FBQztnQkFDcEIsS0FBSyx3QkFBd0IsQ0FBQyxVQUFVO29CQUNwQyxPQUFPLENBQ0gsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxXQUFXLEVBQUU7d0JBQzdCLEtBQUssQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUMsV0FBVyxFQUFFLENBQ25DLENBQUM7Z0JBQ04sS0FBSyx3QkFBd0IsQ0FBQyxTQUFTO29CQUNuQyxPQUFPLEtBQUssQ0FBQyxpQkFBaUIsQ0FBQyxPQUFPLENBQUMsQ0FBQztnQkFDNUMsS0FBSyx3QkFBd0IsQ0FBQyxnQkFBZ0I7b0JBQzFDLE1BQU0sb0JBQW9CLEdBQUcsS0FBSyxDQUFDLE9BQU8sQ0FDdEMsc0JBQXNCLEVBQ3RCLENBQUMsTUFBYyxFQUFFLEVBQUUsQ0FBQyxNQUFNLENBQUMsV0FBVyxFQUFFLENBQzNDLENBQUM7b0JBQ0YsT0FBTyxvQkFBb0IsQ0FBQztnQkFDaEM7b0JBQ0ksT0FBTztZQUNmLENBQUM7UUFDTCxDQUFDO0tBQ0osQ0FBQztBQUNOLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb25zdHJ1Y3RvciB9IGZyb20gJy4uLy4uLy4uL21vZGVscy9taXhpbi5tb2RlbCc7XG5pbXBvcnQgeyBJQ2FJbnB1dCB9IGZyb20gJy4uL2NvbmZpZy9jYS1pbnB1dC5jb25maWcnO1xuaW1wb3J0IHsgSW5wdXRUcmFuc2Zvcm1TdHJpbmdFbnVtIH0gZnJvbSAnLi4vZW51bXMvaW5wdXQtdGV4dC10cmFuc2Zvcm0uZW51bSc7XG5cbmV4cG9ydCBmdW5jdGlvbiBSZXN0cmljdGlvblBpcGVNaXhpbjxcbiAgICBUIGV4dGVuZHMgQ29uc3RydWN0b3I8eyByZXN0cmljdElucHV0OiBJQ2FJbnB1dCB9Pixcbj4oQmFzZTogVCkge1xuICAgIHJldHVybiBjbGFzcyBleHRlbmRzIEJhc2Uge1xuICAgICAgICBwdWJsaWMgY2hlY2tSYW5nZVJlZ2V4KHZhbHVlOiBzdHJpbmcpOiBib29sZWFuIHtcbiAgICAgICAgICAgIGlmIChcbiAgICAgICAgICAgICAgICAoIXRoaXMucmVzdHJpY3RJbnB1dC5taW5WYWx1ZSAmJlxuICAgICAgICAgICAgICAgICAgICAhdGhpcy5yZXN0cmljdElucHV0Lm1heFZhbHVlKSB8fFxuICAgICAgICAgICAgICAgICF2YWx1ZVxuICAgICAgICAgICAgKSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIHRydWU7IC8vIOKchSBObyBsaW1pdHMsIGFsd2F5cyB2YWxpZFxuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICBjb25zdCBtaW4gPSB0aGlzLnJlc3RyaWN0SW5wdXQubWluVmFsdWUgPz8gLUluZmluaXR5O1xuICAgICAgICAgICAgY29uc3QgbWF4ID0gdGhpcy5yZXN0cmljdElucHV0Lm1heFZhbHVlID8/IEluZmluaXR5O1xuXG4gICAgICAgICAgICAvLyDinIUgRW5zdXJlIHRoZSB2YWx1ZSBpcyBhIHZhbGlkIG51bWJlclxuICAgICAgICAgICAgaWYgKCEvXlxcZCskLy50ZXN0KHZhbHVlKSkge1xuICAgICAgICAgICAgICAgIHJldHVybiBmYWxzZTtcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgY29uc3QgbnVtZXJpY1ZhbHVlID0gTnVtYmVyKHZhbHVlKTtcblxuICAgICAgICAgICAgLy8g4pyFIENoZWNrIGlmIHZhbHVlIGlzIHdpdGhpbiB0aGUgdmFsaWQgcmFuZ2VcbiAgICAgICAgICAgIHJldHVybiBudW1lcmljVmFsdWUgPj0gbWluICYmIG51bWVyaWNWYWx1ZSA8PSBtYXg7XG4gICAgICAgIH1cblxuICAgICAgICBwdWJsaWMgZ2V0VGV4dFRyYW5zZm9ybWF0aW9uKFxuICAgICAgICAgICAgdmFsdWU6IHN0cmluZyxcbiAgICAgICAgICAgIHRleHRUcmFuc2Zvcm06IElucHV0VHJhbnNmb3JtU3RyaW5nRW51bSB8IHVuZGVmaW5lZFxuICAgICAgICApOiBzdHJpbmcgfCB1bmRlZmluZWQge1xuICAgICAgICAgICAgc3dpdGNoICh0ZXh0VHJhbnNmb3JtKSB7XG4gICAgICAgICAgICAgICAgY2FzZSBJbnB1dFRyYW5zZm9ybVN0cmluZ0VudW0uQ0FQSVRBTElaRTpcbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuIChcbiAgICAgICAgICAgICAgICAgICAgICAgIHZhbHVlLmNoYXJBdCgwKS50b1VwcGVyQ2FzZSgpICtcbiAgICAgICAgICAgICAgICAgICAgICAgIHZhbHVlLnN1YnN0cmluZygxKS50b0xvd2VyQ2FzZSgpXG4gICAgICAgICAgICAgICAgICAgICk7XG4gICAgICAgICAgICAgICAgY2FzZSBJbnB1dFRyYW5zZm9ybVN0cmluZ0VudW0uVVBQRVJDQVNFOlxuICAgICAgICAgICAgICAgICAgICByZXR1cm4gdmFsdWUudG9Mb2NhbGVVcHBlckNhc2UoJ2VuLVVTJyk7XG4gICAgICAgICAgICAgICAgY2FzZSBJbnB1dFRyYW5zZm9ybVN0cmluZ0VudW0uQ0FQSVRBTElaRURfQ0FTRTpcbiAgICAgICAgICAgICAgICAgICAgY29uc3QgY2FwaXRhbGl6ZWRDYXNlV29yZHMgPSB2YWx1ZS5yZXBsYWNlKFxuICAgICAgICAgICAgICAgICAgICAgICAgLyheXFx3ezF9KXwoXFxzK1xcd3sxfSkvZyxcbiAgICAgICAgICAgICAgICAgICAgICAgIChsZXR0ZXI6IHN0cmluZykgPT4gbGV0dGVyLnRvVXBwZXJDYXNlKClcbiAgICAgICAgICAgICAgICAgICAgKTtcbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuIGNhcGl0YWxpemVkQ2FzZVdvcmRzO1xuICAgICAgICAgICAgICAgIGRlZmF1bHQ6XG4gICAgICAgICAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgIH07XG59XG4iXX0=
34
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzdHJpY3Rpb24tcGlwZS5taXhpbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NhLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2NhLWlucHV0L21peGlucy9yZXN0cmljdGlvbi1waXBlLm1peGluLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBRTlFLE1BQU0sVUFBVSxvQkFBb0IsQ0FFbEMsSUFBTztJQUNMLE9BQU8sS0FBTSxTQUFRLElBQUk7UUFDZCxlQUFlLENBQUMsS0FBYTtZQUNoQyxJQUNJLENBQUMsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLFFBQVE7Z0JBQ3pCLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxRQUFRLENBQUM7Z0JBQ2pDLENBQUMsS0FBSyxFQUNSLENBQUM7Z0JBQ0MsT0FBTyxJQUFJLENBQUMsQ0FBQyw0QkFBNEI7WUFDN0MsQ0FBQztZQUVELE1BQU0sR0FBRyxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsUUFBUSxJQUFJLENBQUMsUUFBUSxDQUFDO1lBQ3JELE1BQU0sR0FBRyxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsUUFBUSxJQUFJLFFBQVEsQ0FBQztZQUVwRCx1Q0FBdUM7WUFFdkMsTUFBTSxTQUFTLEdBQUcsS0FBSyxDQUFDLE9BQU8sQ0FBQyxTQUFTLEVBQUUsRUFBRSxDQUFDLENBQUM7WUFFL0MsTUFBTSxZQUFZLEdBQUcsTUFBTSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1lBRXZDLDZDQUE2QztZQUM3QyxPQUFPLFlBQVksSUFBSSxHQUFHLElBQUksWUFBWSxJQUFJLEdBQUcsQ0FBQztRQUN0RCxDQUFDO1FBRU0scUJBQXFCLENBQ3hCLEtBQWEsRUFDYixhQUFtRDtZQUVuRCxRQUFRLGFBQWEsRUFBRSxDQUFDO2dCQUNwQixLQUFLLHdCQUF3QixDQUFDLFVBQVU7b0JBQ3BDLE9BQU8sQ0FDSCxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxDQUFDLFdBQVcsRUFBRTt3QkFDN0IsS0FBSyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxXQUFXLEVBQUUsQ0FDbkMsQ0FBQztnQkFDTixLQUFLLHdCQUF3QixDQUFDLFNBQVM7b0JBQ25DLE9BQU8sS0FBSyxDQUFDLGlCQUFpQixDQUFDLE9BQU8sQ0FBQyxDQUFDO2dCQUM1QyxLQUFLLHdCQUF3QixDQUFDLGdCQUFnQjtvQkFDMUMsTUFBTSxvQkFBb0IsR0FBRyxLQUFLLENBQUMsT0FBTyxDQUN0QyxzQkFBc0IsRUFDdEIsQ0FBQyxNQUFjLEVBQUUsRUFBRSxDQUFDLE1BQU0sQ0FBQyxXQUFXLEVBQUUsQ0FDM0MsQ0FBQztvQkFDRixPQUFPLG9CQUFvQixDQUFDO2dCQUNoQztvQkFDSSxPQUFPLEtBQUssQ0FBQztZQUNyQixDQUFDO1FBQ0wsQ0FBQztLQUNKLENBQUM7QUFDTixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29uc3RydWN0b3IgfSBmcm9tICcuLi8uLi8uLi9tb2RlbHMvbWl4aW4ubW9kZWwnO1xuaW1wb3J0IHsgSUNhSW5wdXQgfSBmcm9tICcuLi9jb25maWcvY2EtaW5wdXQuY29uZmlnJztcbmltcG9ydCB7IElucHV0VHJhbnNmb3JtU3RyaW5nRW51bSB9IGZyb20gJy4uL2VudW1zL2lucHV0LXRleHQtdHJhbnNmb3JtLmVudW0nO1xuXG5leHBvcnQgZnVuY3Rpb24gUmVzdHJpY3Rpb25QaXBlTWl4aW48XG4gICAgVCBleHRlbmRzIENvbnN0cnVjdG9yPHsgcmVzdHJpY3RJbnB1dDogSUNhSW5wdXQgfT4sXG4+KEJhc2U6IFQpIHtcbiAgICByZXR1cm4gY2xhc3MgZXh0ZW5kcyBCYXNlIHtcbiAgICAgICAgcHVibGljIGNoZWNrUmFuZ2VSZWdleCh2YWx1ZTogc3RyaW5nKTogYm9vbGVhbiB7XG4gICAgICAgICAgICBpZiAoXG4gICAgICAgICAgICAgICAgKCF0aGlzLnJlc3RyaWN0SW5wdXQubWluVmFsdWUgJiZcbiAgICAgICAgICAgICAgICAgICAgIXRoaXMucmVzdHJpY3RJbnB1dC5tYXhWYWx1ZSkgfHxcbiAgICAgICAgICAgICAgICAhdmFsdWVcbiAgICAgICAgICAgICkge1xuICAgICAgICAgICAgICAgIHJldHVybiB0cnVlOyAvLyDinIUgTm8gbGltaXRzLCBhbHdheXMgdmFsaWRcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgY29uc3QgbWluID0gdGhpcy5yZXN0cmljdElucHV0Lm1pblZhbHVlID8/IC1JbmZpbml0eTtcbiAgICAgICAgICAgIGNvbnN0IG1heCA9IHRoaXMucmVzdHJpY3RJbnB1dC5tYXhWYWx1ZSA/PyBJbmZpbml0eTtcblxuICAgICAgICAgICAgLy8g4pyFIEVuc3VyZSB0aGUgdmFsdWUgaXMgYSB2YWxpZCBudW1iZXJcblxuICAgICAgICAgICAgY29uc3QgdGVtcFZhbHVlID0gdmFsdWUucmVwbGFjZSgvW14wLTldL2csICcnKTtcblxuICAgICAgICAgICAgY29uc3QgbnVtZXJpY1ZhbHVlID0gTnVtYmVyKHRlbXBWYWx1ZSk7XG5cbiAgICAgICAgICAgIC8vIOKchSBDaGVjayBpZiB2YWx1ZSBpcyB3aXRoaW4gdGhlIHZhbGlkIHJhbmdlXG4gICAgICAgICAgICByZXR1cm4gbnVtZXJpY1ZhbHVlID49IG1pbiAmJiBudW1lcmljVmFsdWUgPD0gbWF4O1xuICAgICAgICB9XG5cbiAgICAgICAgcHVibGljIGdldFRleHRUcmFuc2Zvcm1hdGlvbihcbiAgICAgICAgICAgIHZhbHVlOiBzdHJpbmcsXG4gICAgICAgICAgICB0ZXh0VHJhbnNmb3JtOiBJbnB1dFRyYW5zZm9ybVN0cmluZ0VudW0gfCB1bmRlZmluZWRcbiAgICAgICAgKTogc3RyaW5nIHwgdW5kZWZpbmVkIHtcbiAgICAgICAgICAgIHN3aXRjaCAodGV4dFRyYW5zZm9ybSkge1xuICAgICAgICAgICAgICAgIGNhc2UgSW5wdXRUcmFuc2Zvcm1TdHJpbmdFbnVtLkNBUElUQUxJWkU6XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAgICAgICAgICAgICB2YWx1ZS5jaGFyQXQoMCkudG9VcHBlckNhc2UoKSArXG4gICAgICAgICAgICAgICAgICAgICAgICB2YWx1ZS5zdWJzdHJpbmcoMSkudG9Mb3dlckNhc2UoKVxuICAgICAgICAgICAgICAgICAgICApO1xuICAgICAgICAgICAgICAgIGNhc2UgSW5wdXRUcmFuc2Zvcm1TdHJpbmdFbnVtLlVQUEVSQ0FTRTpcbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuIHZhbHVlLnRvTG9jYWxlVXBwZXJDYXNlKCdlbi1VUycpO1xuICAgICAgICAgICAgICAgIGNhc2UgSW5wdXRUcmFuc2Zvcm1TdHJpbmdFbnVtLkNBUElUQUxJWkVEX0NBU0U6XG4gICAgICAgICAgICAgICAgICAgIGNvbnN0IGNhcGl0YWxpemVkQ2FzZVdvcmRzID0gdmFsdWUucmVwbGFjZShcbiAgICAgICAgICAgICAgICAgICAgICAgIC8oXlxcd3sxfSl8KFxccytcXHd7MX0pL2csXG4gICAgICAgICAgICAgICAgICAgICAgICAobGV0dGVyOiBzdHJpbmcpID0+IGxldHRlci50b1VwcGVyQ2FzZSgpXG4gICAgICAgICAgICAgICAgICAgICk7XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiBjYXBpdGFsaXplZENhc2VXb3JkcztcbiAgICAgICAgICAgICAgICBkZWZhdWx0OlxuICAgICAgICAgICAgICAgICAgICByZXR1cm4gdmFsdWU7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICB9O1xufVxuIl19