ngx-histaff-alpha 4.5.6 → 4.5.7

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.
@@ -23,8 +23,10 @@ export class CoreDropdownComponent extends CoreFormControlBaseComponent {
23
23
  this.mls = mls;
24
24
  this.placeholder = 'UI_COMMON_PLACE_HOLDER_SEARCH_HERE';
25
25
  this.fitHeightWithItemCount = true;
26
- this.searchHeight = 38;
26
+ //searchHeight: number = 38;
27
+ this.searchHeight = 0;
27
28
  this.subscriptions = [];
29
+ this.currentIndex = 0;
28
30
  }
29
31
  ngOnInit() {
30
32
  if (!!!this.itemHeight)
@@ -119,6 +121,7 @@ export class CoreDropdownComponent extends CoreFormControlBaseComponent {
119
121
  if (this.disabled || this.readonly)
120
122
  return;
121
123
  this.expandState = !!!this.expandState;
124
+ setTimeout(() => this.container.nativeElement.querySelector('.in-place-search')?.focus());
122
125
  }
123
126
  ngOnChanges(changes) {
124
127
  if (!!!changes['options'])
@@ -130,6 +133,60 @@ export class CoreDropdownComponent extends CoreFormControlBaseComponent {
130
133
  this.markAsTouched();
131
134
  this.onChange(null);
132
135
  }
136
+ changeFocus() {
137
+ const liElement = this.container?.nativeElement.querySelector('.item-li');
138
+ if (liElement) {
139
+ liElement.setAttribute('tabindex', '0'); // Make it focusable
140
+ liElement.focus();
141
+ liElement.classList.add('hover-effect');
142
+ // Remove hover effect when focus is lost
143
+ liElement.addEventListener('blur', () => {
144
+ liElement.classList.remove('hover-effect');
145
+ }, { once: true }); // Only listen once
146
+ setTimeout(() => liElement.classList.remove('hover-effect'), 1000);
147
+ }
148
+ }
149
+ navigateList(event) {
150
+ const items = this.container?.nativeElement.querySelectorAll('.item-li');
151
+ if (!items || items.length === 0)
152
+ return;
153
+ // Remove hover effect from current item
154
+ items[this.currentIndex]?.classList.remove('hover-effect');
155
+ // Navigate based on the key pressed
156
+ if (event.key === 'ArrowDown') {
157
+ this.currentIndex = (this.currentIndex + 1) % items.length; // Wrap around at the end
158
+ }
159
+ else if (event.key === 'ArrowUp') {
160
+ this.currentIndex = (this.currentIndex - 1 + items.length) % items.length; // Wrap around at the beginning
161
+ }
162
+ else {
163
+ return; // Exit if it's not an Arrow key
164
+ }
165
+ // Focus and add hover effect to the new item
166
+ const newItem = items[this.currentIndex];
167
+ newItem.setAttribute('tabindex', '0'); // Ensure it's focusable
168
+ newItem.focus();
169
+ newItem.classList.add('hover-effect');
170
+ }
171
+ onDropdownKeydown(event) {
172
+ if (event.key === 'ArrowUp' || event.key === 'ArrowDown') {
173
+ event.preventDefault(); // Prevent default scrolling behavior
174
+ this.navigateList(event);
175
+ }
176
+ }
177
+ onListItemKeydown(context, e) {
178
+ if (e.key === 'Enter') {
179
+ this.onListItemClick(context);
180
+ }
181
+ }
182
+ onInPlaceSearchKeydown(e) {
183
+ e.stopPropagation();
184
+ if (e.key === 'Tab') {
185
+ this.currentIndex = 0;
186
+ e.preventDefault();
187
+ setTimeout(() => this.changeFocus(), 10);
188
+ }
189
+ }
133
190
  ngOnDestroy() {
134
191
  if (this.listenerFn)
135
192
  this.listenerFn();
@@ -142,7 +199,7 @@ export class CoreDropdownComponent extends CoreFormControlBaseComponent {
142
199
  multi: true,
143
200
  useExisting: CoreDropdownComponent,
144
201
  },
145
- ], viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<app-threedots *ngIf=\"loading\"></app-threedots>\r\n<div #container class=\"core-dropdown-container\" *ngIf=\"!loading\">\r\n <input type=\"checkbox\" class=\"expand-state\" [(ngModel)]=\"expandState\" />\r\n\r\n <div class=\"input-wrapper\">\r\n <input class=\"value\" [value]=\"value\" />\r\n <label type=\"text\" class=\"text form-control\" [class.form-control-disabled]=\"disabled\" (click)=\"toggleExpanded()\">\r\n <span [appTooltip]=\"text\">{{ !!loading ? \"...\" : (text | translate : lang) }}</span>\r\n <div class=\"icon\">\r\n <i class=\"feather-chevron-down\"></i>\r\n </div>\r\n </label>\r\n @if (!clearDisable) {\r\n <div class=\"clear-icon-wrapper\" [class.d-none]=\"!!disabled || !!!value\" (click)=\"onClickClear()\">\r\n <div class=\"flex-wrapper\" [appTooltip]=\"'UI.CORE_CONTOL_COMMON_CLEAR' | translate : lang\">\r\n <i class=\"feather-x\"></i>\r\n </div>\r\n </div>\r\n }\r\n </div>\r\n\r\n <div class=\"dropdown\" [class.form-control-disabled]=\"disabled\" *ngIf=\"!!expandState\">\r\n <input class=\"search\" type=\"text\" [placeholder]=\"placeholderText\" [(ngModel)]=\"searchText\"\r\n (ngModelChange)=\"onSearchTextChange($event)\" autocomplete=\"false\" [class.form-control-disabled]=\"disabled\"\r\n [disabled]=\"disabled\" />\r\n <core-scroll [localOptions]=\"localOptions\" [itemTemplate]=\"itemTemplateRef\" [itemCount]=\"localOptions.length\"\r\n [height]=\"(fitHeightWithItemCount && localOptions.length * itemHeight < 400) ? localOptions.length * itemHeight : 400 - searchHeight\" [childHeight]=\"itemHeight\"></core-scroll>\r\n </div>\r\n</div>\r\n\r\n<ng-template #itemTemplateRef let-context=\"context\">\r\n <li (click)=\"onListItemClick(context)\" [ngStyle]=\"{ height: itemHeight + 'px' }\">\r\n <label [ngStyle]=\"{\r\n width: '100%',\r\n overflow: 'hidden',\r\n textOverflow: 'ellipsis',\r\n whiteSpace: 'nowrap'\r\n }\" [appTooltip]=\"context.text\">{{ context.text | translate : lang }}</label>\r\n </li>\r\n</ng-template>", styles: [".core-dropdown-container{position:relative;display:block;--indicator-height: 0px;--search-bg-color: white;--search-border-color: #D1D1D1;--search-item-hover-bg: #358ccb;--search-item-hover-color: white;--dropdown-bg: lightyellow;--arrow-color: #358ccb;--height: var(--size-form-control-height);--item-height: 50px;--max-z-index: 0;--search-height: 38px}.core-dropdown-container input.expand-state,.core-dropdown-container .value{display:none}.core-dropdown-container label.text{width:100%;height:var(--height);overflow:hidden;white-space:nowrap;text-overflow:ellipsis;display:flex;align-items:center;justify-content:space-between}.core-dropdown-container label.text span{width:calc(100% - var(--height));overflow-x:hidden;text-overflow:ellipsis;color:inherit}.core-dropdown-container .input-wrapper .clear-icon-wrapper{display:none;position:absolute;background-color:transparent;right:22px;top:-4px;width:44px;height:44px;border-radius:.375rem;cursor:pointer}.core-dropdown-container .input-wrapper .clear-icon-wrapper>.flex-wrapper{width:44px;height:44px;display:flex;align-items:center;justify-content:center}.core-dropdown-container .input-wrapper .clear-icon-wrapper>.flex-wrapper>i{color:#848484;font-size:24px}.core-dropdown-container .input-wrapper:hover>.clear-icon-wrapper{display:block}.core-dropdown-container label.text div.icon{display:flex;align-items:center;justify-content:center;position:absolute;right:0;top:0;width:calc(var(--height) - 0px);height:calc(var(--height) - 0px);border:#ced4da solid 1px;cursor:pointer}.core-dropdown-container label.text div.icon i{width:14px;height:14px;font-size:14px;color:#848484}.core-dropdown-container .dropdown{display:block;position:absolute;width:100%;max-height:0px;overflow:hidden;background-color:#fff;font-size:15px;box-shadow:0 1rem 3rem #0000002e;transition:.25s linear;z-index:calc(var(--max-z-index) + 1)}.core-dropdown-container .dropdown ul{padding-left:6px}.core-dropdown-container .dropdown ul>li{display:flex;align-items:center;cursor:pointer;padding:0px var(--size-scrollbar-width);transition:.25s linear}.core-dropdown-container .dropdown ul>li>label{width:100%}.core-dropdown-container .dropdown ul>li:hover{background-color:var(--search-item-hover-bg);color:var(--search-item-hover-color);transition:.25s linear}.core-dropdown-container input.expand-state:checked~.dropdown{border:1px solid #ced4da;margin-top:2px;max-height:400px;transition:.25s linear}.core-dropdown-container input.search{margin:0;width:100%;border:0;border-bottom:1px solid var(--search-border-color);background-color:var(--search-bg-color);position:sticky;top:0;height:38px;padding:6px 12px;font-size:15px}.core-dropdown-container input.search:focus{outline:none}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "component", type: CoreScrollComponent, selector: "core-scroll", inputs: ["localOptions", "itemTemplate", "itemCount", "height", "childHeight", "renderAhread"] }, { kind: "component", type: ThreedotsComponent, selector: "app-threedots" }, { kind: "directive", type: TooltipDirective, selector: "[appTooltip]", inputs: ["color", "backgroundColor", "appTooltip", "showAnyway", "position"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }], encapsulation: i0.ViewEncapsulation.None }); }
202
+ ], viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<app-threedots *ngIf=\"loading\"></app-threedots>\r\n<div #container class=\"core-dropdown-container\" *ngIf=\"!loading\">\r\n <input type=\"checkbox\" class=\"expand-state\" [(ngModel)]=\"expandState\" />\r\n\r\n <div class=\"input-wrapper\">\r\n <input class=\"value\" [value]=\"value\" />\r\n <input class=\"in-place-search form-control\" type=\"text\" [placeholder]=\"placeholderText\" [(ngModel)]=\"searchText\"\r\n (ngModelChange)=\"onSearchTextChange($event)\" autocomplete=\"false\" [class.form-control-disabled]=\"disabled\"\r\n [disabled]=\"disabled\" (keydown)=\"onInPlaceSearchKeydown($event)\" />\r\n <label type=\"text\" class=\"text form-control\" [class.form-control-disabled]=\"disabled\" (click)=\"toggleExpanded()\">\r\n <span [appTooltip]=\"text\">{{ !!loading ? \"...\" : (text | translate : lang) }}</span>\r\n <div class=\"icon\">\r\n <i class=\"feather-chevron-down\"></i>\r\n </div>\r\n </label>\r\n @if (!clearDisable) {\r\n <div class=\"clear-icon-wrapper\" [class.d-none]=\"!!disabled || !!!value\" (click)=\"onClickClear()\">\r\n <div class=\"flex-wrapper\" [appTooltip]=\"'UI.CORE_CONTOL_COMMON_CLEAR' | translate : lang\">\r\n <i class=\"feather-x\"></i>\r\n </div>\r\n </div>\r\n }\r\n </div>\r\n\r\n <div class=\"dropdown\" [class.form-control-disabled]=\"disabled\" *ngIf=\"!!expandState\" (keydown)=\"onDropdownKeydown($event)\">\r\n <input class=\"search d-none\" type=\"text\" [placeholder]=\"placeholderText\" [(ngModel)]=\"searchText\"\r\n (ngModelChange)=\"onSearchTextChange($event)\" autocomplete=\"false\" [class.form-control-disabled]=\"disabled\"\r\n [disabled]=\"disabled\" />\r\n <core-scroll [localOptions]=\"localOptions\" [itemTemplate]=\"itemTemplateRef\" [itemCount]=\"localOptions.length\"\r\n [height]=\"(fitHeightWithItemCount && localOptions.length * itemHeight < 400) ? localOptions.length * itemHeight : 400 - searchHeight\" [childHeight]=\"itemHeight\"></core-scroll>\r\n </div>\r\n</div>\r\n\r\n<ng-template #itemTemplateRef let-context=\"context\">\r\n <li class=\"item-li\" (click)=\"onListItemClick(context)\" (keydown)=\"onListItemKeydown(context, $event)\" [ngStyle]=\"{ height: itemHeight + 'px' }\">\r\n <label [ngStyle]=\"{\r\n width: '100%',\r\n overflow: 'hidden',\r\n textOverflow: 'ellipsis',\r\n whiteSpace: 'nowrap'\r\n }\" [appTooltip]=\"context.text\">{{ context.text | translate : lang }}</label>\r\n </li>\r\n</ng-template>", styles: [".core-dropdown-container{position:relative;display:block;--indicator-height: 0px;--search-bg-color: white;--search-border-color: #D1D1D1;--search-item-hover-bg: #358ccb;--search-item-hover-color: white;--dropdown-bg: lightyellow;--arrow-color: #358ccb;--height: var(--size-form-control-height);--item-height: 50px;--max-z-index: 0;--search-height: 38px}.core-dropdown-container input.expand-state,.core-dropdown-container .value{display:none}.core-dropdown-container .in-place-search{display:none;position:absolute;top:0;left:0;z-index:1}.core-dropdown-container label.text{width:100%;height:var(--height);overflow:hidden;white-space:nowrap;text-overflow:ellipsis;display:flex;align-items:center;justify-content:space-between}.core-dropdown-container label.text span{width:calc(100% - var(--height));overflow-x:hidden;text-overflow:ellipsis;color:inherit}.core-dropdown-container .input-wrapper .clear-icon-wrapper{display:none;position:absolute;background-color:transparent;right:24px;top:-4px;width:44px;height:44px;border-radius:.375rem;cursor:pointer}.core-dropdown-container .input-wrapper .clear-icon-wrapper>.flex-wrapper{width:44px;height:44px;display:flex;align-items:center;justify-content:center}.core-dropdown-container .input-wrapper .clear-icon-wrapper>.flex-wrapper>i{color:#848484;font-size:24px}.core-dropdown-container .input-wrapper:hover>.clear-icon-wrapper{display:block}.core-dropdown-container label.text div.icon{display:flex;align-items:center;justify-content:center;position:absolute;right:0;top:0;width:calc(var(--height) - 0px);height:calc(var(--height) - 0px);border:#ced4da solid 1px;cursor:pointer}.core-dropdown-container label.text div.icon i{width:14px;height:14px;font-size:14px;color:#848484}.core-dropdown-container .dropdown{display:block;position:absolute;width:100%;max-height:0px;overflow:hidden;background-color:#fff;font-size:15px;box-shadow:0 1rem 3rem #0000002e;transition:.25s linear;z-index:calc(var(--max-z-index) + 1)}.core-dropdown-container .dropdown ul{padding-left:6px}.core-dropdown-container .dropdown ul>li{display:flex;align-items:center;cursor:pointer;padding:0px var(--size-scrollbar-width);transition:.25s linear}.core-dropdown-container .dropdown ul>li>label{width:100%}.core-dropdown-container .dropdown ul>li:hover{background-color:var(--search-item-hover-bg);color:var(--search-item-hover-color);transition:.25s linear}.core-dropdown-container .hover-effect{background-color:var(--search-item-hover-bg);color:var(--search-item-hover-color);transition:.25s linear}.core-dropdown-container input.expand-state:checked~.dropdown{border:1px solid #ced4da;margin-top:3px;max-height:400px;transition:.25s linear}.core-dropdown-container input.expand-state:checked~.input-wrapper>.in-place-search{display:block}.core-dropdown-container input.search{margin:0;width:100%;border:0;border-bottom:1px solid var(--search-border-color);background-color:var(--search-bg-color);position:sticky;top:0;height:38px;padding:6px 12px;font-size:15px}.core-dropdown-container input.search:focus{outline:none}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "component", type: CoreScrollComponent, selector: "core-scroll", inputs: ["localOptions", "itemTemplate", "itemCount", "height", "childHeight", "renderAhread"] }, { kind: "component", type: ThreedotsComponent, selector: "app-threedots" }, { kind: "directive", type: TooltipDirective, selector: "[appTooltip]", inputs: ["color", "backgroundColor", "appTooltip", "showAnyway", "position"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }], encapsulation: i0.ViewEncapsulation.None }); }
146
203
  }
147
204
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: CoreDropdownComponent, decorators: [{
148
205
  type: Component,
@@ -160,7 +217,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
160
217
  multi: true,
161
218
  useExisting: CoreDropdownComponent,
162
219
  },
163
- ], template: "<app-threedots *ngIf=\"loading\"></app-threedots>\r\n<div #container class=\"core-dropdown-container\" *ngIf=\"!loading\">\r\n <input type=\"checkbox\" class=\"expand-state\" [(ngModel)]=\"expandState\" />\r\n\r\n <div class=\"input-wrapper\">\r\n <input class=\"value\" [value]=\"value\" />\r\n <label type=\"text\" class=\"text form-control\" [class.form-control-disabled]=\"disabled\" (click)=\"toggleExpanded()\">\r\n <span [appTooltip]=\"text\">{{ !!loading ? \"...\" : (text | translate : lang) }}</span>\r\n <div class=\"icon\">\r\n <i class=\"feather-chevron-down\"></i>\r\n </div>\r\n </label>\r\n @if (!clearDisable) {\r\n <div class=\"clear-icon-wrapper\" [class.d-none]=\"!!disabled || !!!value\" (click)=\"onClickClear()\">\r\n <div class=\"flex-wrapper\" [appTooltip]=\"'UI.CORE_CONTOL_COMMON_CLEAR' | translate : lang\">\r\n <i class=\"feather-x\"></i>\r\n </div>\r\n </div>\r\n }\r\n </div>\r\n\r\n <div class=\"dropdown\" [class.form-control-disabled]=\"disabled\" *ngIf=\"!!expandState\">\r\n <input class=\"search\" type=\"text\" [placeholder]=\"placeholderText\" [(ngModel)]=\"searchText\"\r\n (ngModelChange)=\"onSearchTextChange($event)\" autocomplete=\"false\" [class.form-control-disabled]=\"disabled\"\r\n [disabled]=\"disabled\" />\r\n <core-scroll [localOptions]=\"localOptions\" [itemTemplate]=\"itemTemplateRef\" [itemCount]=\"localOptions.length\"\r\n [height]=\"(fitHeightWithItemCount && localOptions.length * itemHeight < 400) ? localOptions.length * itemHeight : 400 - searchHeight\" [childHeight]=\"itemHeight\"></core-scroll>\r\n </div>\r\n</div>\r\n\r\n<ng-template #itemTemplateRef let-context=\"context\">\r\n <li (click)=\"onListItemClick(context)\" [ngStyle]=\"{ height: itemHeight + 'px' }\">\r\n <label [ngStyle]=\"{\r\n width: '100%',\r\n overflow: 'hidden',\r\n textOverflow: 'ellipsis',\r\n whiteSpace: 'nowrap'\r\n }\" [appTooltip]=\"context.text\">{{ context.text | translate : lang }}</label>\r\n </li>\r\n</ng-template>", styles: [".core-dropdown-container{position:relative;display:block;--indicator-height: 0px;--search-bg-color: white;--search-border-color: #D1D1D1;--search-item-hover-bg: #358ccb;--search-item-hover-color: white;--dropdown-bg: lightyellow;--arrow-color: #358ccb;--height: var(--size-form-control-height);--item-height: 50px;--max-z-index: 0;--search-height: 38px}.core-dropdown-container input.expand-state,.core-dropdown-container .value{display:none}.core-dropdown-container label.text{width:100%;height:var(--height);overflow:hidden;white-space:nowrap;text-overflow:ellipsis;display:flex;align-items:center;justify-content:space-between}.core-dropdown-container label.text span{width:calc(100% - var(--height));overflow-x:hidden;text-overflow:ellipsis;color:inherit}.core-dropdown-container .input-wrapper .clear-icon-wrapper{display:none;position:absolute;background-color:transparent;right:22px;top:-4px;width:44px;height:44px;border-radius:.375rem;cursor:pointer}.core-dropdown-container .input-wrapper .clear-icon-wrapper>.flex-wrapper{width:44px;height:44px;display:flex;align-items:center;justify-content:center}.core-dropdown-container .input-wrapper .clear-icon-wrapper>.flex-wrapper>i{color:#848484;font-size:24px}.core-dropdown-container .input-wrapper:hover>.clear-icon-wrapper{display:block}.core-dropdown-container label.text div.icon{display:flex;align-items:center;justify-content:center;position:absolute;right:0;top:0;width:calc(var(--height) - 0px);height:calc(var(--height) - 0px);border:#ced4da solid 1px;cursor:pointer}.core-dropdown-container label.text div.icon i{width:14px;height:14px;font-size:14px;color:#848484}.core-dropdown-container .dropdown{display:block;position:absolute;width:100%;max-height:0px;overflow:hidden;background-color:#fff;font-size:15px;box-shadow:0 1rem 3rem #0000002e;transition:.25s linear;z-index:calc(var(--max-z-index) + 1)}.core-dropdown-container .dropdown ul{padding-left:6px}.core-dropdown-container .dropdown ul>li{display:flex;align-items:center;cursor:pointer;padding:0px var(--size-scrollbar-width);transition:.25s linear}.core-dropdown-container .dropdown ul>li>label{width:100%}.core-dropdown-container .dropdown ul>li:hover{background-color:var(--search-item-hover-bg);color:var(--search-item-hover-color);transition:.25s linear}.core-dropdown-container input.expand-state:checked~.dropdown{border:1px solid #ced4da;margin-top:2px;max-height:400px;transition:.25s linear}.core-dropdown-container input.search{margin:0;width:100%;border:0;border-bottom:1px solid var(--search-border-color);background-color:var(--search-bg-color);position:sticky;top:0;height:38px;padding:6px 12px;font-size:15px}.core-dropdown-container input.search:focus{outline:none}\n"] }]
220
+ ], template: "<app-threedots *ngIf=\"loading\"></app-threedots>\r\n<div #container class=\"core-dropdown-container\" *ngIf=\"!loading\">\r\n <input type=\"checkbox\" class=\"expand-state\" [(ngModel)]=\"expandState\" />\r\n\r\n <div class=\"input-wrapper\">\r\n <input class=\"value\" [value]=\"value\" />\r\n <input class=\"in-place-search form-control\" type=\"text\" [placeholder]=\"placeholderText\" [(ngModel)]=\"searchText\"\r\n (ngModelChange)=\"onSearchTextChange($event)\" autocomplete=\"false\" [class.form-control-disabled]=\"disabled\"\r\n [disabled]=\"disabled\" (keydown)=\"onInPlaceSearchKeydown($event)\" />\r\n <label type=\"text\" class=\"text form-control\" [class.form-control-disabled]=\"disabled\" (click)=\"toggleExpanded()\">\r\n <span [appTooltip]=\"text\">{{ !!loading ? \"...\" : (text | translate : lang) }}</span>\r\n <div class=\"icon\">\r\n <i class=\"feather-chevron-down\"></i>\r\n </div>\r\n </label>\r\n @if (!clearDisable) {\r\n <div class=\"clear-icon-wrapper\" [class.d-none]=\"!!disabled || !!!value\" (click)=\"onClickClear()\">\r\n <div class=\"flex-wrapper\" [appTooltip]=\"'UI.CORE_CONTOL_COMMON_CLEAR' | translate : lang\">\r\n <i class=\"feather-x\"></i>\r\n </div>\r\n </div>\r\n }\r\n </div>\r\n\r\n <div class=\"dropdown\" [class.form-control-disabled]=\"disabled\" *ngIf=\"!!expandState\" (keydown)=\"onDropdownKeydown($event)\">\r\n <input class=\"search d-none\" type=\"text\" [placeholder]=\"placeholderText\" [(ngModel)]=\"searchText\"\r\n (ngModelChange)=\"onSearchTextChange($event)\" autocomplete=\"false\" [class.form-control-disabled]=\"disabled\"\r\n [disabled]=\"disabled\" />\r\n <core-scroll [localOptions]=\"localOptions\" [itemTemplate]=\"itemTemplateRef\" [itemCount]=\"localOptions.length\"\r\n [height]=\"(fitHeightWithItemCount && localOptions.length * itemHeight < 400) ? localOptions.length * itemHeight : 400 - searchHeight\" [childHeight]=\"itemHeight\"></core-scroll>\r\n </div>\r\n</div>\r\n\r\n<ng-template #itemTemplateRef let-context=\"context\">\r\n <li class=\"item-li\" (click)=\"onListItemClick(context)\" (keydown)=\"onListItemKeydown(context, $event)\" [ngStyle]=\"{ height: itemHeight + 'px' }\">\r\n <label [ngStyle]=\"{\r\n width: '100%',\r\n overflow: 'hidden',\r\n textOverflow: 'ellipsis',\r\n whiteSpace: 'nowrap'\r\n }\" [appTooltip]=\"context.text\">{{ context.text | translate : lang }}</label>\r\n </li>\r\n</ng-template>", styles: [".core-dropdown-container{position:relative;display:block;--indicator-height: 0px;--search-bg-color: white;--search-border-color: #D1D1D1;--search-item-hover-bg: #358ccb;--search-item-hover-color: white;--dropdown-bg: lightyellow;--arrow-color: #358ccb;--height: var(--size-form-control-height);--item-height: 50px;--max-z-index: 0;--search-height: 38px}.core-dropdown-container input.expand-state,.core-dropdown-container .value{display:none}.core-dropdown-container .in-place-search{display:none;position:absolute;top:0;left:0;z-index:1}.core-dropdown-container label.text{width:100%;height:var(--height);overflow:hidden;white-space:nowrap;text-overflow:ellipsis;display:flex;align-items:center;justify-content:space-between}.core-dropdown-container label.text span{width:calc(100% - var(--height));overflow-x:hidden;text-overflow:ellipsis;color:inherit}.core-dropdown-container .input-wrapper .clear-icon-wrapper{display:none;position:absolute;background-color:transparent;right:24px;top:-4px;width:44px;height:44px;border-radius:.375rem;cursor:pointer}.core-dropdown-container .input-wrapper .clear-icon-wrapper>.flex-wrapper{width:44px;height:44px;display:flex;align-items:center;justify-content:center}.core-dropdown-container .input-wrapper .clear-icon-wrapper>.flex-wrapper>i{color:#848484;font-size:24px}.core-dropdown-container .input-wrapper:hover>.clear-icon-wrapper{display:block}.core-dropdown-container label.text div.icon{display:flex;align-items:center;justify-content:center;position:absolute;right:0;top:0;width:calc(var(--height) - 0px);height:calc(var(--height) - 0px);border:#ced4da solid 1px;cursor:pointer}.core-dropdown-container label.text div.icon i{width:14px;height:14px;font-size:14px;color:#848484}.core-dropdown-container .dropdown{display:block;position:absolute;width:100%;max-height:0px;overflow:hidden;background-color:#fff;font-size:15px;box-shadow:0 1rem 3rem #0000002e;transition:.25s linear;z-index:calc(var(--max-z-index) + 1)}.core-dropdown-container .dropdown ul{padding-left:6px}.core-dropdown-container .dropdown ul>li{display:flex;align-items:center;cursor:pointer;padding:0px var(--size-scrollbar-width);transition:.25s linear}.core-dropdown-container .dropdown ul>li>label{width:100%}.core-dropdown-container .dropdown ul>li:hover{background-color:var(--search-item-hover-bg);color:var(--search-item-hover-color);transition:.25s linear}.core-dropdown-container .hover-effect{background-color:var(--search-item-hover-bg);color:var(--search-item-hover-color);transition:.25s linear}.core-dropdown-container input.expand-state:checked~.dropdown{border:1px solid #ced4da;margin-top:3px;max-height:400px;transition:.25s linear}.core-dropdown-container input.expand-state:checked~.input-wrapper>.in-place-search{display:block}.core-dropdown-container input.search{margin:0;width:100%;border:0;border-bottom:1px solid var(--search-border-color);background-color:var(--search-bg-color);position:sticky;top:0;height:38px;padding:6px 12px;font-size:15px}.core-dropdown-container input.search:focus{outline:none}\n"] }]
164
221
  }], ctorParameters: () => [{ type: i0.Renderer2 }, { type: i1.DomService }, { type: i2.AlertService }, { type: i0.Injector }, { type: i3.MultiLanguageService }], propDecorators: { getByIdObject$: [{
165
222
  type: Input
166
223
  }], paramMode: [{
@@ -187,4 +244,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
187
244
  type: ViewChild,
188
245
  args: ['container']
189
246
  }] } });
190
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-dropdown/core-dropdown/core-dropdown.component.ts","../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-dropdown/core-dropdown/core-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, Injector, Input, OnChanges, OnDestroy, OnInit, Renderer2, SimpleChanges, ViewChild, ViewEncapsulation, isDevMode, } from '@angular/core';\r\nimport { CoreFormControlBaseComponent } from '../../core-form-control-base/core-form-control-base.component';\r\nimport { FormsModule, NG_VALUE_ACCESSOR, NgControl, ReactiveFormsModule } from '@angular/forms';\r\nimport { BehaviorSubject, Subscription, filter } from 'rxjs';\r\nimport { DomService } from '../../services/dom.service';\r\nimport { AlertService } from '../../alert/alert.service';\r\nimport { MultiLanguageService } from '../../../services/multi-language.service';\r\nimport { noneAutoClosedAlertOptions } from '../../../constants/alertOptions';\r\nimport { ICoreDropdownOption } from '../../../interfaces/ICoreDropdownOption';\r\nimport { CommonModule } from '@angular/common';\r\nimport { CoreScrollComponent } from '../../core-scroll/core-scroll/core-scroll.component';\r\nimport { ThreedotsComponent } from '../../threedots/threedots.component';\r\nimport { TooltipDirective } from '../../tooltip/tooltip.directive';\r\nimport { TranslatePipe } from '../../../app-pipes/translate.pipe';\r\n@Component({\r\n  selector: 'core-dropdown',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    ReactiveFormsModule,\r\n    CoreScrollComponent,\r\n    ThreedotsComponent,\r\n    TooltipDirective,\r\n    TranslatePipe,\r\n  ],\r\n  templateUrl: './core-dropdown.component.html',\r\n  styleUrls: ['./core-dropdown.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      multi: true,\r\n      useExisting: CoreDropdownComponent,\r\n    },\r\n  ],\r\n})\r\nexport class CoreDropdownComponent extends CoreFormControlBaseComponent implements OnInit, AfterViewInit, OnDestroy, OnChanges {\r\n  ngControl!: NgControl;\r\n\r\n  @Input() getByIdObject$!: BehaviorSubject<any>;\r\n  @Input() paramMode!: boolean;\r\n  @Input() shownFrom!: string; // take this field from GetById response innerBody to bind to the text\r\n  @Input() options$!: BehaviorSubject<ICoreDropdownOption[]>;\r\n  @Input() height!: string;\r\n  @Input() placeholder: string = 'UI_COMMON_PLACE_HOLDER_SEARCH_HERE';\r\n  @Input() loading!: boolean;\r\n  @Input() warningDisable!: boolean;\r\n  @Input() clearDisable!: boolean;\r\n  @Input() fitHeightWithItemCount: boolean = true;\r\n  @Input() itemHeight!: number;\r\n  @ViewChild('container') container!: ElementRef;\r\n\r\n  listenerFn!: () => void;\r\n\r\n  options!: ICoreDropdownOption[];\r\n\r\n  localOptions!: ICoreDropdownOption[];\r\n  override value!: string | number | null;\r\n\r\n  lang!: string;\r\n  placeholderText!: string;\r\n  text!: string;\r\n  searchText!: string;\r\n  searchHeight: number = 38;\r\n  expandState!: boolean;\r\n\r\n  subscriptions: Subscription[] = [];\r\n\r\n  constructor(\r\n    private renderer: Renderer2,\r\n    private domService: DomService,\r\n    private alertService: AlertService,\r\n    private injector: Injector,\r\n    private mls: MultiLanguageService,\r\n  ) {\r\n    super();\r\n\r\n  }\r\n\r\n  ngOnInit(): void {\r\n\r\n    if (!!!this.itemHeight) this.itemHeight = 40;\r\n\r\n    this.ngControl = this.injector.get(NgControl);\r\n\r\n    /* START: CHECK INPUT ERROR */\r\n    if (!!!this.options$ && isDevMode() && !!!this.warningDisable) {\r\n      this.alertService.error(\r\n        `\r\n        CoreDropdownComponent required this input: options$!: BehaviorSubject<ICoreDropdownOption[]>;\r\n        Also, it needs to receive a new value that usually comes from and API GetAll() action\r\n        `,\r\n        noneAutoClosedAlertOptions,\r\n      );\r\n    }\r\n\r\n    if (!!!this.paramMode) {\r\n      //getByIdObject$\r\n      if (!!!this.getByIdObject$ && isDevMode() && !!!this.warningDisable) {\r\n        this.alertService.error(\r\n          `CoreDropdownComponent Error: Required inputs:\r\n                getByIdObject$: BehaviorSubject&lt;any&gt; (for '${this.ngControl.name}')`,\r\n        );\r\n      }\r\n\r\n      if (!!!this.shownFrom && isDevMode() && !!!this.warningDisable) {\r\n        this.alertService.error(\r\n          `CoreDropdownComponent Error: Required inputs:\r\n              shownFrom: string; (for '${this.ngControl.name}')`,\r\n          noneAutoClosedAlertOptions,\r\n        );\r\n      }\r\n    }\r\n\r\n    /* END: CHECK INPUT ERROR */\r\n\r\n    this.subscriptions.push(\r\n      this.options$.subscribe((x) => {\r\n        this.options = x;\r\n        this.localOptions = x;\r\n        // in scenario when getByIdObject$ has not run\r\n        if (!!this.value) {\r\n          if (!this.text) {\r\n            this.text = this.options?.filter(m => m.value === this.value)[0]?.text\r\n          }\r\n        }\r\n      }),\r\n    );\r\n\r\n    this.subscriptions.push(\r\n      this.getByIdObject$?.subscribe((x) => {\r\n        if (!!x) {\r\n          this.text = x[this.shownFrom];\r\n        } else {\r\n          this.text = '';\r\n        }\r\n      }),\r\n    );\r\n\r\n    this.subscriptions.push(\r\n      this.mls.lang$.subscribe(x => {\r\n        this.lang = x;\r\n        this.placeholderText = this.mls.trans(this.placeholder, x)\r\n      })\r\n    )\r\n\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    /**\r\n     * This events get called by all clicks on the page\r\n     */\r\n    this.listenerFn = this.renderer.listen('window', 'click', (e: Event) => {\r\n      /*\r\n       * handle click outside\r\n       */\r\n      if (this.container && !!!this.container.nativeElement.contains(e.target)) {\r\n        this.expandState = false;\r\n        this.searchText = '';\r\n        this.localOptions = this.options$.value;\r\n      }\r\n    });\r\n\r\n    const maxZIndex = this.domService.getMaxZIndex();\r\n    this.container.nativeElement.style.setProperty('--max-z-index', maxZIndex + 1);\r\n    this.container.nativeElement.style.setProperty('--search-height', this.searchHeight + 'px');\r\n    this.container.nativeElement.style.setProperty('--item-height', this.itemHeight + 'px');\r\n    if (!!this.height) this.container.nativeElement.style.setProperty('--height', this.height);\r\n  }\r\n\r\n  override writeValue(obj: string | number | null): void {\r\n    this.value = obj;\r\n    const filter = this.options?.filter(m => m.value === obj)\r\n    if (!!filter?.length) {\r\n      this.text = this.options.filter(m => m.value === obj)[0].text\r\n    } else {\r\n      this.text = \"\"\r\n    }\r\n\r\n  }\r\n\r\n  onSearchTextChange(value: string) {\r\n    this.localOptions = this.options.filter((x) => x.text.toLowerCase().indexOf(value.toLocaleLowerCase()) >= 0);\r\n  }\r\n\r\n  onListItemClick(option: ICoreDropdownOption): void {\r\n    if (this.disabled) return;\r\n    this.writeValue(option.value)\r\n    // this.text = option.text;\r\n    this.markAsTouched(); // do this before onChange\r\n    this.onChange(option.value);\r\n    this.expandState = false;\r\n  }\r\n\r\n  toggleExpanded(): void {\r\n    if (this.disabled || this.readonly) return;\r\n    this.expandState = !!!this.expandState;\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (!!!changes['options']) return;\r\n    this.localOptions = changes['options']?.currentValue;\r\n  }\r\n\r\n  onClickClear() {\r\n    this.writeValue(null);\r\n    this.markAsTouched();\r\n    this.onChange(null);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    if (this.listenerFn) this.listenerFn();\r\n    this.subscriptions.map((x) => x?.unsubscribe());\r\n  }\r\n}\r\n","<app-threedots *ngIf=\"loading\"></app-threedots>\r\n<div #container class=\"core-dropdown-container\" *ngIf=\"!loading\">\r\n  <input type=\"checkbox\" class=\"expand-state\" [(ngModel)]=\"expandState\" />\r\n\r\n  <div class=\"input-wrapper\">\r\n    <input class=\"value\" [value]=\"value\" />\r\n    <label type=\"text\" class=\"text form-control\" [class.form-control-disabled]=\"disabled\" (click)=\"toggleExpanded()\">\r\n      <span [appTooltip]=\"text\">{{ !!loading ? \"...\" : (text | translate : lang) }}</span>\r\n      <div class=\"icon\">\r\n        <i class=\"feather-chevron-down\"></i>\r\n      </div>\r\n    </label>\r\n    @if (!clearDisable) {\r\n    <div class=\"clear-icon-wrapper\" [class.d-none]=\"!!disabled || !!!value\" (click)=\"onClickClear()\">\r\n      <div class=\"flex-wrapper\" [appTooltip]=\"'UI.CORE_CONTOL_COMMON_CLEAR' | translate : lang\">\r\n        <i class=\"feather-x\"></i>\r\n      </div>\r\n    </div>\r\n    }\r\n  </div>\r\n\r\n  <div class=\"dropdown\" [class.form-control-disabled]=\"disabled\" *ngIf=\"!!expandState\">\r\n    <input class=\"search\" type=\"text\" [placeholder]=\"placeholderText\" [(ngModel)]=\"searchText\"\r\n      (ngModelChange)=\"onSearchTextChange($event)\" autocomplete=\"false\" [class.form-control-disabled]=\"disabled\"\r\n      [disabled]=\"disabled\" />\r\n    <core-scroll [localOptions]=\"localOptions\" [itemTemplate]=\"itemTemplateRef\" [itemCount]=\"localOptions.length\"\r\n      [height]=\"(fitHeightWithItemCount && localOptions.length * itemHeight < 400) ? localOptions.length * itemHeight : 400 - searchHeight\" [childHeight]=\"itemHeight\"></core-scroll>\r\n  </div>\r\n</div>\r\n\r\n<ng-template #itemTemplateRef let-context=\"context\">\r\n  <li (click)=\"onListItemClick(context)\" [ngStyle]=\"{ height: itemHeight + 'px' }\">\r\n    <label [ngStyle]=\"{\r\n        width: '100%',\r\n        overflow: 'hidden',\r\n        textOverflow: 'ellipsis',\r\n        whiteSpace: 'nowrap'\r\n      }\" [appTooltip]=\"context.text\">{{ context.text | translate : lang }}</label>\r\n  </li>\r\n</ng-template>"]}
247
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-dropdown/core-dropdown/core-dropdown.component.ts","../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-dropdown/core-dropdown/core-dropdown.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAiB,SAAS,EAAwB,KAAK,EAA0D,SAAS,EAAE,iBAAiB,EAAE,SAAS,GAAG,MAAM,eAAe,CAAC;AACxL,OAAO,EAAE,4BAA4B,EAAE,MAAM,+DAA+D,CAAC;AAC7G,OAAO,EAAE,WAAW,EAAE,iBAAiB,EAAE,SAAS,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAKhG,OAAO,EAAE,0BAA0B,EAAE,MAAM,iCAAiC,CAAC;AAE7E,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,mBAAmB,EAAE,MAAM,qDAAqD,CAAC;AAC1F,OAAO,EAAE,kBAAkB,EAAE,MAAM,qCAAqC,CAAC;AACzE,OAAO,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAC;AACnE,OAAO,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAC;;;;;;;AAwBlE,MAAM,OAAO,qBAAsB,SAAQ,4BAA4B;IAiCrE,YACU,QAAmB,EACnB,UAAsB,EACtB,YAA0B,EAC1B,QAAkB,EAClB,GAAyB;QAEjC,KAAK,EAAE,CAAC;QANA,aAAQ,GAAR,QAAQ,CAAW;QACnB,eAAU,GAAV,UAAU,CAAY;QACtB,iBAAY,GAAZ,YAAY,CAAc;QAC1B,aAAQ,GAAR,QAAQ,CAAU;QAClB,QAAG,GAAH,GAAG,CAAsB;QA9B1B,gBAAW,GAAW,oCAAoC,CAAC;QAI3D,2BAAsB,GAAY,IAAI,CAAC;QAehD,4BAA4B;QAC5B,iBAAY,GAAW,CAAC,CAAC;QAGzB,kBAAa,GAAmB,EAAE,CAAC;QAiKnC,iBAAY,GAAW,CAAC,CAAC;IAtJzB,CAAC;IAED,QAAQ;QAEN,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU;YAAE,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;QAE7C,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAE9C,8BAA8B;QAC9B,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,IAAI,SAAS,EAAE,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,EAAE;YAC7D,IAAI,CAAC,YAAY,CAAC,KAAK,CACrB;;;SAGC,EACD,0BAA0B,CAC3B,CAAC;SACH;QAED,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,EAAE;YACrB,gBAAgB;YAChB,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,IAAI,SAAS,EAAE,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,EAAE;gBACnE,IAAI,CAAC,YAAY,CAAC,KAAK,CACrB;mEACyD,IAAI,CAAC,SAAS,CAAC,IAAI,IAAI,CACjF,CAAC;aACH;YAED,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,IAAI,SAAS,EAAE,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,EAAE;gBAC9D,IAAI,CAAC,YAAY,CAAC,KAAK,CACrB;yCAC+B,IAAI,CAAC,SAAS,CAAC,IAAI,IAAI,EACtD,0BAA0B,CAC3B,CAAC;aACH;SACF;QAED,4BAA4B;QAE5B,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YAC5B,IAAI,CAAC,OAAO,GAAG,CAAC,CAAC;YACjB,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;YACtB,8CAA8C;YAC9C,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE;gBAChB,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE;oBACd,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,IAAI,CAAA;iBACvE;aACF;QACH,CAAC,CAAC,CACH,CAAC;QAEF,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,IAAI,CAAC,cAAc,EAAE,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YACnC,IAAI,CAAC,CAAC,CAAC,EAAE;gBACP,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;aAC/B;iBAAM;gBACL,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;aAChB;QACH,CAAC,CAAC,CACH,CAAC;QAEF,IAAI,CAAC,aAAa,CAAC,IAAI,CACrB,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;YAC3B,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;YACd,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,CAAA;QAC5D,CAAC,CAAC,CACH,CAAA;IAEH,CAAC;IAED,eAAe;QACb;;WAEG;QACH,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAQ,EAAE,EAAE;YACrE;;eAEG;YACH,IAAI,IAAI,CAAC,SAAS,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE;gBACxE,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;gBACzB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;gBACrB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC;aACzC;QACH,CAAC,CAAC,CAAC;QAEH,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC,YAAY,EAAE,CAAC;QACjD,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,CAAC,WAAW,CAAC,eAAe,EAAE,SAAS,GAAG,CAAC,CAAC,CAAC;QAC/E,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,CAAC,WAAW,CAAC,iBAAiB,EAAE,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,CAAC;QAC5F,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,CAAC,WAAW,CAAC,eAAe,EAAE,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,CAAC;QACxF,IAAI,CAAC,CAAC,IAAI,CAAC,MAAM;YAAE,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,CAAC,WAAW,CAAC,UAAU,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;IAC7F,CAAC;IAEQ,UAAU,CAAC,GAA2B;QAC7C,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC;QACjB,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,GAAG,CAAC,CAAA;QACzD,IAAI,CAAC,CAAC,MAAM,EAAE,MAAM,EAAE;YACpB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAA;SAC9D;aAAM;YACL,IAAI,CAAC,IAAI,GAAG,EAAE,CAAA;SACf;IAEH,CAAC;IAED,kBAAkB,CAAC,KAAa;QAC9B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,iBAAiB,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;IAC/G,CAAC;IAED,eAAe,CAAC,MAA2B;QACzC,IAAI,IAAI,CAAC,QAAQ;YAAE,OAAO;QAC1B,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;QAC7B,2BAA2B;QAC3B,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC,0BAA0B;QAChD,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QAC5B,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;IAC3B,CAAC;IAED,cAAc;QACZ,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ;YAAE,OAAO;QAC3C,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC;QACvC,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,aAAa,CAAC,kBAAkB,CAAC,EAAE,KAAK,EAAE,CAAC,CAAA;IAC3F,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC;YAAE,OAAO;QAClC,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC,SAAS,CAAC,EAAE,YAAY,CAAC;IACvD,CAAC;IAED,YAAY;QACV,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;QACtB,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;IACtB,CAAC;IAED,WAAW;QACT,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,EAAE,aAAa,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;QAC1E,IAAI,SAAS,EAAE;YACb,SAAS,CAAC,YAAY,CAAC,UAAU,EAAE,GAAG,CAAC,CAAC,CAAC,oBAAoB;YAC7D,SAAS,CAAC,KAAK,EAAE,CAAC;YAClB,SAAS,CAAC,SAAS,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;YAExC,yCAAyC;YACzC,SAAS,CAAC,gBAAgB,CAAC,MAAM,EAAE,GAAG,EAAE;gBACtC,SAAS,CAAC,SAAS,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC;YAC7C,CAAC,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,mBAAmB;YAEvC,UAAU,CAAC,GAAG,EAAE,CAAC,SAAS,CAAC,SAAS,CAAC,MAAM,CAAC,cAAc,CAAC,EAAE,IAAI,CAAC,CAAA;SACnE;IACH,CAAC;IAGD,YAAY,CAAC,KAAoB;QAC/B,MAAM,KAAK,GAA4B,IAAI,CAAC,SAAS,EAAE,aAAa,CAAC,gBAAgB,CAAC,UAAU,CAAC,CAAC;QAClG,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO;QAEzC,wCAAwC;QACxC,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,SAAS,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC;QAE3D,oCAAoC;QACpC,IAAI,KAAK,CAAC,GAAG,KAAK,WAAW,EAAE;YAC7B,IAAI,CAAC,YAAY,GAAG,CAAC,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,yBAAyB;SACtF;aAAM,IAAI,KAAK,CAAC,GAAG,KAAK,SAAS,EAAE;YAClC,IAAI,CAAC,YAAY,GAAG,CAAC,IAAI,CAAC,YAAY,GAAG,CAAC,GAAG,KAAK,CAAC,MAAM,CAAC,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,+BAA+B;SAC3G;aAAM;YACL,OAAO,CAAC,gCAAgC;SACzC;QAED,6CAA6C;QAC7C,MAAM,OAAO,GAAG,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACzC,OAAO,CAAC,YAAY,CAAC,UAAU,EAAE,GAAG,CAAC,CAAC,CAAC,wBAAwB;QAC/D,OAAO,CAAC,KAAK,EAAE,CAAC;QAChB,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;IACxC,CAAC;IAED,iBAAiB,CAAC,KAAoB;QACpC,IAAI,KAAK,CAAC,GAAG,KAAK,SAAS,IAAI,KAAK,CAAC,GAAG,KAAK,WAAW,EAAE;YACxD,KAAK,CAAC,cAAc,EAAE,CAAC,CAAC,qCAAqC;YAC7D,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;SAC1B;IACH,CAAC;IAED,iBAAiB,CAAC,OAAY,EAAE,CAAgB;QAC9C,IAAI,CAAC,CAAC,GAAG,KAAK,OAAO,EAAE;YACrB,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;SAC/B;IACH,CAAC;IAED,sBAAsB,CAAC,CAAgB;QACrC,CAAC,CAAC,eAAe,EAAE,CAAC;QACpB,IAAI,CAAC,CAAC,GAAG,KAAK,KAAK,EAAE;YACnB,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;YACtB,CAAC,CAAC,cAAc,EAAE,CAAC;YACnB,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE,EAAE,CAAC,CAAA;SACzC;IACH,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,UAAU;YAAE,IAAI,CAAC,UAAU,EAAE,CAAC;QACvC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,WAAW,EAAE,CAAC,CAAC;IAClD,CAAC;8GAjPU,qBAAqB;kGAArB,qBAAqB,8XARrB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,KAAK,EAAE,IAAI;gBACX,WAAW,EAAE,qBAAqB;aACnC;SACF,8KCnCH,4+EA0Cc,miGDxBV,YAAY,uNACZ,WAAW,+xBACX,mBAAmB,+BACnB,mBAAmB,wJACnB,kBAAkB,0DAClB,gBAAgB,kIAChB,aAAa;;2FAaJ,qBAAqB;kBAvBjC,SAAS;+BACE,eAAe,cACb,IAAI,WACP;wBACP,YAAY;wBACZ,WAAW;wBACX,mBAAmB;wBACnB,mBAAmB;wBACnB,kBAAkB;wBAClB,gBAAgB;wBAChB,aAAa;qBACd,iBAGc,iBAAiB,CAAC,IAAI,aAC1B;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,KAAK,EAAE,IAAI;4BACX,WAAW,uBAAuB;yBACnC;qBACF;4LAKQ,cAAc;sBAAtB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,sBAAsB;sBAA9B,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACkB,SAAS;sBAAhC,SAAS;uBAAC,WAAW","sourcesContent":["import { AfterViewInit, Component, ElementRef, Injector, Input, OnChanges, OnDestroy, OnInit, Renderer2, SimpleChanges, ViewChild, ViewEncapsulation, isDevMode, } from '@angular/core';\r\nimport { CoreFormControlBaseComponent } from '../../core-form-control-base/core-form-control-base.component';\r\nimport { FormsModule, NG_VALUE_ACCESSOR, NgControl, ReactiveFormsModule } from '@angular/forms';\r\nimport { BehaviorSubject, Subscription, filter } from 'rxjs';\r\nimport { DomService } from '../../services/dom.service';\r\nimport { AlertService } from '../../alert/alert.service';\r\nimport { MultiLanguageService } from '../../../services/multi-language.service';\r\nimport { noneAutoClosedAlertOptions } from '../../../constants/alertOptions';\r\nimport { ICoreDropdownOption } from '../../../interfaces/ICoreDropdownOption';\r\nimport { CommonModule } from '@angular/common';\r\nimport { CoreScrollComponent } from '../../core-scroll/core-scroll/core-scroll.component';\r\nimport { ThreedotsComponent } from '../../threedots/threedots.component';\r\nimport { TooltipDirective } from '../../tooltip/tooltip.directive';\r\nimport { TranslatePipe } from '../../../app-pipes/translate.pipe';\r\n@Component({\r\n  selector: 'core-dropdown',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    ReactiveFormsModule,\r\n    CoreScrollComponent,\r\n    ThreedotsComponent,\r\n    TooltipDirective,\r\n    TranslatePipe,\r\n  ],\r\n  templateUrl: './core-dropdown.component.html',\r\n  styleUrls: ['./core-dropdown.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      multi: true,\r\n      useExisting: CoreDropdownComponent,\r\n    },\r\n  ],\r\n})\r\nexport class CoreDropdownComponent extends CoreFormControlBaseComponent implements OnInit, AfterViewInit, OnDestroy, OnChanges {\r\n  ngControl!: NgControl;\r\n\r\n  @Input() getByIdObject$!: BehaviorSubject<any>;\r\n  @Input() paramMode!: boolean;\r\n  @Input() shownFrom!: string; // take this field from GetById response innerBody to bind to the text\r\n  @Input() options$!: BehaviorSubject<ICoreDropdownOption[]>;\r\n  @Input() height!: string;\r\n  @Input() placeholder: string = 'UI_COMMON_PLACE_HOLDER_SEARCH_HERE';\r\n  @Input() loading!: boolean;\r\n  @Input() warningDisable!: boolean;\r\n  @Input() clearDisable!: boolean;\r\n  @Input() fitHeightWithItemCount: boolean = true;\r\n  @Input() itemHeight!: number;\r\n  @ViewChild('container') container!: ElementRef;\r\n\r\n  listenerFn!: () => void;\r\n\r\n  options!: ICoreDropdownOption[];\r\n\r\n  localOptions!: ICoreDropdownOption[];\r\n  override value!: string | number | null;\r\n\r\n  lang!: string;\r\n  placeholderText!: string;\r\n  text!: string;\r\n  searchText!: string;\r\n  //searchHeight: number = 38;\r\n  searchHeight: number = 0;\r\n  expandState!: boolean;\r\n\r\n  subscriptions: Subscription[] = [];\r\n\r\n  constructor(\r\n    private renderer: Renderer2,\r\n    private domService: DomService,\r\n    private alertService: AlertService,\r\n    private injector: Injector,\r\n    private mls: MultiLanguageService,\r\n  ) {\r\n    super();\r\n\r\n  }\r\n\r\n  ngOnInit(): void {\r\n\r\n    if (!!!this.itemHeight) this.itemHeight = 40;\r\n\r\n    this.ngControl = this.injector.get(NgControl);\r\n\r\n    /* START: CHECK INPUT ERROR */\r\n    if (!!!this.options$ && isDevMode() && !!!this.warningDisable) {\r\n      this.alertService.error(\r\n        `\r\n        CoreDropdownComponent required this input: options$!: BehaviorSubject<ICoreDropdownOption[]>;\r\n        Also, it needs to receive a new value that usually comes from and API GetAll() action\r\n        `,\r\n        noneAutoClosedAlertOptions,\r\n      );\r\n    }\r\n\r\n    if (!!!this.paramMode) {\r\n      //getByIdObject$\r\n      if (!!!this.getByIdObject$ && isDevMode() && !!!this.warningDisable) {\r\n        this.alertService.error(\r\n          `CoreDropdownComponent Error: Required inputs:\r\n                getByIdObject$: BehaviorSubject&lt;any&gt; (for '${this.ngControl.name}')`,\r\n        );\r\n      }\r\n\r\n      if (!!!this.shownFrom && isDevMode() && !!!this.warningDisable) {\r\n        this.alertService.error(\r\n          `CoreDropdownComponent Error: Required inputs:\r\n              shownFrom: string; (for '${this.ngControl.name}')`,\r\n          noneAutoClosedAlertOptions,\r\n        );\r\n      }\r\n    }\r\n\r\n    /* END: CHECK INPUT ERROR */\r\n\r\n    this.subscriptions.push(\r\n      this.options$.subscribe((x) => {\r\n        this.options = x;\r\n        this.localOptions = x;\r\n        // in scenario when getByIdObject$ has not run\r\n        if (!!this.value) {\r\n          if (!this.text) {\r\n            this.text = this.options?.filter(m => m.value === this.value)[0]?.text\r\n          }\r\n        }\r\n      }),\r\n    );\r\n\r\n    this.subscriptions.push(\r\n      this.getByIdObject$?.subscribe((x) => {\r\n        if (!!x) {\r\n          this.text = x[this.shownFrom];\r\n        } else {\r\n          this.text = '';\r\n        }\r\n      }),\r\n    );\r\n\r\n    this.subscriptions.push(\r\n      this.mls.lang$.subscribe(x => {\r\n        this.lang = x;\r\n        this.placeholderText = this.mls.trans(this.placeholder, x)\r\n      })\r\n    )\r\n\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    /**\r\n     * This events get called by all clicks on the page\r\n     */\r\n    this.listenerFn = this.renderer.listen('window', 'click', (e: Event) => {\r\n      /*\r\n       * handle click outside\r\n       */\r\n      if (this.container && !!!this.container.nativeElement.contains(e.target)) {\r\n        this.expandState = false;\r\n        this.searchText = '';\r\n        this.localOptions = this.options$.value;\r\n      }\r\n    });\r\n\r\n    const maxZIndex = this.domService.getMaxZIndex();\r\n    this.container.nativeElement.style.setProperty('--max-z-index', maxZIndex + 1);\r\n    this.container.nativeElement.style.setProperty('--search-height', this.searchHeight + 'px');\r\n    this.container.nativeElement.style.setProperty('--item-height', this.itemHeight + 'px');\r\n    if (!!this.height) this.container.nativeElement.style.setProperty('--height', this.height);\r\n  }\r\n\r\n  override writeValue(obj: string | number | null): void {\r\n    this.value = obj;\r\n    const filter = this.options?.filter(m => m.value === obj)\r\n    if (!!filter?.length) {\r\n      this.text = this.options.filter(m => m.value === obj)[0].text\r\n    } else {\r\n      this.text = \"\"\r\n    }\r\n\r\n  }\r\n\r\n  onSearchTextChange(value: string) {\r\n    this.localOptions = this.options.filter((x) => x.text.toLowerCase().indexOf(value.toLocaleLowerCase()) >= 0);\r\n  }\r\n\r\n  onListItemClick(option: ICoreDropdownOption): void {\r\n    if (this.disabled) return;\r\n    this.writeValue(option.value)\r\n    // this.text = option.text;\r\n    this.markAsTouched(); // do this before onChange\r\n    this.onChange(option.value);\r\n    this.expandState = false;\r\n  }\r\n\r\n  toggleExpanded(): void {\r\n    if (this.disabled || this.readonly) return;\r\n    this.expandState = !!!this.expandState;\r\n    setTimeout(() => this.container.nativeElement.querySelector('.in-place-search')?.focus())\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (!!!changes['options']) return;\r\n    this.localOptions = changes['options']?.currentValue;\r\n  }\r\n\r\n  onClickClear() {\r\n    this.writeValue(null);\r\n    this.markAsTouched();\r\n    this.onChange(null);\r\n  }\r\n\r\n  changeFocus(): void {\r\n    const liElement = this.container?.nativeElement.querySelector('.item-li');\r\n    if (liElement) {\r\n      liElement.setAttribute('tabindex', '0'); // Make it focusable\r\n      liElement.focus();\r\n      liElement.classList.add('hover-effect');\r\n\r\n      // Remove hover effect when focus is lost\r\n      liElement.addEventListener('blur', () => {\r\n        liElement.classList.remove('hover-effect');\r\n      }, { once: true }); // Only listen once\r\n\r\n      setTimeout(() => liElement.classList.remove('hover-effect'), 1000)\r\n    }\r\n  }\r\n\r\n  currentIndex: number = 0;\r\n  navigateList(event: KeyboardEvent): void {\r\n    const items: NodeListOf<HTMLElement> = this.container?.nativeElement.querySelectorAll('.item-li');\r\n    if (!items || items.length === 0) return;\r\n\r\n    // Remove hover effect from current item\r\n    items[this.currentIndex]?.classList.remove('hover-effect');\r\n\r\n    // Navigate based on the key pressed\r\n    if (event.key === 'ArrowDown') {\r\n      this.currentIndex = (this.currentIndex + 1) % items.length; // Wrap around at the end\r\n    } else if (event.key === 'ArrowUp') {\r\n      this.currentIndex = (this.currentIndex - 1 + items.length) % items.length; // Wrap around at the beginning\r\n    } else {\r\n      return; // Exit if it's not an Arrow key\r\n    }\r\n\r\n    // Focus and add hover effect to the new item\r\n    const newItem = items[this.currentIndex];\r\n    newItem.setAttribute('tabindex', '0'); // Ensure it's focusable\r\n    newItem.focus();\r\n    newItem.classList.add('hover-effect');\r\n  }\r\n\r\n  onDropdownKeydown(event: KeyboardEvent): void {\r\n    if (event.key === 'ArrowUp' || event.key === 'ArrowDown') {\r\n      event.preventDefault(); // Prevent default scrolling behavior\r\n      this.navigateList(event);\r\n    }\r\n  }\r\n\r\n  onListItemKeydown(context: any, e: KeyboardEvent): void {\r\n    if (e.key === 'Enter') {\r\n      this.onListItemClick(context);\r\n    }\r\n  }\r\n\r\n  onInPlaceSearchKeydown(e: KeyboardEvent) {\r\n    e.stopPropagation();\r\n    if (e.key === 'Tab') {\r\n      this.currentIndex = 0;\r\n      e.preventDefault();\r\n      setTimeout(() => this.changeFocus(), 10)\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    if (this.listenerFn) this.listenerFn();\r\n    this.subscriptions.map((x) => x?.unsubscribe());\r\n  }\r\n}\r\n","<app-threedots *ngIf=\"loading\"></app-threedots>\r\n<div #container class=\"core-dropdown-container\" *ngIf=\"!loading\">\r\n  <input type=\"checkbox\" class=\"expand-state\" [(ngModel)]=\"expandState\" />\r\n\r\n  <div class=\"input-wrapper\">\r\n    <input class=\"value\" [value]=\"value\" />\r\n    <input class=\"in-place-search form-control\" type=\"text\" [placeholder]=\"placeholderText\" [(ngModel)]=\"searchText\"\r\n      (ngModelChange)=\"onSearchTextChange($event)\" autocomplete=\"false\" [class.form-control-disabled]=\"disabled\"\r\n      [disabled]=\"disabled\" (keydown)=\"onInPlaceSearchKeydown($event)\" />\r\n    <label type=\"text\" class=\"text form-control\" [class.form-control-disabled]=\"disabled\" (click)=\"toggleExpanded()\">\r\n      <span [appTooltip]=\"text\">{{ !!loading ? \"...\" : (text | translate : lang) }}</span>\r\n      <div class=\"icon\">\r\n        <i class=\"feather-chevron-down\"></i>\r\n      </div>\r\n    </label>\r\n    @if (!clearDisable) {\r\n    <div class=\"clear-icon-wrapper\" [class.d-none]=\"!!disabled || !!!value\" (click)=\"onClickClear()\">\r\n      <div class=\"flex-wrapper\" [appTooltip]=\"'UI.CORE_CONTOL_COMMON_CLEAR' | translate : lang\">\r\n        <i class=\"feather-x\"></i>\r\n      </div>\r\n    </div>\r\n    }\r\n  </div>\r\n\r\n  <div class=\"dropdown\" [class.form-control-disabled]=\"disabled\" *ngIf=\"!!expandState\" (keydown)=\"onDropdownKeydown($event)\">\r\n    <input class=\"search d-none\" type=\"text\" [placeholder]=\"placeholderText\" [(ngModel)]=\"searchText\"\r\n      (ngModelChange)=\"onSearchTextChange($event)\" autocomplete=\"false\" [class.form-control-disabled]=\"disabled\"\r\n      [disabled]=\"disabled\" />\r\n    <core-scroll [localOptions]=\"localOptions\" [itemTemplate]=\"itemTemplateRef\" [itemCount]=\"localOptions.length\"\r\n      [height]=\"(fitHeightWithItemCount && localOptions.length * itemHeight < 400) ? localOptions.length * itemHeight : 400 - searchHeight\" [childHeight]=\"itemHeight\"></core-scroll>\r\n  </div>\r\n</div>\r\n\r\n<ng-template #itemTemplateRef let-context=\"context\">\r\n  <li class=\"item-li\" (click)=\"onListItemClick(context)\" (keydown)=\"onListItemKeydown(context, $event)\" [ngStyle]=\"{ height: itemHeight + 'px' }\">\r\n    <label [ngStyle]=\"{\r\n        width: '100%',\r\n        overflow: 'hidden',\r\n        textOverflow: 'ellipsis',\r\n        whiteSpace: 'nowrap'\r\n      }\" [appTooltip]=\"context.text\">{{ context.text | translate : lang }}</label>\r\n  </li>\r\n</ng-template>"]}
@@ -163,24 +163,34 @@ export class CoreFormComponent {
163
163
  this.onCancal.emit(null);
164
164
  }
165
165
  updatePayload() {
166
- this.payLoad = JSON.stringify(this.form?.getRawValue(), null, 2);
166
+ if (this.payLoad === '') {
167
+ this.payLoad = JSON.stringify(this.form?.getRawValue(), null, 2);
168
+ }
169
+ else {
170
+ this.payLoad = '';
171
+ }
167
172
  }
168
173
  updateValidorOverview() {
169
- const result = [];
170
- Object.keys(this.form.controls).forEach((key) => {
171
- const control = this.form.get(key);
172
- const errors = [];
173
- if (!!control.invalid) {
174
- Object.keys(control.errors).forEach((key) => {
175
- errors.push(key);
174
+ if (this.validatorOverview === undefined) {
175
+ const result = [];
176
+ Object.keys(this.form.controls).forEach((key) => {
177
+ const control = this.form.get(key);
178
+ const errors = [];
179
+ if (!!control.invalid) {
180
+ Object.keys(control.errors).forEach((key) => {
181
+ errors.push(key);
182
+ });
183
+ }
184
+ result.push({
185
+ key,
186
+ errors,
176
187
  });
177
- }
178
- result.push({
179
- key,
180
- errors,
181
188
  });
182
- });
183
- this.validatorOverview = JSON.stringify(result, null, 2);
189
+ this.validatorOverview = JSON.stringify(result, null, 2);
190
+ }
191
+ else {
192
+ this.validatorOverview = undefined;
193
+ }
184
194
  }
185
195
  ngOnDestroy() {
186
196
  this.subscriptions.map((x) => x?.unsubscribe());
@@ -208,7 +218,7 @@ export class CoreFormComponent {
208
218
  this.buttonClick.emit(e);
209
219
  }
210
220
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: CoreFormComponent, deps: [{ token: i1.CoreControlService }, { token: i2.MultiLanguageService }, { token: i3.AlertService }, { token: i4.CoreFormService }, { token: i5.AppConfigService }], target: i0.ɵɵFactoryTarget.Component }); }
211
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.3", type: CoreFormComponent, isStandalone: true, selector: "core-form", inputs: { formName: "formName", width: "width", submitText: "submitText", leftInputSections: "leftInputSections", leftInputSectionsFlexSize: "leftInputSectionsFlexSize", inputSections: "inputSections", mode$: "mode$", bottomTemplateRef: "bottomTemplateRef", customFormButtonItems: "customFormButtonItems", showCaptionButton: "showCaptionButton", disableSaveButton: "disableSaveButton", checkError$: "checkError$" }, outputs: { onFormCreated: "onFormCreated", onFormRefCreated: "onFormRefCreated", onSubmit: "onSubmit", onSave: "onSave", onCancal: "onCancal", buttonClick: "buttonClick" }, viewQueries: [{ propertyName: "formRef", first: true, predicate: ["formRef"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "@if (!!form) {\r\n<div class=\"core-form-container\" [ngStyle]=\"{\r\n width: !!width ? width + 'px' : 'auto'\r\n}\">\r\n\r\n <form #formRef (ngSubmit)=\"onFormSubmit()\" [formGroup]=\"form\" autocomplete=\"off\">\r\n\r\n <div class=\"row\">\r\n\r\n @if (!!leftInputSections) {\r\n <div [class]=\"'col-md-' + (leftInputSectionsFlexSize || 0)\">\r\n\r\n @for (section of leftInputSections; track $index) {\r\n <div class=\"section\"\r\n [class.d-none]=\"(!!isUpdateMode && section.addModeOnly) || (!!!isUpdateMode && section.updateModeOnly) || !!section.hidden\">\r\n\r\n @if (!!section.caption) {\r\n <div class=\"section-header-label\">\r\n <div class=\"section-img-wrapper\">\r\n <div class=\"section-img\"></div>\r\n </div>\r\n <div class=\"section-caption\">{{ section.caption | translate: lang }}</div>\r\n </div>\r\n }\r\n\r\n @for (row of section.rows; track $index) {\r\n <div class=\"row mb15\">\r\n @for (col of row; track $index) {\r\n <div [class]=\"'col-md-' + col.flexSize\" [class.grid-buffer]=\"col.controlType==='GRIDBUFFER'\"\r\n [class.button-control]=\"col.controlType==='BUTTON'\">\r\n <core-control [control]=\"col\" [form]=\"form\" [checkError$]=\"checkError$\"></core-control>\r\n </div>\r\n }\r\n </div>\r\n }\r\n\r\n </div>\r\n\r\n }\r\n\r\n </div>\r\n }\r\n\r\n <div [class]=\"'col-md-' + (12 - (leftInputSectionsFlexSize || 0))\">\r\n\r\n @for (section of sections; track $index) {\r\n <div class=\"section\"\r\n [class.d-none]=\"(!!isUpdateMode && section.addModeOnly) || (!!!isUpdateMode && section.updateModeOnly) || !!section.hidden\" [ngStyle]=\"{\r\n maxWidth: !!section.maxWidth ? section.maxWidth + 'px' : 'none'\r\n }\">\r\n\r\n @if (!!section.caption) {\r\n <div class=\"section-header-label\">\r\n <div class=\"section-img-wrapper\">\r\n <div class=\"section-img\"></div>\r\n </div>\r\n <div class=\"section-caption\">{{ section.caption | translate: lang }}</div>\r\n </div>\r\n }\r\n\r\n @for (row of section.rows; track $index) {\r\n <div class=\"row mb15\">\r\n @for (col of row; track $index) {\r\n <div [class]=\"'col-md-' + col.flexSize\" [class.grid-buffer]=\"col.controlType==='GRIDBUFFER'\"\r\n [class.button-control]=\"col.controlType==='BUTTON'\">\r\n <core-control [control]=\"col\" [form]=\"form\" [checkError$]=\"checkError$\"></core-control>\r\n </div>\r\n }\r\n </div>\r\n }\r\n\r\n </div>\r\n }\r\n\r\n </div>\r\n\r\n @if (!!bottomTemplateRef) {\r\n <div class=\"col-md-12\">\r\n <div class=\"bottom-template-wrapper\">\r\n <ng-container *ngTemplateOutlet=\"bottomTemplateRef\"></ng-container>\r\n </div>\r\n </div>\r\n }\r\n\r\n </div>\r\n\r\n <div class=\"h10\"></div>\r\n\r\n <div class=\"form-row\">\r\n\r\n <core-button-group-vns [showCaption]=\"showCaptionButton\" [forHeader]=\"false\"\r\n (buttonClick)=\"onButtonClick($event)\" [shownItems]=\"buttonItems\"\r\n class=\"buttonGroupCustom\"></core-button-group-vns>\r\n </div>\r\n @if (isDevMode) {\r\n <div class=\"form-row d-flex d-flex-center\">\r\n <div class=\"dev-button\" (click)=\"updatePayload()\">Show\r\n values</div>\r\n <div class=\"dev-button\" (click)=\"updateValidorOverview()\">Show\r\n validators</div>\r\n </div>\r\n }\r\n\r\n </form>\r\n\r\n @if (!!payLoad && isDevMode) {\r\n <div class=\"form-row payload-preview\">\r\n <strong>Current values</strong><br>{{payLoad}}\r\n </div>\r\n }\r\n\r\n @if (!!validatorOverview && isDevMode) {\r\n <div class=\"form-row payload-preview\">\r\n <strong>Current errors</strong><br>{{validatorOverview}}\r\n </div>\r\n }\r\n\r\n</div>\r\n}", styles: [".core-form-container{overflow-x:visible}.core-form-container>form .section{margin-top:var(--size-layout-block-cell-spacing)}.core-form-container>form .section:not(:first-child){margin-top:calc(var(--size-layout-block-cell-spacing) * 2)}.core-form-container>form .section .section-header-label{display:block;height:34px;line-height:34px;margin-bottom:15px;margin-left:12px}.core-form-container>form .section .section-header-label .section-img-wrapper{position:relative}.core-form-container>form .section .section-header-label .section-img-wrapper .section-img{position:absolute;width:34px;height:34px;border-radius:50%;background-color:#d3d3d3;float:left;background-image:url(/assets/images/info.svg);background-repeat:no-repeat;background-position:center}.core-form-container>form .section .section-header-label .section-caption{padding-left:40px;font-weight:700;color:#696969}.core-form-container .row{margin-left:var(--size-layout-block-cell-spacing) 0px;margin-right:var(--size-layout-block-cell-spacing) 0px}.core-form-container .row .grid-buffer{border:dotted 2px darkgray}.core-form-container .row .button-control{display:flex;align-items:flex-end}.core-form-container .form-row{margin:var(--size-layout-block-cell-spacing) 0px;display:flex;align-items:center;justify-content:center}.core-form-container .form-row>button{cursor:pointer;border-radius:0}.core-form-container .form-row>button:not(:first-child){margin-left:var(--size-layout-block-cell-spacing)}.core-form-container .dev-button{cursor:pointer;display:flex;align-items:center;border:1px gray solid;font-size:13px;padding:8px}.core-form-container .payload-preview{display:block;width:100%;height:200px;white-space:pre-wrap;overflow-x:hidden;overflow-y:auto;color:gray!important;background-color:transparent!important}.core-form-container .bottom-template-wrapper{padding-left:12px;padding-right:12px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i6.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i7.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i7.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i7.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: CoreControlComponent, selector: "core-control", inputs: ["control", "form", "checkError$", "rangeLimit"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "component", type: CoreButtonGroupVnsComponent, selector: "core-button-group-vns", inputs: ["height", "instanceNumber", "forHeader", "fixedShow", "shownItems", "showCaption", "lastChildEffectOff"], outputs: ["buttonClick"] }] }); }
221
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.3", type: CoreFormComponent, isStandalone: true, selector: "core-form", inputs: { formName: "formName", width: "width", submitText: "submitText", leftInputSections: "leftInputSections", leftInputSectionsFlexSize: "leftInputSectionsFlexSize", inputSections: "inputSections", mode$: "mode$", bottomTemplateRef: "bottomTemplateRef", customFormButtonItems: "customFormButtonItems", showCaptionButton: "showCaptionButton", disableSaveButton: "disableSaveButton", checkError$: "checkError$" }, outputs: { onFormCreated: "onFormCreated", onFormRefCreated: "onFormRefCreated", onSubmit: "onSubmit", onSave: "onSave", onCancal: "onCancal", buttonClick: "buttonClick" }, viewQueries: [{ propertyName: "formRef", first: true, predicate: ["formRef"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "@if (!!form) {\r\n<div class=\"core-form-container\" [ngStyle]=\"{\r\n width: !!width ? width + 'px' : 'auto'\r\n}\">\r\n\r\n <form #formRef (ngSubmit)=\"onFormSubmit()\" [formGroup]=\"form\" autocomplete=\"off\">\r\n\r\n <div class=\"row\">\r\n\r\n @if (!!leftInputSections) {\r\n <div [class]=\"'col-md-' + (leftInputSectionsFlexSize || 0)\">\r\n\r\n @for (section of leftInputSections; track $index) {\r\n <div class=\"section\"\r\n [class.d-none]=\"(!!isUpdateMode && section.addModeOnly) || (!!!isUpdateMode && section.updateModeOnly) || !!section.hidden\">\r\n\r\n @if (!!section.caption) {\r\n <div class=\"section-header-label\">\r\n <div class=\"section-img-wrapper\">\r\n <div class=\"section-img\"></div>\r\n </div>\r\n <div class=\"section-caption\">{{ section.caption | translate: lang }}</div>\r\n </div>\r\n }\r\n\r\n @for (row of section.rows; track $index) {\r\n <div class=\"row mb15\">\r\n @for (col of row; track $index) {\r\n <div [class]=\"'col-md-' + col.flexSize\" [class.grid-buffer]=\"col.controlType==='GRIDBUFFER'\"\r\n [class.button-control]=\"col.controlType==='BUTTON'\">\r\n <core-control [control]=\"col\" [form]=\"form\" [checkError$]=\"checkError$\"></core-control>\r\n </div>\r\n }\r\n </div>\r\n }\r\n\r\n </div>\r\n\r\n }\r\n\r\n </div>\r\n }\r\n\r\n <div [class]=\"'col-md-' + (12 - (leftInputSectionsFlexSize || 0))\">\r\n\r\n @for (section of sections; track $index) {\r\n <div class=\"section\"\r\n [class.d-none]=\"(!!isUpdateMode && section.addModeOnly) || (!!!isUpdateMode && section.updateModeOnly) || !!section.hidden\" [ngStyle]=\"{\r\n maxWidth: !!section.maxWidth ? section.maxWidth + 'px' : 'none'\r\n }\">\r\n\r\n @if (!!section.caption) {\r\n <div class=\"section-header-label\">\r\n <div class=\"section-img-wrapper\">\r\n <div class=\"section-img\"></div>\r\n </div>\r\n <div class=\"section-caption\">{{ section.caption | translate: lang }}</div>\r\n </div>\r\n }\r\n\r\n @for (row of section.rows; track $index) {\r\n <div class=\"row mb15\">\r\n @for (col of row; track $index) {\r\n <div [class]=\"'col-md-' + col.flexSize\" [class.grid-buffer]=\"col.controlType==='GRIDBUFFER'\"\r\n [class.button-control]=\"col.controlType==='BUTTON'\">\r\n <core-control [control]=\"col\" [form]=\"form\" [checkError$]=\"checkError$\"></core-control>\r\n </div>\r\n }\r\n </div>\r\n }\r\n\r\n </div>\r\n }\r\n\r\n </div>\r\n\r\n @if (!!bottomTemplateRef) {\r\n <div class=\"col-md-12\">\r\n <div class=\"bottom-template-wrapper\">\r\n <ng-container *ngTemplateOutlet=\"bottomTemplateRef\"></ng-container>\r\n </div>\r\n </div>\r\n }\r\n\r\n </div>\r\n\r\n <div class=\"h10\"></div>\r\n\r\n <div class=\"form-row\">\r\n <div class=\"d-flex d-flex-end w-100 pr18\">\r\n <core-button-group-vns [showCaption]=\"showCaptionButton\" [forHeader]=\"false\"\r\n (buttonClick)=\"onButtonClick($event)\" [shownItems]=\"buttonItems\"\r\n class=\"buttonGroupCustom\"></core-button-group-vns>\r\n </div>\r\n </div>\r\n @if (isDevMode) {\r\n <div class=\"form-row d-flex d-flex-center\">\r\n <div class=\"dev-button\" (click)=\"updatePayload()\">Show\r\n values</div>\r\n <div class=\"dev-button\" (click)=\"updateValidorOverview()\">Show\r\n validators</div>\r\n </div>\r\n }\r\n\r\n </form>\r\n\r\n @if (!!payLoad && isDevMode) {\r\n <div class=\"form-row payload-preview\">\r\n <strong>Current values</strong><br>{{payLoad}}\r\n </div>\r\n }\r\n\r\n @if (!!validatorOverview && isDevMode) {\r\n <div class=\"form-row payload-preview validator-preview\">\r\n <strong>Current errors</strong><br>{{validatorOverview}}\r\n </div>\r\n }\r\n\r\n</div>\r\n}", styles: [".core-form-container{overflow-x:visible}.core-form-container>form .section{margin-top:var(--size-layout-block-cell-spacing)}.core-form-container>form .section:not(:first-child){margin-top:calc(var(--size-layout-block-cell-spacing) * 2)}.core-form-container>form .section .section-header-label{display:block;height:34px;line-height:34px;margin-bottom:15px;margin-left:12px}.core-form-container>form .section .section-header-label .section-img-wrapper{position:relative}.core-form-container>form .section .section-header-label .section-img-wrapper .section-img{position:absolute;width:34px;height:34px;border-radius:50%;background-color:#d3d3d3;float:left;background-image:url(/assets/images/info.svg);background-repeat:no-repeat;background-position:center}.core-form-container>form .section .section-header-label .section-caption{padding-left:40px;font-weight:700;color:#696969}.core-form-container .row{margin-left:var(--size-layout-block-cell-spacing) 0px;margin-right:var(--size-layout-block-cell-spacing) 0px}.core-form-container .row .grid-buffer{border:dotted 2px darkgray}.core-form-container .row .button-control{display:flex;align-items:flex-end}.core-form-container .form-row{margin:var(--size-layout-block-cell-spacing) 0px;display:flex;align-items:center;justify-content:center}.core-form-container .form-row>button{cursor:pointer;border-radius:0}.core-form-container .form-row>button:not(:first-child){margin-left:var(--size-layout-block-cell-spacing)}.core-form-container .dev-button{cursor:pointer;display:flex;align-items:center;border:1px gray solid;font-size:13px;padding:8px}.core-form-container .payload-preview{display:block;width:calc(100% - 48px);height:200px;white-space:pre-wrap;overflow-x:hidden;overflow-y:auto;color:gray!important;background-color:#dff6dd;padding:24px;margin:24px}.core-form-container .payload-preview.validator-preview{background-color:#fff4ce}.core-form-container .bottom-template-wrapper{padding-left:12px;padding-right:12px}.core-form-container .w-100{width:100%}.core-form-container .pr18{padding-right:18px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i6.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i7.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i7.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i7.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: CoreControlComponent, selector: "core-control", inputs: ["control", "form", "checkError$", "rangeLimit"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "component", type: CoreButtonGroupVnsComponent, selector: "core-button-group-vns", inputs: ["height", "instanceNumber", "forHeader", "fixedShow", "shownItems", "showCaption", "lastChildEffectOff"], outputs: ["buttonClick"] }] }); }
212
222
  }
213
223
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: CoreFormComponent, decorators: [{
214
224
  type: Component,
@@ -219,7 +229,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
219
229
  CoreControlComponent,
220
230
  TranslatePipe,
221
231
  CoreButtonGroupVnsComponent
222
- ], template: "@if (!!form) {\r\n<div class=\"core-form-container\" [ngStyle]=\"{\r\n width: !!width ? width + 'px' : 'auto'\r\n}\">\r\n\r\n <form #formRef (ngSubmit)=\"onFormSubmit()\" [formGroup]=\"form\" autocomplete=\"off\">\r\n\r\n <div class=\"row\">\r\n\r\n @if (!!leftInputSections) {\r\n <div [class]=\"'col-md-' + (leftInputSectionsFlexSize || 0)\">\r\n\r\n @for (section of leftInputSections; track $index) {\r\n <div class=\"section\"\r\n [class.d-none]=\"(!!isUpdateMode && section.addModeOnly) || (!!!isUpdateMode && section.updateModeOnly) || !!section.hidden\">\r\n\r\n @if (!!section.caption) {\r\n <div class=\"section-header-label\">\r\n <div class=\"section-img-wrapper\">\r\n <div class=\"section-img\"></div>\r\n </div>\r\n <div class=\"section-caption\">{{ section.caption | translate: lang }}</div>\r\n </div>\r\n }\r\n\r\n @for (row of section.rows; track $index) {\r\n <div class=\"row mb15\">\r\n @for (col of row; track $index) {\r\n <div [class]=\"'col-md-' + col.flexSize\" [class.grid-buffer]=\"col.controlType==='GRIDBUFFER'\"\r\n [class.button-control]=\"col.controlType==='BUTTON'\">\r\n <core-control [control]=\"col\" [form]=\"form\" [checkError$]=\"checkError$\"></core-control>\r\n </div>\r\n }\r\n </div>\r\n }\r\n\r\n </div>\r\n\r\n }\r\n\r\n </div>\r\n }\r\n\r\n <div [class]=\"'col-md-' + (12 - (leftInputSectionsFlexSize || 0))\">\r\n\r\n @for (section of sections; track $index) {\r\n <div class=\"section\"\r\n [class.d-none]=\"(!!isUpdateMode && section.addModeOnly) || (!!!isUpdateMode && section.updateModeOnly) || !!section.hidden\" [ngStyle]=\"{\r\n maxWidth: !!section.maxWidth ? section.maxWidth + 'px' : 'none'\r\n }\">\r\n\r\n @if (!!section.caption) {\r\n <div class=\"section-header-label\">\r\n <div class=\"section-img-wrapper\">\r\n <div class=\"section-img\"></div>\r\n </div>\r\n <div class=\"section-caption\">{{ section.caption | translate: lang }}</div>\r\n </div>\r\n }\r\n\r\n @for (row of section.rows; track $index) {\r\n <div class=\"row mb15\">\r\n @for (col of row; track $index) {\r\n <div [class]=\"'col-md-' + col.flexSize\" [class.grid-buffer]=\"col.controlType==='GRIDBUFFER'\"\r\n [class.button-control]=\"col.controlType==='BUTTON'\">\r\n <core-control [control]=\"col\" [form]=\"form\" [checkError$]=\"checkError$\"></core-control>\r\n </div>\r\n }\r\n </div>\r\n }\r\n\r\n </div>\r\n }\r\n\r\n </div>\r\n\r\n @if (!!bottomTemplateRef) {\r\n <div class=\"col-md-12\">\r\n <div class=\"bottom-template-wrapper\">\r\n <ng-container *ngTemplateOutlet=\"bottomTemplateRef\"></ng-container>\r\n </div>\r\n </div>\r\n }\r\n\r\n </div>\r\n\r\n <div class=\"h10\"></div>\r\n\r\n <div class=\"form-row\">\r\n\r\n <core-button-group-vns [showCaption]=\"showCaptionButton\" [forHeader]=\"false\"\r\n (buttonClick)=\"onButtonClick($event)\" [shownItems]=\"buttonItems\"\r\n class=\"buttonGroupCustom\"></core-button-group-vns>\r\n </div>\r\n @if (isDevMode) {\r\n <div class=\"form-row d-flex d-flex-center\">\r\n <div class=\"dev-button\" (click)=\"updatePayload()\">Show\r\n values</div>\r\n <div class=\"dev-button\" (click)=\"updateValidorOverview()\">Show\r\n validators</div>\r\n </div>\r\n }\r\n\r\n </form>\r\n\r\n @if (!!payLoad && isDevMode) {\r\n <div class=\"form-row payload-preview\">\r\n <strong>Current values</strong><br>{{payLoad}}\r\n </div>\r\n }\r\n\r\n @if (!!validatorOverview && isDevMode) {\r\n <div class=\"form-row payload-preview\">\r\n <strong>Current errors</strong><br>{{validatorOverview}}\r\n </div>\r\n }\r\n\r\n</div>\r\n}", styles: [".core-form-container{overflow-x:visible}.core-form-container>form .section{margin-top:var(--size-layout-block-cell-spacing)}.core-form-container>form .section:not(:first-child){margin-top:calc(var(--size-layout-block-cell-spacing) * 2)}.core-form-container>form .section .section-header-label{display:block;height:34px;line-height:34px;margin-bottom:15px;margin-left:12px}.core-form-container>form .section .section-header-label .section-img-wrapper{position:relative}.core-form-container>form .section .section-header-label .section-img-wrapper .section-img{position:absolute;width:34px;height:34px;border-radius:50%;background-color:#d3d3d3;float:left;background-image:url(/assets/images/info.svg);background-repeat:no-repeat;background-position:center}.core-form-container>form .section .section-header-label .section-caption{padding-left:40px;font-weight:700;color:#696969}.core-form-container .row{margin-left:var(--size-layout-block-cell-spacing) 0px;margin-right:var(--size-layout-block-cell-spacing) 0px}.core-form-container .row .grid-buffer{border:dotted 2px darkgray}.core-form-container .row .button-control{display:flex;align-items:flex-end}.core-form-container .form-row{margin:var(--size-layout-block-cell-spacing) 0px;display:flex;align-items:center;justify-content:center}.core-form-container .form-row>button{cursor:pointer;border-radius:0}.core-form-container .form-row>button:not(:first-child){margin-left:var(--size-layout-block-cell-spacing)}.core-form-container .dev-button{cursor:pointer;display:flex;align-items:center;border:1px gray solid;font-size:13px;padding:8px}.core-form-container .payload-preview{display:block;width:100%;height:200px;white-space:pre-wrap;overflow-x:hidden;overflow-y:auto;color:gray!important;background-color:transparent!important}.core-form-container .bottom-template-wrapper{padding-left:12px;padding-right:12px}\n"] }]
232
+ ], template: "@if (!!form) {\r\n<div class=\"core-form-container\" [ngStyle]=\"{\r\n width: !!width ? width + 'px' : 'auto'\r\n}\">\r\n\r\n <form #formRef (ngSubmit)=\"onFormSubmit()\" [formGroup]=\"form\" autocomplete=\"off\">\r\n\r\n <div class=\"row\">\r\n\r\n @if (!!leftInputSections) {\r\n <div [class]=\"'col-md-' + (leftInputSectionsFlexSize || 0)\">\r\n\r\n @for (section of leftInputSections; track $index) {\r\n <div class=\"section\"\r\n [class.d-none]=\"(!!isUpdateMode && section.addModeOnly) || (!!!isUpdateMode && section.updateModeOnly) || !!section.hidden\">\r\n\r\n @if (!!section.caption) {\r\n <div class=\"section-header-label\">\r\n <div class=\"section-img-wrapper\">\r\n <div class=\"section-img\"></div>\r\n </div>\r\n <div class=\"section-caption\">{{ section.caption | translate: lang }}</div>\r\n </div>\r\n }\r\n\r\n @for (row of section.rows; track $index) {\r\n <div class=\"row mb15\">\r\n @for (col of row; track $index) {\r\n <div [class]=\"'col-md-' + col.flexSize\" [class.grid-buffer]=\"col.controlType==='GRIDBUFFER'\"\r\n [class.button-control]=\"col.controlType==='BUTTON'\">\r\n <core-control [control]=\"col\" [form]=\"form\" [checkError$]=\"checkError$\"></core-control>\r\n </div>\r\n }\r\n </div>\r\n }\r\n\r\n </div>\r\n\r\n }\r\n\r\n </div>\r\n }\r\n\r\n <div [class]=\"'col-md-' + (12 - (leftInputSectionsFlexSize || 0))\">\r\n\r\n @for (section of sections; track $index) {\r\n <div class=\"section\"\r\n [class.d-none]=\"(!!isUpdateMode && section.addModeOnly) || (!!!isUpdateMode && section.updateModeOnly) || !!section.hidden\" [ngStyle]=\"{\r\n maxWidth: !!section.maxWidth ? section.maxWidth + 'px' : 'none'\r\n }\">\r\n\r\n @if (!!section.caption) {\r\n <div class=\"section-header-label\">\r\n <div class=\"section-img-wrapper\">\r\n <div class=\"section-img\"></div>\r\n </div>\r\n <div class=\"section-caption\">{{ section.caption | translate: lang }}</div>\r\n </div>\r\n }\r\n\r\n @for (row of section.rows; track $index) {\r\n <div class=\"row mb15\">\r\n @for (col of row; track $index) {\r\n <div [class]=\"'col-md-' + col.flexSize\" [class.grid-buffer]=\"col.controlType==='GRIDBUFFER'\"\r\n [class.button-control]=\"col.controlType==='BUTTON'\">\r\n <core-control [control]=\"col\" [form]=\"form\" [checkError$]=\"checkError$\"></core-control>\r\n </div>\r\n }\r\n </div>\r\n }\r\n\r\n </div>\r\n }\r\n\r\n </div>\r\n\r\n @if (!!bottomTemplateRef) {\r\n <div class=\"col-md-12\">\r\n <div class=\"bottom-template-wrapper\">\r\n <ng-container *ngTemplateOutlet=\"bottomTemplateRef\"></ng-container>\r\n </div>\r\n </div>\r\n }\r\n\r\n </div>\r\n\r\n <div class=\"h10\"></div>\r\n\r\n <div class=\"form-row\">\r\n <div class=\"d-flex d-flex-end w-100 pr18\">\r\n <core-button-group-vns [showCaption]=\"showCaptionButton\" [forHeader]=\"false\"\r\n (buttonClick)=\"onButtonClick($event)\" [shownItems]=\"buttonItems\"\r\n class=\"buttonGroupCustom\"></core-button-group-vns>\r\n </div>\r\n </div>\r\n @if (isDevMode) {\r\n <div class=\"form-row d-flex d-flex-center\">\r\n <div class=\"dev-button\" (click)=\"updatePayload()\">Show\r\n values</div>\r\n <div class=\"dev-button\" (click)=\"updateValidorOverview()\">Show\r\n validators</div>\r\n </div>\r\n }\r\n\r\n </form>\r\n\r\n @if (!!payLoad && isDevMode) {\r\n <div class=\"form-row payload-preview\">\r\n <strong>Current values</strong><br>{{payLoad}}\r\n </div>\r\n }\r\n\r\n @if (!!validatorOverview && isDevMode) {\r\n <div class=\"form-row payload-preview validator-preview\">\r\n <strong>Current errors</strong><br>{{validatorOverview}}\r\n </div>\r\n }\r\n\r\n</div>\r\n}", styles: [".core-form-container{overflow-x:visible}.core-form-container>form .section{margin-top:var(--size-layout-block-cell-spacing)}.core-form-container>form .section:not(:first-child){margin-top:calc(var(--size-layout-block-cell-spacing) * 2)}.core-form-container>form .section .section-header-label{display:block;height:34px;line-height:34px;margin-bottom:15px;margin-left:12px}.core-form-container>form .section .section-header-label .section-img-wrapper{position:relative}.core-form-container>form .section .section-header-label .section-img-wrapper .section-img{position:absolute;width:34px;height:34px;border-radius:50%;background-color:#d3d3d3;float:left;background-image:url(/assets/images/info.svg);background-repeat:no-repeat;background-position:center}.core-form-container>form .section .section-header-label .section-caption{padding-left:40px;font-weight:700;color:#696969}.core-form-container .row{margin-left:var(--size-layout-block-cell-spacing) 0px;margin-right:var(--size-layout-block-cell-spacing) 0px}.core-form-container .row .grid-buffer{border:dotted 2px darkgray}.core-form-container .row .button-control{display:flex;align-items:flex-end}.core-form-container .form-row{margin:var(--size-layout-block-cell-spacing) 0px;display:flex;align-items:center;justify-content:center}.core-form-container .form-row>button{cursor:pointer;border-radius:0}.core-form-container .form-row>button:not(:first-child){margin-left:var(--size-layout-block-cell-spacing)}.core-form-container .dev-button{cursor:pointer;display:flex;align-items:center;border:1px gray solid;font-size:13px;padding:8px}.core-form-container .payload-preview{display:block;width:calc(100% - 48px);height:200px;white-space:pre-wrap;overflow-x:hidden;overflow-y:auto;color:gray!important;background-color:#dff6dd;padding:24px;margin:24px}.core-form-container .payload-preview.validator-preview{background-color:#fff4ce}.core-form-container .bottom-template-wrapper{padding-left:12px;padding-right:12px}.core-form-container .w-100{width:100%}.core-form-container .pr18{padding-right:18px}\n"] }]
223
233
  }], ctorParameters: () => [{ type: i1.CoreControlService }, { type: i2.MultiLanguageService }, { type: i3.AlertService }, { type: i4.CoreFormService }, { type: i5.AppConfigService }], propDecorators: { formName: [{
224
234
  type: Input
225
235
  }], width: [{
@@ -260,4 +270,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
260
270
  type: ViewChild,
261
271
  args: ['formRef']
262
272
  }] } });
263
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-form.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-form/core-form/core-form.component.ts","../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-form/core-form/core-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, EventEmitter, Input, OnChanges, OnDestroy, OnInit, Output, SimpleChanges, TemplateRef, ViewChild, isDevMode, } from '@angular/core';\r\nimport { AbstractControl, FormGroup, FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { ICoreFormSection } from './enum-interfaces';\r\nimport { CoreControlService } from '../core-control.service';\r\nimport { BehaviorSubject, Subscription } from 'rxjs';\r\nimport { AlertService } from '../../alert/alert.service';\r\nimport { EnumCorePageEditMode } from '../../core-page-edit/EnumCorePageEditMode';\r\nimport { CoreFormService } from '../core-form.service';\r\nimport { ICoreButtonVNS } from '../../core-button-group-vns/core-button-group-vns/ICoreButtonVNS';\r\nimport { EnumCoreButtonVNSCode } from '../../core-button-group-vns/core-button-group-vns/EnumCoreButtonVNSCode';\r\nimport { EnumTranslateKey } from \"alpha-global-constants\";\r\nimport { MultiLanguageService } from '../../../services/multi-language.service';\r\nimport { noneAutoClosedAlertOptions } from '../../../constants/alertOptions';\r\nimport { CommonModule } from '@angular/common';\r\nimport { CoreControlComponent } from '../../core-control/core-control/core-control.component';\r\nimport { TranslatePipe } from '../../../app-pipes/translate.pipe';\r\nimport { CoreButtonGroupVnsComponent } from '../../core-button-group-vns/core-button-group-vns/core-button-group-vns.component';\r\nimport { AppConfigService } from '../../../services/app-config.service';\r\n\r\nexport interface IDynamicFormEmitOnFormCreated {\r\n  formName: string;\r\n  formGroup: FormGroup;\r\n}\r\n\r\n@Component({\r\n  selector: 'core-form',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    ReactiveFormsModule,\r\n    CoreControlComponent,\r\n    TranslatePipe,\r\n    CoreButtonGroupVnsComponent\r\n  ],\r\n  templateUrl: './core-form.component.html',\r\n  styleUrls: ['./core-form.component.scss'],\r\n})\r\nexport class CoreFormComponent implements OnChanges, OnInit, AfterViewInit, OnDestroy {\r\n\r\n  @Input() formName!: string;\r\n  @Input() width!: number;\r\n  @Input() submitText!: EnumTranslateKey;\r\n  @Input() leftInputSections!: ICoreFormSection[];\r\n  @Input() leftInputSectionsFlexSize!: number;\r\n  @Input() inputSections!: ICoreFormSection[];\r\n  @Input() mode$!: BehaviorSubject<EnumCorePageEditMode>;\r\n  @Input() bottomTemplateRef!: TemplateRef<any>;\r\n  @Input() customFormButtonItems!: EnumCoreButtonVNSCode[]; // Optional\r\n  @Input() showCaptionButton!: boolean;\r\n  @Input() disableSaveButton!: boolean;\r\n  @Input() checkError$ = new BehaviorSubject<boolean>(false);\r\n\r\n  @Output() onFormCreated = new EventEmitter<IDynamicFormEmitOnFormCreated>();\r\n  @Output() onFormRefCreated = new EventEmitter<ElementRef<any>>();\r\n  @Output() onSubmit = new EventEmitter();\r\n  @Output() onSave = new EventEmitter();\r\n  @Output() onCancal = new EventEmitter();\r\n  @Output() buttonClick = new EventEmitter<ICoreButtonVNS>();\r\n\r\n\r\n  @ViewChild('formRef') formRef!: ElementRef;\r\n\r\n  buttonItems!: EnumCoreButtonVNSCode[];\r\n\r\n  form!: FormGroup;\r\n  sections!: ICoreFormSection[];\r\n  lang!: string;\r\n  subscriptions: Subscription[] = [];\r\n\r\n  payLoad = '';\r\n  validatorOverview: any;\r\n  isDevMode!: boolean;\r\n  isUpdateMode!: boolean;\r\n\r\n  constructor(\r\n    private coreControlService: CoreControlService,\r\n    private multiLanguageService: MultiLanguageService,\r\n    private alertService: AlertService,\r\n    private coreFormService: CoreFormService,\r\n    private appConfigService: AppConfigService\r\n  ) {\r\n    this.isDevMode = isDevMode();\r\n  }\r\n\r\n  private updateSections(newSections: ICoreFormSection[]): void {\r\n\r\n    this.sections.map((section, sectionIndex) => {\r\n      const newSection = newSections[sectionIndex];\r\n      section.rows.map((row, rowIndex) => {\r\n        const newRow = newSection.rows[rowIndex];\r\n        row.map((control, controlIndex) => {\r\n          const newControl = newRow[controlIndex];\r\n\r\n          /* THE ONLY PROP TO BE UDATED IS 'hidden', THE OTHERS SHOULD BE MANIPULATED THROUGH this.form.get(YOUR_CONTROL_NAME)... */\r\n          control.hidden = newControl?.hidden;\r\n          /************************************************************************************************************************/\r\n        });\r\n      });\r\n\r\n      /* #region Oct the 11th 2023 */\r\n      /* Some sections was posibly have renderOff=true from previous state and their controls must be created/remove */\r\n      /*\r\n      BUT THIS TASK IS HARD SO FAR\r\n      */\r\n      /* #endregion Oct the 11th 2023 */\r\n\r\n    });\r\n\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['inputSections']) {\r\n      let newSections: ICoreFormSection[] =\r\n        changes['inputSections'].currentValue;\r\n\r\n      if (!!!this.form) {\r\n        this.sections = newSections;\r\n\r\n        let leftGroup;\r\n        let form: FormGroup<any>;\r\n\r\n        const mainGroup = this.coreControlService.toGroup(this.sections);\r\n\r\n        if (!!this.leftInputSections) {\r\n          leftGroup = this.coreControlService.toGroup(this.leftInputSections);\r\n          form = new FormGroup({ ...leftGroup, ...mainGroup });\r\n        } else {\r\n          form = new FormGroup(mainGroup);\r\n        }\r\n\r\n        this.form = form;\r\n\r\n      } else {\r\n        this.updateSections(newSections);\r\n      }\r\n\r\n      this.onFormCreated.emit({\r\n        formName: this.formName,\r\n        formGroup: this.form,\r\n      });\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n\r\n    /*\r\n    if (this.appConfigService.APP_TYPE === \"WEBAPP\") {\r\n    */\r\n\r\n      if (!this.disableSaveButton) {\r\n        this.buttonItems = [\r\n          EnumCoreButtonVNSCode.NONE_HEADER_SAVE,\r\n          EnumCoreButtonVNSCode.NONE_HEADER_CANCEL,\r\n        ]\r\n      } else {\r\n        this.buttonItems = [\r\n          EnumCoreButtonVNSCode.NONE_HEADER_CANCEL,\r\n        ]\r\n      }\r\n\r\n    /*\r\n    } else if (this.appConfigService.APP_TYPE === \"PORTAL\") {\r\n      if (!this.disableSaveButton) {\r\n        this.buttonItems = [\r\n          EnumCoreButtonVNSCode.SEND,\r\n          EnumCoreButtonVNSCode.CANCEL,\r\n          EnumCoreButtonVNSCode.SAVE,\r\n        ]\r\n      } else {\r\n        this.buttonItems = [\r\n          EnumCoreButtonVNSCode.SEND,\r\n          EnumCoreButtonVNSCode.CANCEL,\r\n        ]\r\n      }\r\n    }\r\n    */\r\n\r\n    if (!!this.customFormButtonItems) {\r\n      this.buttonItems = this.customFormButtonItems;\r\n    }\r\n\r\n    this.subscriptions.push(\r\n      this.mode$.subscribe(\r\n        (x) => (this.isUpdateMode = x === EnumCorePageEditMode.UPDATE)\r\n      )\r\n    );\r\n\r\n    console.log(this.mode$);\r\n\r\n    /* START: Check if id field is available */\r\n    if (!!!this.form.get('id') && isDevMode()) {\r\n      this.alertService.error(\r\n        `\r\n            Control \"id\" is mandatory. Please define one in your bussiness component. You can assign its \"hidden\" property to true if needed.\r\n          `,\r\n        noneAutoClosedAlertOptions\r\n      );\r\n    }\r\n    /* END: Check if id field is available */\r\n\r\n    if (isDevMode()) {\r\n      /* START: Check if each field is unique */\r\n\r\n      const fields = this.coreFormService.getAllFormBaseControlNames(\r\n        this.sections\r\n      );\r\n\r\n      fields.reduce((p, c) => {\r\n        if (c === '') {\r\n          this.alertService.error(\r\n            `Form control name must be definded, '${c}' is invalid form control name!!!`,\r\n            noneAutoClosedAlertOptions\r\n          );\r\n        } else {\r\n          if (p === c) {\r\n            this.alertService.error(\r\n              `Duplicate form control name: '${c}'. Consider to predefine one ONLY!!!.`,\r\n              noneAutoClosedAlertOptions\r\n            );\r\n          }\r\n        }\r\n        return c;\r\n      });\r\n      /* END: Check if each field is unique */\r\n    }\r\n\r\n    this.subscriptions.push(\r\n      this.multiLanguageService.lang$.subscribe((x) => (this.lang = x))\r\n    );\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.onFormRefCreated.emit(this.formRef);\r\n  }\r\n\r\n  onFormSubmit() {\r\n    this.checkError$.next(true);\r\n    if (!!this.form.valid) {\r\n      this.payLoad = JSON.stringify(this.form?.getRawValue(), null, 2);\r\n      this.onSubmit.emit(this.form?.getRawValue());\r\n    }\r\n  }\r\n\r\n  onFormSave() {\r\n    this.checkError$.next(true);\r\n    if (!!this.form.valid) {\r\n      this.payLoad = JSON.stringify(this.form?.getRawValue(), null, 2);\r\n      this.onSave.emit(this.form?.getRawValue());\r\n    }\r\n    setTimeout(() => this.checkError$.next(false), 3000);\r\n  }\r\n\r\n  onCancelLocal() {\r\n    this.onCancal.emit(null);\r\n  }\r\n\r\n  updatePayload(): void {\r\n    this.payLoad = JSON.stringify(this.form?.getRawValue(), null, 2);\r\n  }\r\n\r\n  updateValidorOverview(): void {\r\n    const result: { key: string; errors: any[] }[] = [];\r\n    Object.keys(this.form.controls).forEach((key) => {\r\n      const control: AbstractControl = this.form.get(key)!;\r\n      const errors: any[] = [];\r\n      if (!!control.invalid) {\r\n        Object.keys(control.errors!).forEach((key) => {\r\n          errors.push(key);\r\n        });\r\n      }\r\n      result.push({\r\n        key,\r\n        errors,\r\n      });\r\n    });\r\n    this.validatorOverview = JSON.stringify(result, null, 2);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subscriptions.map((x) => x?.unsubscribe());\r\n  }\r\n\r\n  onButtonClick(e: ICoreButtonVNS): void {\r\n\r\n    switch (e.code) {\r\n      case EnumCoreButtonVNSCode.NONE_HEADER_CANCEL:\r\n      case EnumCoreButtonVNSCode.CANCEL:\r\n        this.onCancelLocal();\r\n        break;\r\n      case EnumCoreButtonVNSCode.NONE_HEADER_SAVE:\r\n      case EnumCoreButtonVNSCode.SEND:\r\n      case EnumCoreButtonVNSCode.NONE_HEADER_DELETE:\r\n      case EnumCoreButtonVNSCode.NONE_HEADER_LIQUIDATE_CONTRACT:\r\n      case EnumCoreButtonVNSCode.ONFORMDELETE:\r\n      case EnumCoreButtonVNSCode.SAVE_PASSWORD:\r\n        this.onFormSubmit();\r\n        break;\r\n      case EnumCoreButtonVNSCode.SAVE:\r\n        this.onFormSave();\r\n        break;\r\n      default:\r\n        break;\r\n    }\r\n    this.buttonClick.emit(e);\r\n  }\r\n}\r\n","@if (!!form) {\r\n<div class=\"core-form-container\" [ngStyle]=\"{\r\n    width: !!width ? width + 'px' : 'auto'\r\n}\">\r\n\r\n    <form #formRef (ngSubmit)=\"onFormSubmit()\" [formGroup]=\"form\" autocomplete=\"off\">\r\n\r\n        <div class=\"row\">\r\n\r\n            @if (!!leftInputSections) {\r\n            <div [class]=\"'col-md-' + (leftInputSectionsFlexSize || 0)\">\r\n\r\n                @for (section of leftInputSections; track $index) {\r\n                <div class=\"section\"\r\n                    [class.d-none]=\"(!!isUpdateMode && section.addModeOnly) || (!!!isUpdateMode && section.updateModeOnly) || !!section.hidden\">\r\n\r\n                    @if (!!section.caption) {\r\n                    <div class=\"section-header-label\">\r\n                        <div class=\"section-img-wrapper\">\r\n                            <div class=\"section-img\"></div>\r\n                        </div>\r\n                        <div class=\"section-caption\">{{ section.caption | translate: lang }}</div>\r\n                    </div>\r\n                    }\r\n\r\n                    @for (row of section.rows; track $index) {\r\n                    <div class=\"row mb15\">\r\n                        @for (col of row; track $index) {\r\n                        <div [class]=\"'col-md-' + col.flexSize\" [class.grid-buffer]=\"col.controlType==='GRIDBUFFER'\"\r\n                            [class.button-control]=\"col.controlType==='BUTTON'\">\r\n                            <core-control [control]=\"col\" [form]=\"form\" [checkError$]=\"checkError$\"></core-control>\r\n                        </div>\r\n                        }\r\n                    </div>\r\n                    }\r\n\r\n                </div>\r\n\r\n                }\r\n\r\n            </div>\r\n            }\r\n\r\n            <div [class]=\"'col-md-' + (12 - (leftInputSectionsFlexSize || 0))\">\r\n\r\n                @for (section of sections; track $index) {\r\n                <div class=\"section\"\r\n                    [class.d-none]=\"(!!isUpdateMode && section.addModeOnly) || (!!!isUpdateMode && section.updateModeOnly) || !!section.hidden\" [ngStyle]=\"{\r\n                        maxWidth: !!section.maxWidth ? section.maxWidth + 'px' : 'none'\r\n                    }\">\r\n\r\n                    @if (!!section.caption) {\r\n                    <div class=\"section-header-label\">\r\n                        <div class=\"section-img-wrapper\">\r\n                            <div class=\"section-img\"></div>\r\n                        </div>\r\n                        <div class=\"section-caption\">{{ section.caption | translate: lang }}</div>\r\n                    </div>\r\n                    }\r\n\r\n                    @for (row of section.rows; track $index) {\r\n                    <div class=\"row mb15\">\r\n                        @for (col of row; track $index) {\r\n                        <div [class]=\"'col-md-' + col.flexSize\" [class.grid-buffer]=\"col.controlType==='GRIDBUFFER'\"\r\n                            [class.button-control]=\"col.controlType==='BUTTON'\">\r\n                            <core-control [control]=\"col\" [form]=\"form\" [checkError$]=\"checkError$\"></core-control>\r\n                        </div>\r\n                        }\r\n                    </div>\r\n                    }\r\n\r\n                </div>\r\n                }\r\n\r\n            </div>\r\n\r\n            @if (!!bottomTemplateRef) {\r\n                <div class=\"col-md-12\">\r\n                    <div class=\"bottom-template-wrapper\">\r\n                        <ng-container *ngTemplateOutlet=\"bottomTemplateRef\"></ng-container>\r\n                    </div>\r\n                </div>\r\n            }\r\n\r\n        </div>\r\n\r\n        <div class=\"h10\"></div>\r\n\r\n        <div class=\"form-row\">\r\n\r\n            <core-button-group-vns [showCaption]=\"showCaptionButton\" [forHeader]=\"false\"\r\n                (buttonClick)=\"onButtonClick($event)\" [shownItems]=\"buttonItems\"\r\n                class=\"buttonGroupCustom\"></core-button-group-vns>\r\n        </div>\r\n        @if (isDevMode) {\r\n        <div class=\"form-row d-flex d-flex-center\">\r\n            <div class=\"dev-button\" (click)=\"updatePayload()\">Show\r\n                values</div>\r\n            <div class=\"dev-button\" (click)=\"updateValidorOverview()\">Show\r\n                validators</div>\r\n        </div>\r\n        }\r\n\r\n    </form>\r\n\r\n    @if (!!payLoad && isDevMode) {\r\n    <div class=\"form-row payload-preview\">\r\n        <strong>Current values</strong><br>{{payLoad}}\r\n    </div>\r\n    }\r\n\r\n    @if (!!validatorOverview && isDevMode) {\r\n    <div class=\"form-row payload-preview\">\r\n        <strong>Current errors</strong><br>{{validatorOverview}}\r\n    </div>\r\n    }\r\n\r\n</div>\r\n}"]}
273
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-form.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-form/core-form/core-form.component.ts","../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-form/core-form/core-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, EventEmitter, Input, OnChanges, OnDestroy, OnInit, Output, SimpleChanges, TemplateRef, ViewChild, isDevMode, } from '@angular/core';\r\nimport { AbstractControl, FormGroup, FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { ICoreFormSection } from './enum-interfaces';\r\nimport { CoreControlService } from '../core-control.service';\r\nimport { BehaviorSubject, Subscription } from 'rxjs';\r\nimport { AlertService } from '../../alert/alert.service';\r\nimport { EnumCorePageEditMode } from '../../core-page-edit/EnumCorePageEditMode';\r\nimport { CoreFormService } from '../core-form.service';\r\nimport { ICoreButtonVNS } from '../../core-button-group-vns/core-button-group-vns/ICoreButtonVNS';\r\nimport { EnumCoreButtonVNSCode } from '../../core-button-group-vns/core-button-group-vns/EnumCoreButtonVNSCode';\r\nimport { EnumTranslateKey } from \"alpha-global-constants\";\r\nimport { MultiLanguageService } from '../../../services/multi-language.service';\r\nimport { noneAutoClosedAlertOptions } from '../../../constants/alertOptions';\r\nimport { CommonModule } from '@angular/common';\r\nimport { CoreControlComponent } from '../../core-control/core-control/core-control.component';\r\nimport { TranslatePipe } from '../../../app-pipes/translate.pipe';\r\nimport { CoreButtonGroupVnsComponent } from '../../core-button-group-vns/core-button-group-vns/core-button-group-vns.component';\r\nimport { AppConfigService } from '../../../services/app-config.service';\r\n\r\nexport interface IDynamicFormEmitOnFormCreated {\r\n  formName: string;\r\n  formGroup: FormGroup;\r\n}\r\n\r\n@Component({\r\n  selector: 'core-form',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    ReactiveFormsModule,\r\n    CoreControlComponent,\r\n    TranslatePipe,\r\n    CoreButtonGroupVnsComponent\r\n  ],\r\n  templateUrl: './core-form.component.html',\r\n  styleUrls: ['./core-form.component.scss'],\r\n})\r\nexport class CoreFormComponent implements OnChanges, OnInit, AfterViewInit, OnDestroy {\r\n\r\n  @Input() formName!: string;\r\n  @Input() width!: number;\r\n  @Input() submitText!: EnumTranslateKey;\r\n  @Input() leftInputSections!: ICoreFormSection[];\r\n  @Input() leftInputSectionsFlexSize!: number;\r\n  @Input() inputSections!: ICoreFormSection[];\r\n  @Input() mode$!: BehaviorSubject<EnumCorePageEditMode>;\r\n  @Input() bottomTemplateRef!: TemplateRef<any>;\r\n  @Input() customFormButtonItems!: EnumCoreButtonVNSCode[]; // Optional\r\n  @Input() showCaptionButton!: boolean;\r\n  @Input() disableSaveButton!: boolean;\r\n  @Input() checkError$ = new BehaviorSubject<boolean>(false);\r\n\r\n  @Output() onFormCreated = new EventEmitter<IDynamicFormEmitOnFormCreated>();\r\n  @Output() onFormRefCreated = new EventEmitter<ElementRef<any>>();\r\n  @Output() onSubmit = new EventEmitter();\r\n  @Output() onSave = new EventEmitter();\r\n  @Output() onCancal = new EventEmitter();\r\n  @Output() buttonClick = new EventEmitter<ICoreButtonVNS>();\r\n\r\n\r\n  @ViewChild('formRef') formRef!: ElementRef;\r\n\r\n  buttonItems!: EnumCoreButtonVNSCode[];\r\n\r\n  form!: FormGroup;\r\n  sections!: ICoreFormSection[];\r\n  lang!: string;\r\n  subscriptions: Subscription[] = [];\r\n\r\n  payLoad = '';\r\n  validatorOverview: any;\r\n  isDevMode!: boolean;\r\n  isUpdateMode!: boolean;\r\n\r\n  constructor(\r\n    private coreControlService: CoreControlService,\r\n    private multiLanguageService: MultiLanguageService,\r\n    private alertService: AlertService,\r\n    private coreFormService: CoreFormService,\r\n    private appConfigService: AppConfigService\r\n  ) {\r\n    this.isDevMode = isDevMode();\r\n  }\r\n\r\n  private updateSections(newSections: ICoreFormSection[]): void {\r\n\r\n    this.sections.map((section, sectionIndex) => {\r\n      const newSection = newSections[sectionIndex];\r\n      section.rows.map((row, rowIndex) => {\r\n        const newRow = newSection.rows[rowIndex];\r\n        row.map((control, controlIndex) => {\r\n          const newControl = newRow[controlIndex];\r\n\r\n          /* THE ONLY PROP TO BE UDATED IS 'hidden', THE OTHERS SHOULD BE MANIPULATED THROUGH this.form.get(YOUR_CONTROL_NAME)... */\r\n          control.hidden = newControl?.hidden;\r\n          /************************************************************************************************************************/\r\n        });\r\n      });\r\n\r\n      /* #region Oct the 11th 2023 */\r\n      /* Some sections was posibly have renderOff=true from previous state and their controls must be created/remove */\r\n      /*\r\n      BUT THIS TASK IS HARD SO FAR\r\n      */\r\n      /* #endregion Oct the 11th 2023 */\r\n\r\n    });\r\n\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['inputSections']) {\r\n      let newSections: ICoreFormSection[] =\r\n        changes['inputSections'].currentValue;\r\n\r\n      if (!!!this.form) {\r\n        this.sections = newSections;\r\n\r\n        let leftGroup;\r\n        let form: FormGroup<any>;\r\n\r\n        const mainGroup = this.coreControlService.toGroup(this.sections);\r\n\r\n        if (!!this.leftInputSections) {\r\n          leftGroup = this.coreControlService.toGroup(this.leftInputSections);\r\n          form = new FormGroup({ ...leftGroup, ...mainGroup });\r\n        } else {\r\n          form = new FormGroup(mainGroup);\r\n        }\r\n\r\n        this.form = form;\r\n\r\n      } else {\r\n        this.updateSections(newSections);\r\n      }\r\n\r\n      this.onFormCreated.emit({\r\n        formName: this.formName,\r\n        formGroup: this.form,\r\n      });\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n\r\n    /*\r\n    if (this.appConfigService.APP_TYPE === \"WEBAPP\") {\r\n    */\r\n\r\n      if (!this.disableSaveButton) {\r\n        this.buttonItems = [\r\n          EnumCoreButtonVNSCode.NONE_HEADER_SAVE,\r\n          EnumCoreButtonVNSCode.NONE_HEADER_CANCEL,\r\n        ]\r\n      } else {\r\n        this.buttonItems = [\r\n          EnumCoreButtonVNSCode.NONE_HEADER_CANCEL,\r\n        ]\r\n      }\r\n\r\n    /*\r\n    } else if (this.appConfigService.APP_TYPE === \"PORTAL\") {\r\n      if (!this.disableSaveButton) {\r\n        this.buttonItems = [\r\n          EnumCoreButtonVNSCode.SEND,\r\n          EnumCoreButtonVNSCode.CANCEL,\r\n          EnumCoreButtonVNSCode.SAVE,\r\n        ]\r\n      } else {\r\n        this.buttonItems = [\r\n          EnumCoreButtonVNSCode.SEND,\r\n          EnumCoreButtonVNSCode.CANCEL,\r\n        ]\r\n      }\r\n    }\r\n    */\r\n\r\n    if (!!this.customFormButtonItems) {\r\n      this.buttonItems = this.customFormButtonItems;\r\n    }\r\n\r\n    this.subscriptions.push(\r\n      this.mode$.subscribe(\r\n        (x) => (this.isUpdateMode = x === EnumCorePageEditMode.UPDATE)\r\n      )\r\n    );\r\n\r\n    console.log(this.mode$);\r\n\r\n    /* START: Check if id field is available */\r\n    if (!!!this.form.get('id') && isDevMode()) {\r\n      this.alertService.error(\r\n        `\r\n            Control \"id\" is mandatory. Please define one in your bussiness component. You can assign its \"hidden\" property to true if needed.\r\n          `,\r\n        noneAutoClosedAlertOptions\r\n      );\r\n    }\r\n    /* END: Check if id field is available */\r\n\r\n    if (isDevMode()) {\r\n      /* START: Check if each field is unique */\r\n\r\n      const fields = this.coreFormService.getAllFormBaseControlNames(\r\n        this.sections\r\n      );\r\n\r\n      fields.reduce((p, c) => {\r\n        if (c === '') {\r\n          this.alertService.error(\r\n            `Form control name must be definded, '${c}' is invalid form control name!!!`,\r\n            noneAutoClosedAlertOptions\r\n          );\r\n        } else {\r\n          if (p === c) {\r\n            this.alertService.error(\r\n              `Duplicate form control name: '${c}'. Consider to predefine one ONLY!!!.`,\r\n              noneAutoClosedAlertOptions\r\n            );\r\n          }\r\n        }\r\n        return c;\r\n      });\r\n      /* END: Check if each field is unique */\r\n    }\r\n\r\n    this.subscriptions.push(\r\n      this.multiLanguageService.lang$.subscribe((x) => (this.lang = x))\r\n    );\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.onFormRefCreated.emit(this.formRef);\r\n  }\r\n\r\n  onFormSubmit() {\r\n    this.checkError$.next(true);\r\n    if (!!this.form.valid) {\r\n      this.payLoad = JSON.stringify(this.form?.getRawValue(), null, 2);\r\n      this.onSubmit.emit(this.form?.getRawValue());\r\n    }\r\n  }\r\n\r\n  onFormSave() {\r\n    this.checkError$.next(true);\r\n    if (!!this.form.valid) {\r\n      this.payLoad = JSON.stringify(this.form?.getRawValue(), null, 2);\r\n      this.onSave.emit(this.form?.getRawValue());\r\n    }\r\n    setTimeout(() => this.checkError$.next(false), 3000);\r\n  }\r\n\r\n  onCancelLocal() {\r\n    this.onCancal.emit(null);\r\n  }\r\n\r\n  updatePayload(): void {\r\n    if (this.payLoad === '') {\r\n      this.payLoad = JSON.stringify(this.form?.getRawValue(), null, 2);\r\n    } else {\r\n      this.payLoad = '';\r\n    }\r\n    \r\n  }\r\n\r\n  updateValidorOverview(): void {\r\n\r\n    if (this.validatorOverview === undefined) {\r\n      const result: { key: string; errors: any[] }[] = [];\r\n      Object.keys(this.form.controls).forEach((key) => {\r\n        const control: AbstractControl = this.form.get(key)!;\r\n        const errors: any[] = [];\r\n        if (!!control.invalid) {\r\n          Object.keys(control.errors!).forEach((key) => {\r\n            errors.push(key);\r\n          });\r\n        }\r\n        result.push({\r\n          key,\r\n          errors,\r\n        });\r\n      });\r\n      this.validatorOverview = JSON.stringify(result, null, 2);\r\n    } else {\r\n      this.validatorOverview = undefined\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.subscriptions.map((x) => x?.unsubscribe());\r\n  }\r\n\r\n  onButtonClick(e: ICoreButtonVNS): void {\r\n\r\n    switch (e.code) {\r\n      case EnumCoreButtonVNSCode.NONE_HEADER_CANCEL:\r\n      case EnumCoreButtonVNSCode.CANCEL:\r\n        this.onCancelLocal();\r\n        break;\r\n      case EnumCoreButtonVNSCode.NONE_HEADER_SAVE:\r\n      case EnumCoreButtonVNSCode.SEND:\r\n      case EnumCoreButtonVNSCode.NONE_HEADER_DELETE:\r\n      case EnumCoreButtonVNSCode.NONE_HEADER_LIQUIDATE_CONTRACT:\r\n      case EnumCoreButtonVNSCode.ONFORMDELETE:\r\n      case EnumCoreButtonVNSCode.SAVE_PASSWORD:\r\n        this.onFormSubmit();\r\n        break;\r\n      case EnumCoreButtonVNSCode.SAVE:\r\n        this.onFormSave();\r\n        break;\r\n      default:\r\n        break;\r\n    }\r\n    this.buttonClick.emit(e);\r\n  }\r\n}\r\n","@if (!!form) {\r\n<div class=\"core-form-container\" [ngStyle]=\"{\r\n    width: !!width ? width + 'px' : 'auto'\r\n}\">\r\n\r\n    <form #formRef (ngSubmit)=\"onFormSubmit()\" [formGroup]=\"form\" autocomplete=\"off\">\r\n\r\n        <div class=\"row\">\r\n\r\n            @if (!!leftInputSections) {\r\n            <div [class]=\"'col-md-' + (leftInputSectionsFlexSize || 0)\">\r\n\r\n                @for (section of leftInputSections; track $index) {\r\n                <div class=\"section\"\r\n                    [class.d-none]=\"(!!isUpdateMode && section.addModeOnly) || (!!!isUpdateMode && section.updateModeOnly) || !!section.hidden\">\r\n\r\n                    @if (!!section.caption) {\r\n                    <div class=\"section-header-label\">\r\n                        <div class=\"section-img-wrapper\">\r\n                            <div class=\"section-img\"></div>\r\n                        </div>\r\n                        <div class=\"section-caption\">{{ section.caption | translate: lang }}</div>\r\n                    </div>\r\n                    }\r\n\r\n                    @for (row of section.rows; track $index) {\r\n                    <div class=\"row mb15\">\r\n                        @for (col of row; track $index) {\r\n                        <div [class]=\"'col-md-' + col.flexSize\" [class.grid-buffer]=\"col.controlType==='GRIDBUFFER'\"\r\n                            [class.button-control]=\"col.controlType==='BUTTON'\">\r\n                            <core-control [control]=\"col\" [form]=\"form\" [checkError$]=\"checkError$\"></core-control>\r\n                        </div>\r\n                        }\r\n                    </div>\r\n                    }\r\n\r\n                </div>\r\n\r\n                }\r\n\r\n            </div>\r\n            }\r\n\r\n            <div [class]=\"'col-md-' + (12 - (leftInputSectionsFlexSize || 0))\">\r\n\r\n                @for (section of sections; track $index) {\r\n                <div class=\"section\"\r\n                    [class.d-none]=\"(!!isUpdateMode && section.addModeOnly) || (!!!isUpdateMode && section.updateModeOnly) || !!section.hidden\" [ngStyle]=\"{\r\n                        maxWidth: !!section.maxWidth ? section.maxWidth + 'px' : 'none'\r\n                    }\">\r\n\r\n                    @if (!!section.caption) {\r\n                    <div class=\"section-header-label\">\r\n                        <div class=\"section-img-wrapper\">\r\n                            <div class=\"section-img\"></div>\r\n                        </div>\r\n                        <div class=\"section-caption\">{{ section.caption | translate: lang }}</div>\r\n                    </div>\r\n                    }\r\n\r\n                    @for (row of section.rows; track $index) {\r\n                    <div class=\"row mb15\">\r\n                        @for (col of row; track $index) {\r\n                        <div [class]=\"'col-md-' + col.flexSize\" [class.grid-buffer]=\"col.controlType==='GRIDBUFFER'\"\r\n                            [class.button-control]=\"col.controlType==='BUTTON'\">\r\n                            <core-control [control]=\"col\" [form]=\"form\" [checkError$]=\"checkError$\"></core-control>\r\n                        </div>\r\n                        }\r\n                    </div>\r\n                    }\r\n\r\n                </div>\r\n                }\r\n\r\n            </div>\r\n\r\n            @if (!!bottomTemplateRef) {\r\n                <div class=\"col-md-12\">\r\n                    <div class=\"bottom-template-wrapper\">\r\n                        <ng-container *ngTemplateOutlet=\"bottomTemplateRef\"></ng-container>\r\n                    </div>\r\n                </div>\r\n            }\r\n\r\n        </div>\r\n\r\n        <div class=\"h10\"></div>\r\n\r\n        <div class=\"form-row\">\r\n            <div class=\"d-flex d-flex-end w-100 pr18\">\r\n                <core-button-group-vns [showCaption]=\"showCaptionButton\" [forHeader]=\"false\"\r\n                (buttonClick)=\"onButtonClick($event)\" [shownItems]=\"buttonItems\"\r\n                class=\"buttonGroupCustom\"></core-button-group-vns>\r\n            </div>\r\n        </div>\r\n        @if (isDevMode) {\r\n        <div class=\"form-row d-flex d-flex-center\">\r\n            <div class=\"dev-button\" (click)=\"updatePayload()\">Show\r\n                values</div>\r\n            <div class=\"dev-button\" (click)=\"updateValidorOverview()\">Show\r\n                validators</div>\r\n        </div>\r\n        }\r\n\r\n    </form>\r\n\r\n    @if (!!payLoad && isDevMode) {\r\n    <div class=\"form-row payload-preview\">\r\n        <strong>Current values</strong><br>{{payLoad}}\r\n    </div>\r\n    }\r\n\r\n    @if (!!validatorOverview && isDevMode) {\r\n    <div class=\"form-row payload-preview validator-preview\">\r\n        <strong>Current errors</strong><br>{{validatorOverview}}\r\n    </div>\r\n    }\r\n\r\n</div>\r\n}"]}