barsa-sap-ui 1.0.278 → 1.0.281

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.
@@ -2,22 +2,24 @@ import { Component, HostListener, Input, ViewChild, ChangeDetectionStrategy } fr
2
2
  import { of, Subject } from 'rxjs';
3
3
  import { debounceTime, filter, distinctUntilChanged, tap, takeUntil, switchMap } from 'rxjs/operators';
4
4
  import { ComboboxComponent } from '@fundamental-ngx/core';
5
- import { FieldBaseComponent, BarsaApi } from 'barsa-novin-ray-core';
5
+ import { FieldBaseComponent, BarsaApi, PreventDefaulEvent, getUniqueId } from 'barsa-novin-ray-core';
6
6
  import * as i0 from "@angular/core";
7
7
  import * as i1 from "@angular/common";
8
8
  import * as i2 from "@angular/forms";
9
9
  import * as i3 from "@fundamental-ngx/core/button";
10
10
  import * as i4 from "@fundamental-ngx/core/combobox";
11
11
  import * as i5 from "@fundamental-ngx/core/form";
12
- import * as i6 from "@fundamental-ngx/core/input-group";
13
- import * as i7 from "@fundamental-ngx/core/list";
14
- import * as i8 from "@fundamental-ngx/platform/button";
15
- import * as i9 from "../mask/mask.component";
16
- import * as i10 from "barsa-novin-ray-core";
12
+ import * as i6 from "@fundamental-ngx/core/icon";
13
+ import * as i7 from "@fundamental-ngx/core/input-group";
14
+ import * as i8 from "@fundamental-ngx/core/list";
15
+ import * as i9 from "@fundamental-ngx/platform/button";
16
+ import * as i10 from "../mask/mask.component";
17
+ import * as i11 from "barsa-novin-ray-core";
17
18
  export class UiMoInfoUlvComboComponent extends FieldBaseComponent {
18
19
  constructor() {
19
20
  super(...arguments);
20
21
  this.smartChange = new Subject();
22
+ this.allColumns = [];
21
23
  this._openPopupFormSelectionSource = new Subject();
22
24
  this._closeDialogSource = new Subject();
23
25
  this._loadingSource = new Subject();
@@ -43,6 +45,9 @@ export class UiMoInfoUlvComboComponent extends FieldBaseComponent {
43
45
  this.Focus = () => { };
44
46
  this.SetUlvAdapter = (type, ulvAdapter) => {
45
47
  this.ulvAdapter = ulvAdapter;
48
+ if (ulvAdapter?.Setting?.View?.Columns?.length) {
49
+ this.allColumns = ulvAdapter.Setting.View.Columns.filter((c) => c.MetaFieldTypeId > 0);
50
+ }
46
51
  /* eslint-disable */
47
52
  };
48
53
  this.IsUiCreated = (type) => {
@@ -70,10 +75,7 @@ export class UiMoInfoUlvComboComponent extends FieldBaseComponent {
70
75
  /* eslint-disable */
71
76
  };
72
77
  this.getRawValue = () => {
73
- if (!this.value) {
74
- return this.rawValue;
75
- }
76
- return '';
78
+ return this.rawValue;
77
79
  /* eslint-disable */
78
80
  };
79
81
  }
@@ -82,6 +84,7 @@ export class UiMoInfoUlvComboComponent extends FieldBaseComponent {
82
84
  e.preventDefault();
83
85
  }
84
86
  ngOnInit() {
87
+ this.comboboxId = getUniqueId(3);
85
88
  this.loading$ = this._loadingSource.asObservable().pipe(takeUntil(this._onDestroy$));
86
89
  this.loading$.subscribe(() => {
87
90
  this.isDataLoadedFirstTime =
@@ -109,6 +112,33 @@ export class UiMoInfoUlvComboComponent extends FieldBaseComponent {
109
112
  super.ngAfterViewInit();
110
113
  // this._setComboText(this.value);
111
114
  }
115
+ onPagingClick(e) {
116
+ PreventDefaulEvent(e);
117
+ }
118
+ onPageChange(e) {
119
+ this._loadingSource.next(true);
120
+ this.ulvAdapter.DataCtrlr.MoveToPage(e, () => {
121
+ this._loadingSource.next(false);
122
+ });
123
+ }
124
+ onItemClick(e) {
125
+ const selectedMo = e.item;
126
+ this._fireValueChange(selectedMo);
127
+ }
128
+ onPageChange2(pageSetting, e) {
129
+ PreventDefaulEvent(e);
130
+ this._loadingSource.next(true);
131
+ const ulvAdapter = this.ulvAdapter;
132
+ const temp1 = ulvAdapter.Setting.Data.MoDataList;
133
+ temp1.splice(temp1.length - 1, 1);
134
+ const moDataListOld = [...temp1];
135
+ moDataListOld.forEach((c) => (c.$__IsLast = false));
136
+ this.ulvAdapter.DataCtrlr.MoveToPage(pageSetting.Page + 1, () => {
137
+ const moDataList = ulvAdapter.Setting.Data.MoDataList;
138
+ moDataList.splice(0, 0, ...moDataListOld);
139
+ this._loadingSource.next(false);
140
+ });
141
+ }
112
142
  onOpenChange(fdCombobox, isOpen) {
113
143
  if (isOpen) {
114
144
  this._focus();
@@ -187,15 +217,18 @@ export class UiMoInfoUlvComboComponent extends FieldBaseComponent {
187
217
  if (value === null || typeof value === 'undefined') {
188
218
  this._valueMo = null;
189
219
  }
190
- const valueText = '';
220
+ this.valueText = this._getValueText(value);
221
+ this._setComboText(this.valueText);
222
+ }
223
+ _getValueText(value) {
191
224
  if (!value) {
192
- this.valueText = '';
225
+ return '';
193
226
  }
194
227
  else if (typeof value === 'string') {
195
- this.valueText = value;
228
+ return value;
196
229
  }
197
230
  else if (typeof value === 'object') {
198
- this.valueText = value.$Caption;
231
+ return value.$Caption;
199
232
  }
200
233
  if (typeof value !== 'string' && value && this.UlvMainCtrlr && this.UlvMainCtrlr.Dd) {
201
234
  const view = this.UlvMainCtrlr.Dd.Setting.View;
@@ -204,9 +237,8 @@ export class UiMoInfoUlvComboComponent extends FieldBaseComponent {
204
237
  const firstCol = view.Columns.find((c) => !c.Name.startsWith('$') && c.Name !== 'Id');
205
238
  colName = firstCol?.Name ? firstCol.Name : '$Caption';
206
239
  }
207
- this.valueText = this.getMoValueCaption(this._valueMo, colName, this.valueText);
240
+ return this.getMoValueCaption(this._valueMo, colName, this.valueText);
208
241
  }
209
- this._setComboText(this.valueText);
210
242
  }
211
243
  _setComboText(value) {
212
244
  // if (value === null || typeof value === 'undefined') {
@@ -258,7 +290,7 @@ export class UiMoInfoUlvComboComponent extends FieldBaseComponent {
258
290
  });
259
291
  if (findMo) {
260
292
  canRequest = false;
261
- this._fireValueChange(findMo);
293
+ //this._fireValueChange(findMo);
262
294
  }
263
295
  }
264
296
  return canRequest;
@@ -295,10 +327,10 @@ export class UiMoInfoUlvComboComponent extends FieldBaseComponent {
295
327
  }
296
328
  }
297
329
  UiMoInfoUlvComboComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: UiMoInfoUlvComboComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
298
- UiMoInfoUlvComboComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: UiMoInfoUlvComboComponent, selector: "bsu-ui-mo-info-ulv-combo", inputs: { ulvAdapter: "ulvAdapter", Control: "Control", UlvUi: "UlvUi", UlvMainCtrlr: "UlvMainCtrlr", IsExpanded: "IsExpanded", Collapse: "Collapse", Expand: "Expand", on: "on", Focus: "Focus", SetUlvAdapter: "SetUlvAdapter", IsUiCreated: "IsUiCreated", Mask: "Mask", hide: "hide", show: "show", Unmask: "Unmask", getRawValue: "getRawValue" }, host: { listeners: { "keydown.alt": "onAlt($event)" } }, viewQueries: [{ propertyName: "fdComboRef", first: true, predicate: ComboboxComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<ng-container *ngIf=\"context._showPopup || context._showDropDown === false; else combo\">\n <div style=\"display: flex\" class=\"fd-input-group\">\n <input\n fd-input-group-input\n fd-form-control\n #inputRef\n [placeholder]=\"Setting.NullText || ''\"\n [attr.readonly]=\"true\"\n [attr.disabled]=\"(disable$ | async) === true ? true : null\"\n [value]=\"!value ? '' : (value | bbbTranslate)\"\n [id]=\"id\"\n [style.direction]=\"Setting.IsLtr === true ? 'ltr' : null\"\n (input)=\"onValueChange($event)\"\n />\n <span\n fd-input-group-addon\n *ngIf=\"value && (disableOrReadonly$ | async) !== true\"\n class=\"fd-input-group__addon--button\"\n >\n <button fd-button fdType=\"transparent\" glyph=\"decline\" (click)=\"onClear()\"></button>\n </span>\n <span\n fd-input-group-addon\n *ngIf=\"!value && (disableOrReadonly$ | async) !== true && Setting.ShowNewButton\"\n class=\"fd-input-group__addon--button\"\n >\n <button fd-button fdType=\"transparent\" glyph=\"add\" (click)=\"onNew()\"></button>\n </span>\n <span\n fd-input-group-addon\n *ngIf=\"value && (disableOrReadonly$ | async) !== true && Setting.ViewRelatedFormType === 'Show'\"\n class=\"fd-input-group__addon--button\"\n >\n <button fd-button fdType=\"transparent\" glyph=\"edit\" (click)=\"onEdit()\"></button>\n </span>\n <span\n fd-input-group-addon\n *ngIf=\"value && (disableOrReadonly$ | async) !== true && Setting.ViewRelatedFormType === 'ShowReadOnly'\"\n class=\"fd-input-group__addon--button\"\n >\n <button fd-button fdType=\"transparent\" glyph=\"show\" (click)=\"onEdit()\"></button>\n </span>\n <span\n fd-input-group-addon\n *ngIf=\"context._showPopup && !value && (disableOrReadonly$ | async) !== true\"\n class=\"fd-input-group__addon--button\"\n >\n <button fd-button fdType=\"transparent\" glyph=\"search\" (click)=\"onSearch()\"></button>\n </span>\n </div>\n</ng-container>\n\n<ng-template #combo>\n <div [class.control-disabled]=\"disable$ | async\" class=\"simple-combo-wrapper\">\n <fd-combobox\n #fdCombobox\n class=\"combo-mo-ulv\"\n [class.has-report]=\"hasReport\"\n [placeholder]=\"''\"\n [mobile]=\"(deviceSize$ | async) === 's'\"\n [mobileConfig]=\"mobileConfig\"\n [fillOnSelect]=\"true\"\n [readOnly]=\"(readonly$ | async) === true ? true : false\"\n [disabled]=\"(disable$ | async) === true ? true : false\"\n [dropdownValues]=\"(loading$ | async) === true | moInfoUlvMoList: isDataLoadedFirstTime:ulvAdapter:UlvUi\"\n [filterFn]=\"customFilter\"\n [openOnKeyboardEvent]=\"true\"\n [itemTemplate]=\"template\"\n [ngModel]=\"valueText | bbbTranslate\"\n [displayFn]=\"displayFunc\"\n [showDropdownButton]=\"(disableOrReadonly$ | async) !== true\"\n (inputTextChange)=\"onInputChange($event)\"\n (openChange)=\"onOpenChange(fdCombobox, $event)\"\n >\n </fd-combobox>\n <button *ngIf=\"value\" fd-button fdType=\"transparent\" glyph=\"decline\" (click)=\"onClear()\"></button>\n <fdp-button\n *ngIf=\"hasReport && (disableOrReadonly$ | async) !== true\"\n glyph=\"search\"\n buttonType=\"transparent\"\n class=\"combo-popup-btn\"\n (click)=\"onSearch()\"\n ></fdp-button>\n </div>\n <ng-template #template let-item>\n <div fd-list-content *ngIf=\"item.$isLoading; else showItem\" style=\"width: 100%; height: 20px\">\n <bsu-mask [size]=\"'s'\" [marginTop]=\"'10px'\"></bsu-mask>\n </div>\n <ng-template #showItem>\n <i fd-list-icon [glyph]=\"item.$Icon\"></i>\n <span fd-list-title>{{\n item.isEmpty ? ('NoData' | bbbTranslate) : (item.$MoCaption || item.$Caption | bbbTranslate)\n }}</span>\n </ng-template>\n </ng-template>\n</ng-template>\n", styles: [":host{display:block}.combo-mo-ulv{width:100%}.combo-mo-ulv ::ng-deep .fd-popover-custom{width:100%}.fd-input-group>.fd-input-group__input{background-color:transparent!important}.simple-combo-wrapper{display:flex;align-items:center;position:relative}.combo-wrapper{display:flex;align-items:center;border:var(--sapField_BorderWidth, .0625rem) solid var(--sapField_BorderColor, #89919a);border-radius:var(--sapField_BorderCornerRadius, .125rem)}::ng-deep .combo-popup-btn{border:none;background:transparent}::ng-deep .combo-popup-btn button{border-color:transparent!important;border:none}::ng-deep .fd-combobox-count-list-results{display:none}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i4.ComboboxComponent, selector: "fd-combobox", inputs: ["comboboxId", "inputId", "ariaLabel", "ariaLabelledBy", "required", "dropdownValues", "filterFn", "disabled", "placeholder", "isSearch", "glyph", "showClearButton", "triggers", "closeOnOutsideClick", "openOnKeyboardEvent", "state", "itemTemplate", "groupFn", "maxHeight", "searchFn", "highlighting", "closeOnSelect", "fillOnSelect", "autoComplete", "fillControlMode", "communicateByObject", "displayFn", "buttonFocusable", "readOnly", "mobile", "mobileConfig", "showDropdownButton", "includes", "title", "byline"], outputs: ["itemClicked", "openChange", "inputTextChange"] }, { kind: "component", type: i5.FormControlComponent, selector: "[fd-form-control]", inputs: ["state", "type", "class"] }, { kind: "directive", type: i5.InputFormControlDirective, selector: "input[fd-form-control]" }, { kind: "directive", type: i6.InputGroupInputDirective, selector: "[fd-input-group-input]", inputs: ["class"] }, { kind: "directive", type: i6.InputGroupAddOnDirective, selector: "[fd-input-group-addon]", inputs: ["class", "placement", "type", "state", "button"] }, { kind: "directive", type: i7.ListTitleDirective, selector: "[fd-list-title], [fdListTitle]", inputs: ["wrap"] }, { kind: "directive", type: i7.ListIconDirective, selector: "[fdListIcon], [fd-list-icon]", inputs: ["glyph", "class", "role"] }, { kind: "directive", type: i7.ListContentDirective, selector: "[fdListContent], [fd-list-content]", inputs: ["twoCol"] }, { kind: "component", type: i8.ButtonComponent, selector: "fdp-button", inputs: ["glyphPosition", "label", "glyph", "buttonType", "title", "ariaSelected", "ariaDisabled", "ariaExpanded", "ariaControlsId", "ariaPressed", "name", "type", "value"], outputs: ["buttonClicked"] }, { kind: "component", type: i9.MaskComponent, selector: "bsu-mask", inputs: ["size", "marginTop"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i10.BbbTranslatePipe, name: "bbbTranslate" }, { kind: "pipe", type: i10.MoInfoUlvMoListPipe, name: "moInfoUlvMoList" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
330
+ UiMoInfoUlvComboComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: UiMoInfoUlvComboComponent, selector: "bsu-ui-mo-info-ulv-combo", inputs: { ulvAdapter: "ulvAdapter", Control: "Control", UlvUi: "UlvUi", UlvMainCtrlr: "UlvMainCtrlr", IsExpanded: "IsExpanded", Collapse: "Collapse", Expand: "Expand", on: "on", Focus: "Focus", SetUlvAdapter: "SetUlvAdapter", IsUiCreated: "IsUiCreated", Mask: "Mask", hide: "hide", show: "show", Unmask: "Unmask", getRawValue: "getRawValue" }, host: { listeners: { "keydown.alt": "onAlt($event)" } }, viewQueries: [{ propertyName: "fdComboRef", first: true, predicate: ComboboxComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<ng-container\n *ngTemplateOutlet=\"\n context._showPopup || context._showDropDown === false ? inputTemplate : comboTemplate;\n context: {\n $implicit: (loading$ | async) === true | moInfoUlvMoList: isDataLoadedFirstTime:ulvAdapter:UlvUi,\n deviceSize: deviceSize$ | async,\n disableOrReadonly: disableOrReadonly$ | async,\n disable: disable$ | async,\n readonly: readonly$ | async\n }\n \"\n>\n</ng-container>\n<ng-template\n #inputTemplate\n let-deviceSize=\"deviceSize\"\n let-disableOrReadonly=\"disableOrReadonly\"\n let-disable=\"disable\"\n let-readonly=\"readonly\"\n>\n <div style=\"display: flex\" class=\"fd-input-group\">\n <input\n fd-input-group-input\n fd-form-control\n #inputRef\n [placeholder]=\"Setting.NullText || ''\"\n [attr.readonly]=\"true\"\n [attr.disabled]=\"disable === true ? true : null\"\n [value]=\"!value ? '' : (value | bbbTranslate)\"\n [id]=\"id\"\n [style.direction]=\"Setting.IsLtr === true ? 'ltr' : null\"\n (input)=\"onValueChange($event)\"\n />\n <span fd-input-group-addon *ngIf=\"value && disableOrReadonly !== true\" class=\"fd-input-group__addon--button\">\n <button fd-button fdType=\"transparent\" glyph=\"decline\" (click)=\"onClear()\"></button>\n </span>\n <span\n fd-input-group-addon\n *ngIf=\"!value && disableOrReadonly !== true && Setting.ShowNewButton\"\n class=\"fd-input-group__addon--button\"\n >\n <button fd-button fdType=\"transparent\" glyph=\"add\" (click)=\"onNew()\"></button>\n </span>\n <span\n fd-input-group-addon\n *ngIf=\"value && disableOrReadonly !== true && Setting.ViewRelatedFormType === 'Show'\"\n class=\"fd-input-group__addon--button\"\n >\n <button fd-button fdType=\"transparent\" glyph=\"edit\" (click)=\"onEdit()\"></button>\n </span>\n <span\n fd-input-group-addon\n *ngIf=\"value && disableOrReadonly !== true && Setting.ViewRelatedFormType === 'ShowReadOnly'\"\n class=\"fd-input-group__addon--button\"\n >\n <button fd-button fdType=\"transparent\" glyph=\"show\" (click)=\"onEdit()\"></button>\n </span>\n <span\n fd-input-group-addon\n *ngIf=\"context._showPopup && !value && disableOrReadonly !== true\"\n class=\"fd-input-group__addon--button\"\n >\n <button fd-button fdType=\"transparent\" glyph=\"search\" (click)=\"onSearch()\"></button>\n </span>\n </div>\n</ng-template>\n\n<ng-template\n #comboTemplate\n let-moDataList\n let-deviceSize=\"deviceSize\"\n let-disableOrReadonly=\"disableOrReadonly\"\n let-disable=\"disable\"\n let-readonly=\"readonly\"\n>\n <div [class.control-disabled]=\"disable\" class=\"simple-combo-wrapper\">\n <fd-combobox\n #fdCombobox\n class=\"combo-mo-ulv\"\n [comboboxId]=\"comboboxId\"\n [class.has-report]=\"hasReport\"\n [placeholder]=\"''\"\n [mobile]=\"deviceSize === 's'\"\n [mobileConfig]=\"mobileConfig\"\n [fillOnSelect]=\"true\"\n [readOnly]=\"readonly === true ? true : false\"\n [disabled]=\"disable === true ? true : false\"\n [dropdownValues]=\"moDataList\"\n [filterFn]=\"customFilter\"\n [openOnKeyboardEvent]=\"true\"\n [byline]=\"allColumns.length > 0\"\n [itemTemplate]=\"itemTemplate\"\n [ngModel]=\"valueText | bbbTranslate\"\n [displayFn]=\"displayFunc\"\n [showDropdownButton]=\"disableOrReadonly !== true\"\n (itemClicked)=\"onItemClick($event)\"\n (inputTextChange)=\"onInputChange($event)\"\n (openChange)=\"onOpenChange(fdCombobox, $event)\"\n >\n </fd-combobox>\n <button\n *ngIf=\"value && disableOrReadonly !== true\"\n fd-button\n fdType=\"transparent\"\n glyph=\"decline\"\n (click)=\"onClear()\"\n ></button>\n <fdp-button\n *ngIf=\"hasReport && disableOrReadonly !== true\"\n glyph=\"search\"\n buttonType=\"transparent\"\n class=\"combo-popup-btn\"\n (click)=\"onSearch()\"\n ></fdp-button>\n </div>\n <ng-template #itemTemplate let-item>\n <div fd-list-content *ngIf=\"item.$isLoading; else itemWrapper\" style=\"width: 100%; height: 20px\">\n <bsu-mask [size]=\"'s'\" [marginTop]=\"'10px'\"></bsu-mask>\n </div>\n <ng-template #itemWrapper>\n <ng-container *ngIf=\"item.$LoadMore; else showItem\">\n <!-- <bsu-ulv-paging\n (click)=\"onPagingClick($event)\"\n (pageChange)=\"onPageChange($event)\"\n [pagingSetting]=\"ulvAdapter.Setting.Data.Paging\"\n >\n </bsu-ulv-paging> -->\n <button\n style=\"width: 100%\"\n *ngIf=\"ulvAdapter.Setting.Data.Paging.Page + 1 < ulvAdapter.Setting.Data.Paging.TotalPages\"\n fd-button\n (click)=\"onPageChange2(ulvAdapter.Setting.Data.Paging, $event)\"\n [label]=\"'More' | bbbTranslate\"\n ></button>\n </ng-container>\n </ng-template>\n <ng-template #showItem>\n <ng-container *ngIf=\"allColumns?.length; else captionTemplate\">\n <div *ngIf=\"!item.$__IsLast\" class=\"moinfoulv devider\"></div>\n <span fd-list-thumbnail *ngIf=\"item.$Icon\"><fd-icon [glyph]=\"item.$Icon\"></fd-icon></span>\n <div fd-list-content class=\"moinfoulv hasColumns\">\n <div fd-list-title class=\"title\">{{ allColumns[0].Alias | rval: item:allColumns:true }}</div>\n <div fd-list-byline class=\"byline\" *ngIf=\"allColumns[1]\">\n {{ allColumns[1].Alias | rval: item:allColumns:true }}\n </div>\n <div style=\"display: flex; column-gap: 8px; flex-wrap: wrap\">\n <ng-container *ngFor=\"let column of allColumns; let index = index\">\n <ng-container *ngIf=\"index > 1\">\n <ng-container *ngIf=\"column.Alias | rval: item:allColumns:true as value\">\n <span> {{ column.Alias }}:{{ value }}</span>\n </ng-container>\n </ng-container>\n </ng-container>\n </div>\n </div>\n </ng-container>\n <ng-template #captionTemplate>\n <span fd-list-title>{{\n item.isEmpty ? ('NoData' | bbbTranslate) : (item.$MoCaption || item.$Caption | bbbTranslate)\n }}</span>\n </ng-template>\n </ng-template>\n </ng-template>\n</ng-template>\n", styles: [":host{display:block}.combo-mo-ulv{width:100%}.combo-mo-ulv ::ng-deep .fd-popover-custom{width:100%}.fd-input-group>.fd-input-group__input{background-color:transparent!important}.simple-combo-wrapper{display:flex;align-items:center;position:relative}.combo-wrapper{display:flex;align-items:center;border:var(--sapField_BorderWidth, .0625rem) solid var(--sapField_BorderColor, #89919a);border-radius:var(--sapField_BorderCornerRadius, .125rem)}::ng-deep .combo-popup-btn{border:none;background:transparent}::ng-deep .combo-popup-btn button{border-color:transparent!important;border:none}::ng-deep .fd-combobox-count-list-results{display:none}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.ButtonComponent, selector: "button[fd-button], a[fd-button]", inputs: ["class"], exportAs: ["fd-button"] }, { kind: "component", type: i4.ComboboxComponent, selector: "fd-combobox", inputs: ["comboboxId", "inputId", "ariaLabel", "ariaLabelledBy", "required", "dropdownValues", "filterFn", "disabled", "placeholder", "isSearch", "glyph", "showClearButton", "triggers", "closeOnOutsideClick", "openOnKeyboardEvent", "state", "itemTemplate", "groupFn", "maxHeight", "searchFn", "highlighting", "closeOnSelect", "fillOnSelect", "autoComplete", "fillControlMode", "communicateByObject", "displayFn", "buttonFocusable", "readOnly", "mobile", "mobileConfig", "showDropdownButton", "includes", "title", "byline"], outputs: ["itemClicked", "openChange", "inputTextChange"] }, { kind: "component", type: i5.FormControlComponent, selector: "[fd-form-control]", inputs: ["state", "type", "class"] }, { kind: "directive", type: i5.InputFormControlDirective, selector: "input[fd-form-control]" }, { kind: "component", type: i6.IconComponent, selector: "fd-icon", inputs: ["glyph", "font", "class", "ariaLabel"] }, { kind: "directive", type: i7.InputGroupInputDirective, selector: "[fd-input-group-input]", inputs: ["class"] }, { kind: "directive", type: i7.InputGroupAddOnDirective, selector: "[fd-input-group-addon]", inputs: ["class", "placement", "type", "state", "button"] }, { kind: "directive", type: i8.ListTitleDirective, selector: "[fd-list-title], [fdListTitle]", inputs: ["wrap"] }, { kind: "directive", type: i8.ListBylineDirective, selector: "[fdListByline], [fd-list-byline]", inputs: ["twoCol", "wrap"] }, { kind: "directive", type: i8.ListContentDirective, selector: "[fdListContent], [fd-list-content]", inputs: ["twoCol"] }, { kind: "directive", type: i8.ListThumbnailDirective, selector: "[fdListThumbnail], [fd-list-thumbnail]" }, { kind: "component", type: i9.ButtonComponent, selector: "fdp-button", inputs: ["glyphPosition", "label", "glyph", "buttonType", "title", "ariaSelected", "ariaDisabled", "ariaExpanded", "ariaControlsId", "ariaPressed", "name", "type", "value"], outputs: ["buttonClicked"] }, { kind: "component", type: i10.MaskComponent, selector: "bsu-mask", inputs: ["size", "marginTop"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i11.MoReportValuePipe, name: "rval" }, { kind: "pipe", type: i11.BbbTranslatePipe, name: "bbbTranslate" }, { kind: "pipe", type: i11.MoInfoUlvMoListPipe, name: "moInfoUlvMoList" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
299
331
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: UiMoInfoUlvComboComponent, decorators: [{
300
332
  type: Component,
301
- args: [{ selector: 'bsu-ui-mo-info-ulv-combo', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container *ngIf=\"context._showPopup || context._showDropDown === false; else combo\">\n <div style=\"display: flex\" class=\"fd-input-group\">\n <input\n fd-input-group-input\n fd-form-control\n #inputRef\n [placeholder]=\"Setting.NullText || ''\"\n [attr.readonly]=\"true\"\n [attr.disabled]=\"(disable$ | async) === true ? true : null\"\n [value]=\"!value ? '' : (value | bbbTranslate)\"\n [id]=\"id\"\n [style.direction]=\"Setting.IsLtr === true ? 'ltr' : null\"\n (input)=\"onValueChange($event)\"\n />\n <span\n fd-input-group-addon\n *ngIf=\"value && (disableOrReadonly$ | async) !== true\"\n class=\"fd-input-group__addon--button\"\n >\n <button fd-button fdType=\"transparent\" glyph=\"decline\" (click)=\"onClear()\"></button>\n </span>\n <span\n fd-input-group-addon\n *ngIf=\"!value && (disableOrReadonly$ | async) !== true && Setting.ShowNewButton\"\n class=\"fd-input-group__addon--button\"\n >\n <button fd-button fdType=\"transparent\" glyph=\"add\" (click)=\"onNew()\"></button>\n </span>\n <span\n fd-input-group-addon\n *ngIf=\"value && (disableOrReadonly$ | async) !== true && Setting.ViewRelatedFormType === 'Show'\"\n class=\"fd-input-group__addon--button\"\n >\n <button fd-button fdType=\"transparent\" glyph=\"edit\" (click)=\"onEdit()\"></button>\n </span>\n <span\n fd-input-group-addon\n *ngIf=\"value && (disableOrReadonly$ | async) !== true && Setting.ViewRelatedFormType === 'ShowReadOnly'\"\n class=\"fd-input-group__addon--button\"\n >\n <button fd-button fdType=\"transparent\" glyph=\"show\" (click)=\"onEdit()\"></button>\n </span>\n <span\n fd-input-group-addon\n *ngIf=\"context._showPopup && !value && (disableOrReadonly$ | async) !== true\"\n class=\"fd-input-group__addon--button\"\n >\n <button fd-button fdType=\"transparent\" glyph=\"search\" (click)=\"onSearch()\"></button>\n </span>\n </div>\n</ng-container>\n\n<ng-template #combo>\n <div [class.control-disabled]=\"disable$ | async\" class=\"simple-combo-wrapper\">\n <fd-combobox\n #fdCombobox\n class=\"combo-mo-ulv\"\n [class.has-report]=\"hasReport\"\n [placeholder]=\"''\"\n [mobile]=\"(deviceSize$ | async) === 's'\"\n [mobileConfig]=\"mobileConfig\"\n [fillOnSelect]=\"true\"\n [readOnly]=\"(readonly$ | async) === true ? true : false\"\n [disabled]=\"(disable$ | async) === true ? true : false\"\n [dropdownValues]=\"(loading$ | async) === true | moInfoUlvMoList: isDataLoadedFirstTime:ulvAdapter:UlvUi\"\n [filterFn]=\"customFilter\"\n [openOnKeyboardEvent]=\"true\"\n [itemTemplate]=\"template\"\n [ngModel]=\"valueText | bbbTranslate\"\n [displayFn]=\"displayFunc\"\n [showDropdownButton]=\"(disableOrReadonly$ | async) !== true\"\n (inputTextChange)=\"onInputChange($event)\"\n (openChange)=\"onOpenChange(fdCombobox, $event)\"\n >\n </fd-combobox>\n <button *ngIf=\"value\" fd-button fdType=\"transparent\" glyph=\"decline\" (click)=\"onClear()\"></button>\n <fdp-button\n *ngIf=\"hasReport && (disableOrReadonly$ | async) !== true\"\n glyph=\"search\"\n buttonType=\"transparent\"\n class=\"combo-popup-btn\"\n (click)=\"onSearch()\"\n ></fdp-button>\n </div>\n <ng-template #template let-item>\n <div fd-list-content *ngIf=\"item.$isLoading; else showItem\" style=\"width: 100%; height: 20px\">\n <bsu-mask [size]=\"'s'\" [marginTop]=\"'10px'\"></bsu-mask>\n </div>\n <ng-template #showItem>\n <i fd-list-icon [glyph]=\"item.$Icon\"></i>\n <span fd-list-title>{{\n item.isEmpty ? ('NoData' | bbbTranslate) : (item.$MoCaption || item.$Caption | bbbTranslate)\n }}</span>\n </ng-template>\n </ng-template>\n</ng-template>\n", styles: [":host{display:block}.combo-mo-ulv{width:100%}.combo-mo-ulv ::ng-deep .fd-popover-custom{width:100%}.fd-input-group>.fd-input-group__input{background-color:transparent!important}.simple-combo-wrapper{display:flex;align-items:center;position:relative}.combo-wrapper{display:flex;align-items:center;border:var(--sapField_BorderWidth, .0625rem) solid var(--sapField_BorderColor, #89919a);border-radius:var(--sapField_BorderCornerRadius, .125rem)}::ng-deep .combo-popup-btn{border:none;background:transparent}::ng-deep .combo-popup-btn button{border-color:transparent!important;border:none}::ng-deep .fd-combobox-count-list-results{display:none}\n"] }]
333
+ args: [{ selector: 'bsu-ui-mo-info-ulv-combo', changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-container\n *ngTemplateOutlet=\"\n context._showPopup || context._showDropDown === false ? inputTemplate : comboTemplate;\n context: {\n $implicit: (loading$ | async) === true | moInfoUlvMoList: isDataLoadedFirstTime:ulvAdapter:UlvUi,\n deviceSize: deviceSize$ | async,\n disableOrReadonly: disableOrReadonly$ | async,\n disable: disable$ | async,\n readonly: readonly$ | async\n }\n \"\n>\n</ng-container>\n<ng-template\n #inputTemplate\n let-deviceSize=\"deviceSize\"\n let-disableOrReadonly=\"disableOrReadonly\"\n let-disable=\"disable\"\n let-readonly=\"readonly\"\n>\n <div style=\"display: flex\" class=\"fd-input-group\">\n <input\n fd-input-group-input\n fd-form-control\n #inputRef\n [placeholder]=\"Setting.NullText || ''\"\n [attr.readonly]=\"true\"\n [attr.disabled]=\"disable === true ? true : null\"\n [value]=\"!value ? '' : (value | bbbTranslate)\"\n [id]=\"id\"\n [style.direction]=\"Setting.IsLtr === true ? 'ltr' : null\"\n (input)=\"onValueChange($event)\"\n />\n <span fd-input-group-addon *ngIf=\"value && disableOrReadonly !== true\" class=\"fd-input-group__addon--button\">\n <button fd-button fdType=\"transparent\" glyph=\"decline\" (click)=\"onClear()\"></button>\n </span>\n <span\n fd-input-group-addon\n *ngIf=\"!value && disableOrReadonly !== true && Setting.ShowNewButton\"\n class=\"fd-input-group__addon--button\"\n >\n <button fd-button fdType=\"transparent\" glyph=\"add\" (click)=\"onNew()\"></button>\n </span>\n <span\n fd-input-group-addon\n *ngIf=\"value && disableOrReadonly !== true && Setting.ViewRelatedFormType === 'Show'\"\n class=\"fd-input-group__addon--button\"\n >\n <button fd-button fdType=\"transparent\" glyph=\"edit\" (click)=\"onEdit()\"></button>\n </span>\n <span\n fd-input-group-addon\n *ngIf=\"value && disableOrReadonly !== true && Setting.ViewRelatedFormType === 'ShowReadOnly'\"\n class=\"fd-input-group__addon--button\"\n >\n <button fd-button fdType=\"transparent\" glyph=\"show\" (click)=\"onEdit()\"></button>\n </span>\n <span\n fd-input-group-addon\n *ngIf=\"context._showPopup && !value && disableOrReadonly !== true\"\n class=\"fd-input-group__addon--button\"\n >\n <button fd-button fdType=\"transparent\" glyph=\"search\" (click)=\"onSearch()\"></button>\n </span>\n </div>\n</ng-template>\n\n<ng-template\n #comboTemplate\n let-moDataList\n let-deviceSize=\"deviceSize\"\n let-disableOrReadonly=\"disableOrReadonly\"\n let-disable=\"disable\"\n let-readonly=\"readonly\"\n>\n <div [class.control-disabled]=\"disable\" class=\"simple-combo-wrapper\">\n <fd-combobox\n #fdCombobox\n class=\"combo-mo-ulv\"\n [comboboxId]=\"comboboxId\"\n [class.has-report]=\"hasReport\"\n [placeholder]=\"''\"\n [mobile]=\"deviceSize === 's'\"\n [mobileConfig]=\"mobileConfig\"\n [fillOnSelect]=\"true\"\n [readOnly]=\"readonly === true ? true : false\"\n [disabled]=\"disable === true ? true : false\"\n [dropdownValues]=\"moDataList\"\n [filterFn]=\"customFilter\"\n [openOnKeyboardEvent]=\"true\"\n [byline]=\"allColumns.length > 0\"\n [itemTemplate]=\"itemTemplate\"\n [ngModel]=\"valueText | bbbTranslate\"\n [displayFn]=\"displayFunc\"\n [showDropdownButton]=\"disableOrReadonly !== true\"\n (itemClicked)=\"onItemClick($event)\"\n (inputTextChange)=\"onInputChange($event)\"\n (openChange)=\"onOpenChange(fdCombobox, $event)\"\n >\n </fd-combobox>\n <button\n *ngIf=\"value && disableOrReadonly !== true\"\n fd-button\n fdType=\"transparent\"\n glyph=\"decline\"\n (click)=\"onClear()\"\n ></button>\n <fdp-button\n *ngIf=\"hasReport && disableOrReadonly !== true\"\n glyph=\"search\"\n buttonType=\"transparent\"\n class=\"combo-popup-btn\"\n (click)=\"onSearch()\"\n ></fdp-button>\n </div>\n <ng-template #itemTemplate let-item>\n <div fd-list-content *ngIf=\"item.$isLoading; else itemWrapper\" style=\"width: 100%; height: 20px\">\n <bsu-mask [size]=\"'s'\" [marginTop]=\"'10px'\"></bsu-mask>\n </div>\n <ng-template #itemWrapper>\n <ng-container *ngIf=\"item.$LoadMore; else showItem\">\n <!-- <bsu-ulv-paging\n (click)=\"onPagingClick($event)\"\n (pageChange)=\"onPageChange($event)\"\n [pagingSetting]=\"ulvAdapter.Setting.Data.Paging\"\n >\n </bsu-ulv-paging> -->\n <button\n style=\"width: 100%\"\n *ngIf=\"ulvAdapter.Setting.Data.Paging.Page + 1 < ulvAdapter.Setting.Data.Paging.TotalPages\"\n fd-button\n (click)=\"onPageChange2(ulvAdapter.Setting.Data.Paging, $event)\"\n [label]=\"'More' | bbbTranslate\"\n ></button>\n </ng-container>\n </ng-template>\n <ng-template #showItem>\n <ng-container *ngIf=\"allColumns?.length; else captionTemplate\">\n <div *ngIf=\"!item.$__IsLast\" class=\"moinfoulv devider\"></div>\n <span fd-list-thumbnail *ngIf=\"item.$Icon\"><fd-icon [glyph]=\"item.$Icon\"></fd-icon></span>\n <div fd-list-content class=\"moinfoulv hasColumns\">\n <div fd-list-title class=\"title\">{{ allColumns[0].Alias | rval: item:allColumns:true }}</div>\n <div fd-list-byline class=\"byline\" *ngIf=\"allColumns[1]\">\n {{ allColumns[1].Alias | rval: item:allColumns:true }}\n </div>\n <div style=\"display: flex; column-gap: 8px; flex-wrap: wrap\">\n <ng-container *ngFor=\"let column of allColumns; let index = index\">\n <ng-container *ngIf=\"index > 1\">\n <ng-container *ngIf=\"column.Alias | rval: item:allColumns:true as value\">\n <span> {{ column.Alias }}:{{ value }}</span>\n </ng-container>\n </ng-container>\n </ng-container>\n </div>\n </div>\n </ng-container>\n <ng-template #captionTemplate>\n <span fd-list-title>{{\n item.isEmpty ? ('NoData' | bbbTranslate) : (item.$MoCaption || item.$Caption | bbbTranslate)\n }}</span>\n </ng-template>\n </ng-template>\n </ng-template>\n</ng-template>\n", styles: [":host{display:block}.combo-mo-ulv{width:100%}.combo-mo-ulv ::ng-deep .fd-popover-custom{width:100%}.fd-input-group>.fd-input-group__input{background-color:transparent!important}.simple-combo-wrapper{display:flex;align-items:center;position:relative}.combo-wrapper{display:flex;align-items:center;border:var(--sapField_BorderWidth, .0625rem) solid var(--sapField_BorderColor, #89919a);border-radius:var(--sapField_BorderCornerRadius, .125rem)}::ng-deep .combo-popup-btn{border:none;background:transparent}::ng-deep .combo-popup-btn button{border-color:transparent!important;border:none}::ng-deep .fd-combobox-count-list-results{display:none}\n"] }]
302
334
  }], propDecorators: { ulvAdapter: [{
303
335
  type: Input
304
336
  }], Control: [{
@@ -338,4 +370,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImpor
338
370
  }], getRawValue: [{
339
371
  type: Input
340
372
  }] } });
341
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-mo-info-ulv-combo.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/ui-mo-info-ulv-combo/ui-mo-info-ulv-combo.component.ts","../../../../../projects/barsa-sap-ui/src/lib/ui-mo-info-ulv-combo/ui-mo-info-ulv-combo.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    HostListener,\n    Input,\n    ViewChild,\n    ChangeDetectionStrategy,\n    OnInit,\n    AfterViewInit\n} from '@angular/core';\nimport { Observable, of, Subject } from 'rxjs';\nimport { debounceTime, filter, distinctUntilChanged, tap, takeUntil, switchMap } from 'rxjs/operators';\nimport { ComboboxComponent, DialogRef } from '@fundamental-ngx/core';\n\nimport {\n    FieldBaseComponent,\n    BarsaApi,\n    ReportExtraInfo,\n    MoForReportModel,\n    ClassNamesModel,\n    ViewTypes,\n    MetaobjectDataModel\n} from 'barsa-novin-ray-core';\n\n@Component({\n    selector: 'bsu-ui-mo-info-ulv-combo',\n    templateUrl: './ui-mo-info-ulv-combo.component.html',\n    styleUrls: ['./ui-mo-info-ulv-combo.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class UiMoInfoUlvComboComponent extends FieldBaseComponent implements OnInit, AfterViewInit {\n    @Input() ulvAdapter: {\n        [key: string]: any;\n        Setting: {\n            [key: string]: any;\n            View: ViewTypes;\n            ClassNames: ClassNamesModel;\n            Extra: ReportExtraInfo;\n            Data: MoForReportModel;\n        };\n    };\n    @Input() Control: any;\n    @Input() UlvUi: any;\n    @Input() UlvMainCtrlr: any;\n    @ViewChild(ComboboxComponent) fdComboRef: ComboboxComponent;\n    isExpand: boolean;\n    smartChange = new Subject<string>();\n    loading$: Observable<boolean>;\n    tickRef: any;\n    inputElement: HTMLInputElement;\n    isFirstLoad: boolean;\n    popoverElement: any;\n    rawValue: string;\n    formSelectionDialog: DialogRef;\n    isOpenSelectionDialog: boolean;\n    hasReport: any;\n    originalValue: any;\n    isDataLoadedFirstTime: boolean;\n    valueText: string;\n    private _openPopupFormSelectionSource = new Subject<void>();\n    private _closeDialogSource = new Subject<void>();\n    private _loadingSource = new Subject<boolean>();\n    private _valueMo: MetaobjectDataModel | null;\n\n    @HostListener('keydown.alt', ['$event'])\n    onAlt(e): void {\n        e.stopPropagation();\n        e.preventDefault();\n    }\n    ngOnInit(): void {\n        this.loading$ = this._loadingSource.asObservable().pipe(takeUntil(this._onDestroy$));\n        this.loading$.subscribe(() => {\n            this.isDataLoadedFirstTime =\n                typeof this.ulvAdapter?.Setting?.Data?.MoDataList === 'object' ||\n                typeof this.UlvUi?.Setting?.Data?.MoDataList === 'object';\n        });\n        this.smartChange\n            .pipe(\n                takeUntil(this._onDestroy$),\n                debounceTime(200),\n                filter((value) => this._filterSmartChange(value)),\n                distinctUntilChanged(),\n                tap((value) => (this.rawValue = value))\n            )\n            .subscribe((value) => {\n                this.context.fireEvent('SmartChange', this.context, value);\n            });\n        this._openPopupFormSelectionSource\n            .asObservable()\n            .pipe(\n                takeUntil(this._closeDialogSource),\n                takeUntil(this._onDestroy$),\n                filter(() => this.UlvUi && !this.isOpenSelectionDialog && this.context._showPopup),\n                switchMap(() => this._openPopupFormSelection())\n            )\n            .subscribe();\n        super.ngOnInit();\n        this.originalValue = this.value;\n        this.hasReport = this.Setting.RelationViewType === 'ReportView' || this.Setting.ReportName === 'Hierarchical';\n        this.Control = this;\n        setTimeout(() => {\n            this._setValueText(this.value);\n        });\n    }\n    ngAfterViewInit(): void {\n        super.ngAfterViewInit();\n        // this._setComboText(this.value);\n    }\n\n    onOpenChange(fdCombobox, isOpen: boolean): void {\n        if (isOpen) {\n            this._focus();\n            // fdCombobox.open = false; // it close popup when click on dropdown button in component\n        } else {\n            const inputText = this.fdComboRef?.inputTextValue;\n            if (!this.value && inputText) {\n                this._raiseSmartChange(inputText);\n            }\n        }\n    }\n    onInputChange(e): void {\n        this._raiseSmartChange(e);\n    }\n    onInputChange2(e): void {\n        this._raiseSmartChange(e.target.value);\n    }\n    onValueChange(e): void {\n        this._raiseValueChanged(e.target.value);\n    }\n    onNew(): void {\n        this._triggerClick('New');\n    }\n    onClear(): void {\n        this._triggerClick('Delete');\n    }\n    onEdit(): void {\n        this._triggerClick('Edit');\n    }\n    onSearch(): void {\n        this._triggerClick('Popup');\n    }\n    /* eslint-disable */\n    customFilter(content: any[], searchTerm: string): any[] {\n        return content;\n    }\n\n    displayFunc = (obj: MetaobjectDataModel) => {\n        if (obj) {\n            const colName = this.getFirstColumnName();\n            return this.getMoValueCaption(obj, colName, obj.$Caption);\n        }\n        return '';\n    };\n    getMoValueCaption(valueMo: MetaobjectDataModel | null, colName: string, defaultValue: string): string {\n        if (valueMo === null) {\n            return defaultValue;\n        }\n        let captionValueMo;\n        const molist: MetaobjectDataModel[] = BarsaApi.Common.Util.TryGetValue(\n            this.ulvAdapter,\n            'Setting.Data.MoDataList',\n            []\n        );\n        const foundedMo = molist.find((c) => c.Id === valueMo.Id);\n        if (colName && foundedMo && foundedMo[colName]) {\n            if (foundedMo[colName + '$Caption']) {\n                captionValueMo = foundedMo[colName + '$Caption'];\n            } else if (foundedMo[colName].$Caption) {\n                captionValueMo = foundedMo[colName].$Caption;\n            } else {\n                captionValueMo = foundedMo[colName];\n            }\n        }\n        return this._bbbPipe.transform(captionValueMo || defaultValue);\n    }\n    getFirstColumnName() {\n        let colName = '$Caption';\n        if (this.UlvMainCtrlr && this.UlvMainCtrlr?.Dd?.Setting?.View) {\n            if (this.UlvMainCtrlr.Dd.Setting.View.Columns) {\n                const firstCol = this.UlvMainCtrlr.Dd.Setting.View.Columns.find(\n                    (c) => !c.Name.startsWith('$') && c.Name !== 'Id'\n                );\n                if (firstCol?.Name) {\n                    colName = firstCol.Name;\n                }\n            }\n        }\n        return colName;\n    }\n\n    /* eslint-disable */\n    @Input() IsExpanded = (type) => false;\n    // return this.comboRef.nativeElement.responsivePopover.isOpen();\n    /* eslint-disable */\n    @Input() Collapse = (type) => {};\n    /* eslint-disable */\n    @Input() Expand = (type) => {\n        this.ulvAdapter = this.UlvMainCtrlr[type];\n    };\n    /* eslint-disable */\n    @Input() on = () => {};\n    /* eslint-disable */\n    @Input() Focus = () => {};\n    @Input()\n    SetUlvAdapter = (type, ulvAdapter) => {\n        this.ulvAdapter = ulvAdapter;\n        /* eslint-disable */\n    };\n    @Input()\n    IsUiCreated = (type) => {\n        return true;\n        /* eslint-disable */\n    };\n    @Input()\n    Mask = (type) => {\n        this._loadingSource.next(true);\n        /* eslint-disable */\n    };\n    @Input()\n    hide = (type) => {\n        // this.triggerClick('Normal');\n        if (this.formSelectionDialog) {\n            this.formSelectionDialog.close();\n        }\n        /* eslint-disable */\n    };\n    @Input()\n    show = (type) => {\n        // this.triggerClick('Normal');\n        this._openPopupFormSelectionSource.next(); // rabete taki general info .popup baz mishod ke baiad dropdown bashe.\n        /* eslint-disable */\n    };\n    @Input()\n    Unmask = (type) => {\n        this._loadingSource.next(false);\n        /* eslint-disable */\n    };\n    @Input()\n    getRawValue = () => {\n        if (!this.value) {\n            return this.rawValue;\n        }\n        return '';\n        /* eslint-disable */\n    };\n    protected _setValue(value: any): void {\n        this._setValueText(value);\n        super._setValue(value);\n        // this._setComboText(value);\n    }\n    protected _setValueText(value): void {\n        if (value === null || typeof value === 'undefined') {\n            this._valueMo = null;\n        }\n        const valueText = '';\n        if (!value) {\n            this.valueText = '';\n        } else if (typeof value === 'string') {\n            this.valueText = value;\n        } else if (typeof value === 'object') {\n            this.valueText = value.$Caption;\n        }\n        if (typeof value !== 'string' && value && this.UlvMainCtrlr && this.UlvMainCtrlr.Dd) {\n            const view = this.UlvMainCtrlr.Dd.Setting.View;\n            let colName = '$Caption';\n            if (view.Columns) {\n                const firstCol = view.Columns.find((c) => !c.Name.startsWith('$') && c.Name !== 'Id');\n                colName = firstCol?.Name ? firstCol.Name : '$Caption';\n            }\n            this.valueText = this.getMoValueCaption(this._valueMo, colName, this.valueText);\n        }\n        this._setComboText(this.valueText);\n    }\n    protected _setComboText(value: string): void {\n        // if (value === null || typeof value === 'undefined') {\n        // this._valueMo = null;\n        //this.fdComboRef.inputTextValue = '';\n        //this.fdComboRef._cdRef.detectChanges();\n        // }\n        const fdComboRef = this.fdComboRef;\n        const inputText = fdComboRef?.inputTextValue;\n        if (fdComboRef && value != inputText) {\n            const UlvMainCtrlr = this.UlvMainCtrlr;\n            if (UlvMainCtrlr && UlvMainCtrlr.Dd) {\n                const view = UlvMainCtrlr.Dd.Setting.View;\n                let colName = '$Caption';\n                if (view.Columns) {\n                    const firstCol = view.Columns.find((c) => !c.Name.startsWith('$') && c.Name !== 'Id');\n                    colName = firstCol?.Name ? firstCol.Name : '$Caption';\n                }\n                value = this.getMoValueCaption(this._valueMo, colName, value);\n            }\n            fdComboRef.inputText = value ? this._bbbPipe.transform(value) + '' : '';\n            this._cdr.detectChanges();\n        }\n    }\n    protected _openPopupFormSelection(): Observable<boolean> {\n        this.isOpenSelectionDialog = true;\n        this.UlvUi.viewerControl.ShowOkCancelButtons = true; // this is useful to ulv manage toolbar buttons.for example move in tree does not shown\n        this.formSelectionDialog = BarsaApi.Bw.UlvFormMultiSelect.Show(this.context, {\n            ulv1: this.UlvUi,\n            title: this._bbbPipe.transform('Select'),\n            IsLoaded: true\n        });\n        setTimeout(() => {\n            this.isOpenSelectionDialog = false;\n        }, 500);\n        return of(true);\n    }\n    protected _filterSmartChange(value): boolean {\n        let canRequest = this.ulvAdapter && value !== this.value;\n        if (canRequest) {\n            const molist: MetaobjectDataModel[] = BarsaApi.Common.Util.TryGetValue(\n                this.ulvAdapter,\n                'Setting.Data.MoDataList',\n                []\n            );\n            if (!molist) {\n                return true;\n            }\n            const colName = this.getFirstColumnName();\n\n            const findMo = molist.find((mo) => {\n                const caption = this.getMoValueCaption(mo, colName, mo.$Caption);\n                return caption === value;\n            });\n            if (findMo) {\n                canRequest = false;\n                this._fireValueChange(findMo);\n            }\n        }\n        return canRequest;\n    }\n\n    protected _focus(): void {\n        this._triggerClick('Normal');\n    }\n\n    protected _raiseSmartChange(value): void {\n        this.smartChange.next(value);\n    }\n\n    protected _triggerClick(eventName, value = null): void {\n        this.context.fireEvent('TriggerClick', this.context, eventName, value);\n    }\n\n    protected _raiseValueChanged(caption): void {\n        const inputValue = caption;\n        const molist: MetaobjectDataModel[] = BarsaApi.Common.Util.TryGetValue(\n            this.ulvAdapter,\n            'Setting.Data.MoDataList',\n            []\n        );\n        if (!molist || molist.length === 0) {\n            return;\n        }\n        //const colName = this.getFirstColumnName();\n\n        const mo = molist.find((c) => c.$Caption === inputValue);\n        if (!mo) {\n            return;\n        }\n        this._fireValueChange(mo);\n    }\n    protected _fireValueChange(mo): void {\n        this.value = mo;\n        this._valueMo = mo;\n        this._setValueText(this.value);\n        // this._setComboText(mo.$Caption);\n        // this._cdr.detectChanges();\n        this._triggerClick('ItemSelect', this.value);\n    }\n}\n","<ng-container *ngIf=\"context._showPopup || context._showDropDown === false; else combo\">\n    <div style=\"display: flex\" class=\"fd-input-group\">\n        <input\n            fd-input-group-input\n            fd-form-control\n            #inputRef\n            [placeholder]=\"Setting.NullText || ''\"\n            [attr.readonly]=\"true\"\n            [attr.disabled]=\"(disable$ | async) === true ? true : null\"\n            [value]=\"!value ? '' : (value | bbbTranslate)\"\n            [id]=\"id\"\n            [style.direction]=\"Setting.IsLtr === true ? 'ltr' : null\"\n            (input)=\"onValueChange($event)\"\n        />\n        <span\n            fd-input-group-addon\n            *ngIf=\"value && (disableOrReadonly$ | async) !== true\"\n            class=\"fd-input-group__addon--button\"\n        >\n            <button fd-button fdType=\"transparent\" glyph=\"decline\" (click)=\"onClear()\"></button>\n        </span>\n        <span\n            fd-input-group-addon\n            *ngIf=\"!value && (disableOrReadonly$ | async) !== true && Setting.ShowNewButton\"\n            class=\"fd-input-group__addon--button\"\n        >\n            <button fd-button fdType=\"transparent\" glyph=\"add\" (click)=\"onNew()\"></button>\n        </span>\n        <span\n            fd-input-group-addon\n            *ngIf=\"value && (disableOrReadonly$ | async) !== true && Setting.ViewRelatedFormType === 'Show'\"\n            class=\"fd-input-group__addon--button\"\n        >\n            <button fd-button fdType=\"transparent\" glyph=\"edit\" (click)=\"onEdit()\"></button>\n        </span>\n        <span\n            fd-input-group-addon\n            *ngIf=\"value && (disableOrReadonly$ | async) !== true && Setting.ViewRelatedFormType === 'ShowReadOnly'\"\n            class=\"fd-input-group__addon--button\"\n        >\n            <button fd-button fdType=\"transparent\" glyph=\"show\" (click)=\"onEdit()\"></button>\n        </span>\n        <span\n            fd-input-group-addon\n            *ngIf=\"context._showPopup && !value && (disableOrReadonly$ | async) !== true\"\n            class=\"fd-input-group__addon--button\"\n        >\n            <button fd-button fdType=\"transparent\" glyph=\"search\" (click)=\"onSearch()\"></button>\n        </span>\n    </div>\n</ng-container>\n\n<ng-template #combo>\n    <div [class.control-disabled]=\"disable$ | async\" class=\"simple-combo-wrapper\">\n        <fd-combobox\n            #fdCombobox\n            class=\"combo-mo-ulv\"\n            [class.has-report]=\"hasReport\"\n            [placeholder]=\"''\"\n            [mobile]=\"(deviceSize$ | async) === 's'\"\n            [mobileConfig]=\"mobileConfig\"\n            [fillOnSelect]=\"true\"\n            [readOnly]=\"(readonly$ | async) === true ? true : false\"\n            [disabled]=\"(disable$ | async) === true ? true : false\"\n            [dropdownValues]=\"(loading$ | async) === true | moInfoUlvMoList: isDataLoadedFirstTime:ulvAdapter:UlvUi\"\n            [filterFn]=\"customFilter\"\n            [openOnKeyboardEvent]=\"true\"\n            [itemTemplate]=\"template\"\n            [ngModel]=\"valueText | bbbTranslate\"\n            [displayFn]=\"displayFunc\"\n            [showDropdownButton]=\"(disableOrReadonly$ | async) !== true\"\n            (inputTextChange)=\"onInputChange($event)\"\n            (openChange)=\"onOpenChange(fdCombobox, $event)\"\n        >\n        </fd-combobox>\n        <button *ngIf=\"value\" fd-button fdType=\"transparent\" glyph=\"decline\" (click)=\"onClear()\"></button>\n        <fdp-button\n            *ngIf=\"hasReport && (disableOrReadonly$ | async) !== true\"\n            glyph=\"search\"\n            buttonType=\"transparent\"\n            class=\"combo-popup-btn\"\n            (click)=\"onSearch()\"\n        ></fdp-button>\n    </div>\n    <ng-template #template let-item>\n        <div fd-list-content *ngIf=\"item.$isLoading; else showItem\" style=\"width: 100%; height: 20px\">\n            <bsu-mask [size]=\"'s'\" [marginTop]=\"'10px'\"></bsu-mask>\n        </div>\n        <ng-template #showItem>\n            <i fd-list-icon [glyph]=\"item.$Icon\"></i>\n            <span fd-list-title>{{\n                item.isEmpty ? ('NoData' | bbbTranslate) : (item.$MoCaption || item.$Caption | bbbTranslate)\n            }}</span>\n        </ng-template>\n    </ng-template>\n</ng-template>\n"]}
373
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-mo-info-ulv-combo.component.js","sourceRoot":"","sources":["../../../../../projects/barsa-sap-ui/src/lib/ui-mo-info-ulv-combo/ui-mo-info-ulv-combo.component.ts","../../../../../projects/barsa-sap-ui/src/lib/ui-mo-info-ulv-combo/ui-mo-info-ulv-combo.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    HostListener,\n    Input,\n    ViewChild,\n    ChangeDetectionStrategy,\n    OnInit,\n    AfterViewInit\n} from '@angular/core';\nimport { Observable, of, Subject } from 'rxjs';\nimport { debounceTime, filter, distinctUntilChanged, tap, takeUntil, switchMap } from 'rxjs/operators';\nimport { ComboboxComponent, ComboboxItem, DialogRef } from '@fundamental-ngx/core';\n\nimport {\n    FieldBaseComponent,\n    BarsaApi,\n    ReportExtraInfo,\n    MoForReportModel,\n    ClassNamesModel,\n    ViewTypes,\n    MetaobjectDataModel,\n    PreventDefaulEvent,\n    PagingSetting,\n    ReportViewColumn,\n    getUniqueId\n} from 'barsa-novin-ray-core';\n\n@Component({\n    selector: 'bsu-ui-mo-info-ulv-combo',\n    templateUrl: './ui-mo-info-ulv-combo.component.html',\n    styleUrls: ['./ui-mo-info-ulv-combo.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class UiMoInfoUlvComboComponent extends FieldBaseComponent implements OnInit, AfterViewInit {\n    @Input() ulvAdapter: {\n        [key: string]: any;\n        Setting: {\n            [key: string]: any;\n            View: ViewTypes;\n            ClassNames: ClassNamesModel;\n            Extra: ReportExtraInfo;\n            Data: MoForReportModel;\n        };\n    };\n    @Input() Control: any;\n    @Input() UlvUi: any;\n    @Input() UlvMainCtrlr: any;\n    @ViewChild(ComboboxComponent) fdComboRef: ComboboxComponent;\n    isExpand: boolean;\n    smartChange = new Subject<string>();\n    loading$: Observable<boolean>;\n    tickRef: any;\n    inputElement: HTMLInputElement;\n    isFirstLoad: boolean;\n    popoverElement: any;\n    rawValue: string;\n    formSelectionDialog: DialogRef;\n    isOpenSelectionDialog: boolean;\n    hasReport: any;\n    originalValue: any;\n    isDataLoadedFirstTime: boolean;\n    valueText: string;\n    allColumns: ReportViewColumn[] = [];\n    private _openPopupFormSelectionSource = new Subject<void>();\n    private _closeDialogSource = new Subject<void>();\n    private _loadingSource = new Subject<boolean>();\n    private _valueMo: MetaobjectDataModel | null;\n    comboboxId: string;\n\n    @HostListener('keydown.alt', ['$event'])\n    onAlt(e): void {\n        e.stopPropagation();\n        e.preventDefault();\n    }\n    ngOnInit(): void {\n        this.comboboxId = getUniqueId(3);\n        this.loading$ = this._loadingSource.asObservable().pipe(takeUntil(this._onDestroy$));\n        this.loading$.subscribe(() => {\n            this.isDataLoadedFirstTime =\n                typeof this.ulvAdapter?.Setting?.Data?.MoDataList === 'object' ||\n                typeof this.UlvUi?.Setting?.Data?.MoDataList === 'object';\n        });\n        this.smartChange\n            .pipe(\n                takeUntil(this._onDestroy$),\n                debounceTime(200),\n                filter((value) => this._filterSmartChange(value)),\n                distinctUntilChanged(),\n                tap((value) => (this.rawValue = value))\n            )\n            .subscribe((value) => {\n                this.context.fireEvent('SmartChange', this.context, value);\n            });\n        this._openPopupFormSelectionSource\n            .asObservable()\n            .pipe(\n                takeUntil(this._closeDialogSource),\n                takeUntil(this._onDestroy$),\n                filter(() => this.UlvUi && !this.isOpenSelectionDialog && this.context._showPopup),\n                switchMap(() => this._openPopupFormSelection())\n            )\n            .subscribe();\n        super.ngOnInit();\n        this.originalValue = this.value;\n        this.hasReport = this.Setting.RelationViewType === 'ReportView' || this.Setting.ReportName === 'Hierarchical';\n        this.Control = this;\n        setTimeout(() => {\n            this._setValueText(this.value);\n        });\n    }\n    ngAfterViewInit(): void {\n        super.ngAfterViewInit();\n        // this._setComboText(this.value);\n    }\n    onPagingClick(e): void {\n        PreventDefaulEvent(e);\n    }\n    onPageChange(e: number): void {\n        this._loadingSource.next(true);\n        this.ulvAdapter.DataCtrlr.MoveToPage(e, () => {\n            this._loadingSource.next(false);\n        });\n    }\n    onItemClick(e: ComboboxItem): void {\n        const selectedMo = e.item;\n        this._fireValueChange(selectedMo);\n    }\n    onPageChange2(pageSetting: PagingSetting, e): void {\n        PreventDefaulEvent(e);\n        this._loadingSource.next(true);\n        const ulvAdapter = this.ulvAdapter;\n        const temp1 = ulvAdapter.Setting.Data.MoDataList;\n        temp1.splice(temp1.length - 1, 1);\n        const moDataListOld = [...temp1];\n        moDataListOld.forEach((c) => (c.$__IsLast = false));\n        this.ulvAdapter.DataCtrlr.MoveToPage(pageSetting.Page + 1, () => {\n            const moDataList: MetaobjectDataModel[] = ulvAdapter.Setting.Data.MoDataList;\n            moDataList.splice(0, 0, ...moDataListOld);\n            this._loadingSource.next(false);\n        });\n    }\n    onOpenChange(fdCombobox, isOpen: boolean): void {\n        if (isOpen) {\n            this._focus();\n            // fdCombobox.open = false; // it close popup when click on dropdown button in component\n        } else {\n            const inputText = this.fdComboRef?.inputTextValue;\n            if (!this.value && inputText) {\n                this._raiseSmartChange(inputText);\n            }\n        }\n    }\n    onInputChange(e): void {\n        this._raiseSmartChange(e);\n    }\n    onInputChange2(e): void {\n        this._raiseSmartChange(e.target.value);\n    }\n    onValueChange(e): void {\n        this._raiseValueChanged(e.target.value);\n    }\n    onNew(): void {\n        this._triggerClick('New');\n    }\n    onClear(): void {\n        this._triggerClick('Delete');\n    }\n    onEdit(): void {\n        this._triggerClick('Edit');\n    }\n    onSearch(): void {\n        this._triggerClick('Popup');\n    }\n    /* eslint-disable */\n    customFilter(content: any[], searchTerm: string): any[] {\n        return content;\n    }\n\n    displayFunc = (obj: MetaobjectDataModel) => {\n        if (obj) {\n            const colName = this.getFirstColumnName();\n            return this.getMoValueCaption(obj, colName, obj.$Caption);\n        }\n        return '';\n    };\n    getMoValueCaption(valueMo: MetaobjectDataModel | null, colName: string, defaultValue: string): string {\n        if (valueMo === null) {\n            return defaultValue;\n        }\n        let captionValueMo;\n        const molist: MetaobjectDataModel[] = BarsaApi.Common.Util.TryGetValue(\n            this.ulvAdapter,\n            'Setting.Data.MoDataList',\n            []\n        );\n        const foundedMo = molist.find((c) => c.Id === valueMo.Id);\n        if (colName && foundedMo && foundedMo[colName]) {\n            if (foundedMo[colName + '$Caption']) {\n                captionValueMo = foundedMo[colName + '$Caption'];\n            } else if (foundedMo[colName].$Caption) {\n                captionValueMo = foundedMo[colName].$Caption;\n            } else {\n                captionValueMo = foundedMo[colName];\n            }\n        }\n        return this._bbbPipe.transform(captionValueMo || defaultValue);\n    }\n    getFirstColumnName() {\n        let colName = '$Caption';\n        if (this.UlvMainCtrlr && this.UlvMainCtrlr?.Dd?.Setting?.View) {\n            if (this.UlvMainCtrlr.Dd.Setting.View.Columns) {\n                const firstCol = this.UlvMainCtrlr.Dd.Setting.View.Columns.find(\n                    (c) => !c.Name.startsWith('$') && c.Name !== 'Id'\n                );\n                if (firstCol?.Name) {\n                    colName = firstCol.Name;\n                }\n            }\n        }\n        return colName;\n    }\n\n    /* eslint-disable */\n    @Input() IsExpanded = (type) => false;\n    // return this.comboRef.nativeElement.responsivePopover.isOpen();\n    /* eslint-disable */\n    @Input() Collapse = (type) => {};\n    /* eslint-disable */\n    @Input() Expand = (type) => {\n        this.ulvAdapter = this.UlvMainCtrlr[type];\n    };\n    /* eslint-disable */\n    @Input() on = () => {};\n    /* eslint-disable */\n    @Input() Focus = () => {};\n    @Input()\n    SetUlvAdapter = (type, ulvAdapter) => {\n        this.ulvAdapter = ulvAdapter;\n        if (ulvAdapter?.Setting?.View?.Columns?.length) {\n            this.allColumns = ulvAdapter.Setting.View.Columns.filter((c) => c.MetaFieldTypeId > 0);\n        }\n        /* eslint-disable */\n    };\n    @Input()\n    IsUiCreated = (type) => {\n        return true;\n        /* eslint-disable */\n    };\n    @Input()\n    Mask = (type) => {\n        this._loadingSource.next(true);\n        /* eslint-disable */\n    };\n    @Input()\n    hide = (type) => {\n        // this.triggerClick('Normal');\n        if (this.formSelectionDialog) {\n            this.formSelectionDialog.close();\n        }\n        /* eslint-disable */\n    };\n    @Input()\n    show = (type) => {\n        // this.triggerClick('Normal');\n        this._openPopupFormSelectionSource.next(); // rabete taki general info .popup baz mishod ke baiad dropdown bashe.\n        /* eslint-disable */\n    };\n    @Input()\n    Unmask = (type) => {\n        this._loadingSource.next(false);\n        /* eslint-disable */\n    };\n    @Input()\n    getRawValue = () => {\n        return this.rawValue;\n        /* eslint-disable */\n    };\n    protected _setValue(value: any): void {\n        this._setValueText(value);\n        super._setValue(value);\n        // this._setComboText(value);\n    }\n    protected _setValueText(value): void {\n        if (value === null || typeof value === 'undefined') {\n            this._valueMo = null;\n        }\n\n        this.valueText = this._getValueText(value);\n        this._setComboText(this.valueText);\n    }\n    protected _getValueText(value) {\n        if (!value) {\n            return '';\n        } else if (typeof value === 'string') {\n            return value;\n        } else if (typeof value === 'object') {\n            return value.$Caption;\n        }\n        if (typeof value !== 'string' && value && this.UlvMainCtrlr && this.UlvMainCtrlr.Dd) {\n            const view = this.UlvMainCtrlr.Dd.Setting.View;\n            let colName = '$Caption';\n            if (view.Columns) {\n                const firstCol = view.Columns.find((c) => !c.Name.startsWith('$') && c.Name !== 'Id');\n                colName = firstCol?.Name ? firstCol.Name : '$Caption';\n            }\n            return this.getMoValueCaption(this._valueMo, colName, this.valueText);\n        }\n    }\n    protected _setComboText(value: string): void {\n        // if (value === null || typeof value === 'undefined') {\n        // this._valueMo = null;\n        //this.fdComboRef.inputTextValue = '';\n        //this.fdComboRef._cdRef.detectChanges();\n        // }\n        const fdComboRef = this.fdComboRef;\n        const inputText = fdComboRef?.inputTextValue;\n        if (fdComboRef && value != inputText) {\n            const UlvMainCtrlr = this.UlvMainCtrlr;\n            if (UlvMainCtrlr && UlvMainCtrlr.Dd) {\n                const view = UlvMainCtrlr.Dd.Setting.View;\n                let colName = '$Caption';\n                if (view.Columns) {\n                    const firstCol = view.Columns.find((c) => !c.Name.startsWith('$') && c.Name !== 'Id');\n                    colName = firstCol?.Name ? firstCol.Name : '$Caption';\n                }\n                value = this.getMoValueCaption(this._valueMo, colName, value);\n            }\n            fdComboRef.inputText = value ? this._bbbPipe.transform(value) + '' : '';\n            this._cdr.detectChanges();\n        }\n    }\n    protected _openPopupFormSelection(): Observable<boolean> {\n        this.isOpenSelectionDialog = true;\n        this.UlvUi.viewerControl.ShowOkCancelButtons = true; // this is useful to ulv manage toolbar buttons.for example move in tree does not shown\n        this.formSelectionDialog = BarsaApi.Bw.UlvFormMultiSelect.Show(this.context, {\n            ulv1: this.UlvUi,\n            title: this._bbbPipe.transform('Select'),\n            IsLoaded: true\n        });\n        setTimeout(() => {\n            this.isOpenSelectionDialog = false;\n        }, 500);\n        return of(true);\n    }\n    protected _filterSmartChange(value): boolean {\n        let canRequest = this.ulvAdapter && value !== this.value;\n        if (canRequest) {\n            const molist: MetaobjectDataModel[] = BarsaApi.Common.Util.TryGetValue(\n                this.ulvAdapter,\n                'Setting.Data.MoDataList',\n                []\n            );\n            if (!molist) {\n                return true;\n            }\n            const colName = this.getFirstColumnName();\n\n            const findMo = molist.find((mo) => {\n                const caption = this.getMoValueCaption(mo, colName, mo.$Caption);\n                return caption === value;\n            });\n            if (findMo) {\n                canRequest = false;\n                //this._fireValueChange(findMo);\n            }\n        }\n        return canRequest;\n    }\n\n    protected _focus(): void {\n        this._triggerClick('Normal');\n    }\n\n    protected _raiseSmartChange(value): void {\n        this.smartChange.next(value);\n    }\n\n    protected _triggerClick(eventName, value = null): void {\n        this.context.fireEvent('TriggerClick', this.context, eventName, value);\n    }\n\n    protected _raiseValueChanged(caption): void {\n        const inputValue = caption;\n        const molist: MetaobjectDataModel[] = BarsaApi.Common.Util.TryGetValue(\n            this.ulvAdapter,\n            'Setting.Data.MoDataList',\n            []\n        );\n        if (!molist || molist.length === 0) {\n            return;\n        }\n        //const colName = this.getFirstColumnName();\n\n        const mo = molist.find((c) => c.$Caption === inputValue);\n        if (!mo) {\n            return;\n        }\n        this._fireValueChange(mo);\n    }\n    protected _fireValueChange(mo): void {\n        this.value = mo;\n        this._valueMo = mo;\n        this._setValueText(this.value);\n        // this._setComboText(mo.$Caption);\n        // this._cdr.detectChanges();\n        this._triggerClick('ItemSelect', this.value);\n    }\n}\n","<ng-container\n    *ngTemplateOutlet=\"\n        context._showPopup || context._showDropDown === false ? inputTemplate : comboTemplate;\n        context: {\n            $implicit: (loading$ | async) === true | moInfoUlvMoList: isDataLoadedFirstTime:ulvAdapter:UlvUi,\n            deviceSize: deviceSize$ | async,\n            disableOrReadonly: disableOrReadonly$ | async,\n            disable: disable$ | async,\n            readonly: readonly$ | async\n        }\n    \"\n>\n</ng-container>\n<ng-template\n    #inputTemplate\n    let-deviceSize=\"deviceSize\"\n    let-disableOrReadonly=\"disableOrReadonly\"\n    let-disable=\"disable\"\n    let-readonly=\"readonly\"\n>\n    <div style=\"display: flex\" class=\"fd-input-group\">\n        <input\n            fd-input-group-input\n            fd-form-control\n            #inputRef\n            [placeholder]=\"Setting.NullText || ''\"\n            [attr.readonly]=\"true\"\n            [attr.disabled]=\"disable === true ? true : null\"\n            [value]=\"!value ? '' : (value | bbbTranslate)\"\n            [id]=\"id\"\n            [style.direction]=\"Setting.IsLtr === true ? 'ltr' : null\"\n            (input)=\"onValueChange($event)\"\n        />\n        <span fd-input-group-addon *ngIf=\"value && disableOrReadonly !== true\" class=\"fd-input-group__addon--button\">\n            <button fd-button fdType=\"transparent\" glyph=\"decline\" (click)=\"onClear()\"></button>\n        </span>\n        <span\n            fd-input-group-addon\n            *ngIf=\"!value && disableOrReadonly !== true && Setting.ShowNewButton\"\n            class=\"fd-input-group__addon--button\"\n        >\n            <button fd-button fdType=\"transparent\" glyph=\"add\" (click)=\"onNew()\"></button>\n        </span>\n        <span\n            fd-input-group-addon\n            *ngIf=\"value && disableOrReadonly !== true && Setting.ViewRelatedFormType === 'Show'\"\n            class=\"fd-input-group__addon--button\"\n        >\n            <button fd-button fdType=\"transparent\" glyph=\"edit\" (click)=\"onEdit()\"></button>\n        </span>\n        <span\n            fd-input-group-addon\n            *ngIf=\"value && disableOrReadonly !== true && Setting.ViewRelatedFormType === 'ShowReadOnly'\"\n            class=\"fd-input-group__addon--button\"\n        >\n            <button fd-button fdType=\"transparent\" glyph=\"show\" (click)=\"onEdit()\"></button>\n        </span>\n        <span\n            fd-input-group-addon\n            *ngIf=\"context._showPopup && !value && disableOrReadonly !== true\"\n            class=\"fd-input-group__addon--button\"\n        >\n            <button fd-button fdType=\"transparent\" glyph=\"search\" (click)=\"onSearch()\"></button>\n        </span>\n    </div>\n</ng-template>\n\n<ng-template\n    #comboTemplate\n    let-moDataList\n    let-deviceSize=\"deviceSize\"\n    let-disableOrReadonly=\"disableOrReadonly\"\n    let-disable=\"disable\"\n    let-readonly=\"readonly\"\n>\n    <div [class.control-disabled]=\"disable\" class=\"simple-combo-wrapper\">\n        <fd-combobox\n            #fdCombobox\n            class=\"combo-mo-ulv\"\n            [comboboxId]=\"comboboxId\"\n            [class.has-report]=\"hasReport\"\n            [placeholder]=\"''\"\n            [mobile]=\"deviceSize === 's'\"\n            [mobileConfig]=\"mobileConfig\"\n            [fillOnSelect]=\"true\"\n            [readOnly]=\"readonly === true ? true : false\"\n            [disabled]=\"disable === true ? true : false\"\n            [dropdownValues]=\"moDataList\"\n            [filterFn]=\"customFilter\"\n            [openOnKeyboardEvent]=\"true\"\n            [byline]=\"allColumns.length > 0\"\n            [itemTemplate]=\"itemTemplate\"\n            [ngModel]=\"valueText | bbbTranslate\"\n            [displayFn]=\"displayFunc\"\n            [showDropdownButton]=\"disableOrReadonly !== true\"\n            (itemClicked)=\"onItemClick($event)\"\n            (inputTextChange)=\"onInputChange($event)\"\n            (openChange)=\"onOpenChange(fdCombobox, $event)\"\n        >\n        </fd-combobox>\n        <button\n            *ngIf=\"value && disableOrReadonly !== true\"\n            fd-button\n            fdType=\"transparent\"\n            glyph=\"decline\"\n            (click)=\"onClear()\"\n        ></button>\n        <fdp-button\n            *ngIf=\"hasReport && disableOrReadonly !== true\"\n            glyph=\"search\"\n            buttonType=\"transparent\"\n            class=\"combo-popup-btn\"\n            (click)=\"onSearch()\"\n        ></fdp-button>\n    </div>\n    <ng-template #itemTemplate let-item>\n        <div fd-list-content *ngIf=\"item.$isLoading; else itemWrapper\" style=\"width: 100%; height: 20px\">\n            <bsu-mask [size]=\"'s'\" [marginTop]=\"'10px'\"></bsu-mask>\n        </div>\n        <ng-template #itemWrapper>\n            <ng-container *ngIf=\"item.$LoadMore; else showItem\">\n                <!-- <bsu-ulv-paging\n                    (click)=\"onPagingClick($event)\"\n                    (pageChange)=\"onPageChange($event)\"\n                    [pagingSetting]=\"ulvAdapter.Setting.Data.Paging\"\n                >\n                </bsu-ulv-paging> -->\n                <button\n                    style=\"width: 100%\"\n                    *ngIf=\"ulvAdapter.Setting.Data.Paging.Page + 1 < ulvAdapter.Setting.Data.Paging.TotalPages\"\n                    fd-button\n                    (click)=\"onPageChange2(ulvAdapter.Setting.Data.Paging, $event)\"\n                    [label]=\"'More' | bbbTranslate\"\n                ></button>\n            </ng-container>\n        </ng-template>\n        <ng-template #showItem>\n            <ng-container *ngIf=\"allColumns?.length; else captionTemplate\">\n                <div *ngIf=\"!item.$__IsLast\" class=\"moinfoulv devider\"></div>\n                <span fd-list-thumbnail *ngIf=\"item.$Icon\"><fd-icon [glyph]=\"item.$Icon\"></fd-icon></span>\n                <div fd-list-content class=\"moinfoulv hasColumns\">\n                    <div fd-list-title class=\"title\">{{ allColumns[0].Alias | rval: item:allColumns:true }}</div>\n                    <div fd-list-byline class=\"byline\" *ngIf=\"allColumns[1]\">\n                        {{ allColumns[1].Alias | rval: item:allColumns:true }}\n                    </div>\n                    <div style=\"display: flex; column-gap: 8px; flex-wrap: wrap\">\n                        <ng-container *ngFor=\"let column of allColumns; let index = index\">\n                            <ng-container *ngIf=\"index > 1\">\n                                <ng-container *ngIf=\"column.Alias | rval: item:allColumns:true as value\">\n                                    <span> {{ column.Alias }}:{{ value }}</span>\n                                </ng-container>\n                            </ng-container>\n                        </ng-container>\n                    </div>\n                </div>\n            </ng-container>\n            <ng-template #captionTemplate>\n                <span fd-list-title>{{\n                    item.isEmpty ? ('NoData' | bbbTranslate) : (item.$MoCaption || item.$Caption | bbbTranslate)\n                }}</span>\n            </ng-template>\n        </ng-template>\n    </ng-template>\n</ng-template>\n"]}
@@ -6,9 +6,17 @@ import * as i2 from "@angular/forms";
6
6
  import * as i3 from "@fundamental-ngx/core/form";
7
7
  import * as i4 from "@fundamental-ngx/core/radio";
8
8
  export class UiRadioGroupComponent extends DeviceInfoFieldBaseComponent {
9
+ constructor() {
10
+ super(...arguments);
11
+ this.isVertically = false;
12
+ this.onlyInMobileVertically = false;
13
+ }
9
14
  ngOnInit() {
10
15
  super.ngOnInit();
16
+ const parameters = this.parameters;
11
17
  this.value = this.context.items.find((c) => c.inputValue === this.value);
18
+ this.onlyInMobileVertically = parameters?.OnlyInMobileVertically;
19
+ this.isVertically = parameters?.IsVertically;
12
20
  }
13
21
  onRadioClicked(item) {
14
22
  this.value = item;
@@ -16,9 +24,9 @@ export class UiRadioGroupComponent extends DeviceInfoFieldBaseComponent {
16
24
  }
17
25
  }
18
26
  UiRadioGroupComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: UiRadioGroupComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
19
- UiRadioGroupComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: UiRadioGroupComponent, selector: "bsu-ui-radio-group", usesInheritance: true, ngImport: i0, template: "<fd-form-group [isInline]=\"true\">\n <ng-container *ngFor=\"let item of context.items; let i = index; let first = first\">\n <div fd-form-item>\n <fd-radio-button\n *ngIf=\"!item.IsEmpty\"\n [value]=\"item.inputValue\"\n [id]=\"'radio-' + id + i\"\n [name]=\"'radio' + id + i\"\n [disabled]=\"(disableOrReadonly$ | async)!!\"\n [ngModel]=\"value?.inputValue\"\n (click)=\"onRadioClicked(item)\"\n >\n {{ item.boxLabel }}\n </fd-radio-button>\n </div>\n </ng-container>\n</fd-form-group>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.FormItemComponent, selector: "[fd-form-item]", inputs: ["isInline", "horizontal"] }, { kind: "component", type: i3.FormGroupComponent, selector: "fd-form-group", inputs: ["isInline"] }, { kind: "component", type: i4.RadioButtonComponent, selector: "fd-radio-button", inputs: ["ariaLabel", "ariaLabelledBy", "ariaDescribedBy", "title", "tabIndex", "state", "disabled", "selectedValue", "name", "id", "value", "required"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
27
+ UiRadioGroupComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.7", type: UiRadioGroupComponent, selector: "bsu-ui-radio-group", usesInheritance: true, ngImport: i0, template: "<fd-form-group [isInline]=\"!isVertically && !(isMobileDevice && onlyInMobileVertically)\">\n <ng-container *ngFor=\"let item of context.items; let i = index; let first = first\">\n <div fd-form-item>\n <fd-radio-button\n *ngIf=\"!item.IsEmpty\"\n [value]=\"item.inputValue\"\n [id]=\"'radio-' + id + i\"\n [name]=\"'radio' + id + i\"\n [disabled]=\"(disableOrReadonly$ | async)!!\"\n [ngModel]=\"value?.inputValue\"\n (click)=\"onRadioClicked(item)\"\n >\n {{ item.boxLabel }}\n </fd-radio-button>\n </div>\n </ng-container>\n</fd-form-group>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.FormItemComponent, selector: "[fd-form-item]", inputs: ["isInline", "horizontal"] }, { kind: "component", type: i3.FormGroupComponent, selector: "fd-form-group", inputs: ["isInline"] }, { kind: "component", type: i4.RadioButtonComponent, selector: "fd-radio-button", inputs: ["ariaLabel", "ariaLabelledBy", "ariaDescribedBy", "title", "tabIndex", "state", "disabled", "selectedValue", "name", "id", "value", "required"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
20
28
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.7", ngImport: i0, type: UiRadioGroupComponent, decorators: [{
21
29
  type: Component,
22
- args: [{ selector: 'bsu-ui-radio-group', changeDetection: ChangeDetectionStrategy.OnPush, template: "<fd-form-group [isInline]=\"true\">\n <ng-container *ngFor=\"let item of context.items; let i = index; let first = first\">\n <div fd-form-item>\n <fd-radio-button\n *ngIf=\"!item.IsEmpty\"\n [value]=\"item.inputValue\"\n [id]=\"'radio-' + id + i\"\n [name]=\"'radio' + id + i\"\n [disabled]=\"(disableOrReadonly$ | async)!!\"\n [ngModel]=\"value?.inputValue\"\n (click)=\"onRadioClicked(item)\"\n >\n {{ item.boxLabel }}\n </fd-radio-button>\n </div>\n </ng-container>\n</fd-form-group>\n" }]
30
+ args: [{ selector: 'bsu-ui-radio-group', changeDetection: ChangeDetectionStrategy.OnPush, template: "<fd-form-group [isInline]=\"!isVertically && !(isMobileDevice && onlyInMobileVertically)\">\n <ng-container *ngFor=\"let item of context.items; let i = index; let first = first\">\n <div fd-form-item>\n <fd-radio-button\n *ngIf=\"!item.IsEmpty\"\n [value]=\"item.inputValue\"\n [id]=\"'radio-' + id + i\"\n [name]=\"'radio' + id + i\"\n [disabled]=\"(disableOrReadonly$ | async)!!\"\n [ngModel]=\"value?.inputValue\"\n (click)=\"onRadioClicked(item)\"\n >\n {{ item.boxLabel }}\n </fd-radio-button>\n </div>\n </ng-container>\n</fd-form-group>\n" }]
23
31
  }] });
24
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWktcmFkaW8tZ3JvdXAuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvdWktcmFkaW8tZ3JvdXAvdWktcmFkaW8tZ3JvdXAuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvdWktcmFkaW8tZ3JvdXAvdWktcmFkaW8tZ3JvdXAuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUMzRSxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQzs7Ozs7O0FBT3pFLE1BQU0sT0FBTyxxQkFBc0IsU0FBUSw0QkFBNEI7SUFDbkUsUUFBUTtRQUNKLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUNqQixJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLFVBQVUsS0FBSyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDN0UsQ0FBQztJQUVELGNBQWMsQ0FBQyxJQUFJO1FBQ2YsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUM7UUFDbEIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDaEMsQ0FBQzs7a0hBVFEscUJBQXFCO3NHQUFyQixxQkFBcUIsaUZDUmxDLHdwQkFpQkE7MkZEVGEscUJBQXFCO2tCQU5qQyxTQUFTOytCQUNJLG9CQUFvQixtQkFHYix1QkFBdUIsQ0FBQyxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IERldmljZUluZm9GaWVsZEJhc2VDb21wb25lbnQgfSBmcm9tICcuLi9kZXZpY2UtaW5mby1maWVsZC1iYXNlJztcclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ2JzdS11aS1yYWRpby1ncm91cCcsXHJcbiAgICB0ZW1wbGF0ZVVybDogJy4vdWktcmFkaW8tZ3JvdXAuY29tcG9uZW50Lmh0bWwnLFxyXG4gICAgc3R5bGVVcmxzOiBbJy4vdWktcmFkaW8tZ3JvdXAuY29tcG9uZW50LnNjc3MnXSxcclxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBVaVJhZGlvR3JvdXBDb21wb25lbnQgZXh0ZW5kcyBEZXZpY2VJbmZvRmllbGRCYXNlQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcclxuICAgIG5nT25Jbml0KCk6IHZvaWQge1xyXG4gICAgICAgIHN1cGVyLm5nT25Jbml0KCk7XHJcbiAgICAgICAgdGhpcy52YWx1ZSA9IHRoaXMuY29udGV4dC5pdGVtcy5maW5kKChjKSA9PiBjLmlucHV0VmFsdWUgPT09IHRoaXMudmFsdWUpO1xyXG4gICAgfVxyXG5cclxuICAgIG9uUmFkaW9DbGlja2VkKGl0ZW0pOiB2b2lkIHtcclxuICAgICAgICB0aGlzLnZhbHVlID0gaXRlbTtcclxuICAgICAgICB0aGlzLnZhbHVlQ2hhbmdlLmVtaXQoaXRlbSk7XHJcbiAgICB9XHJcbn1cclxuIiwiPGZkLWZvcm0tZ3JvdXAgW2lzSW5saW5lXT1cInRydWVcIj5cbiAgICA8bmctY29udGFpbmVyICpuZ0Zvcj1cImxldCBpdGVtIG9mIGNvbnRleHQuaXRlbXM7IGxldCBpID0gaW5kZXg7IGxldCBmaXJzdCA9IGZpcnN0XCI+XG4gICAgICAgIDxkaXYgZmQtZm9ybS1pdGVtPlxuICAgICAgICAgICAgPGZkLXJhZGlvLWJ1dHRvblxuICAgICAgICAgICAgICAgICpuZ0lmPVwiIWl0ZW0uSXNFbXB0eVwiXG4gICAgICAgICAgICAgICAgW3ZhbHVlXT1cIml0ZW0uaW5wdXRWYWx1ZVwiXG4gICAgICAgICAgICAgICAgW2lkXT1cIidyYWRpby0nICsgaWQgKyBpXCJcbiAgICAgICAgICAgICAgICBbbmFtZV09XCIncmFkaW8nICsgaWQgKyBpXCJcbiAgICAgICAgICAgICAgICBbZGlzYWJsZWRdPVwiKGRpc2FibGVPclJlYWRvbmx5JCB8IGFzeW5jKSEhXCJcbiAgICAgICAgICAgICAgICBbbmdNb2RlbF09XCJ2YWx1ZT8uaW5wdXRWYWx1ZVwiXG4gICAgICAgICAgICAgICAgKGNsaWNrKT1cIm9uUmFkaW9DbGlja2VkKGl0ZW0pXCJcbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgICB7eyBpdGVtLmJveExhYmVsIH19XG4gICAgICAgICAgICA8L2ZkLXJhZGlvLWJ1dHRvbj5cbiAgICAgICAgPC9kaXY+XG4gICAgPC9uZy1jb250YWluZXI+XG48L2ZkLWZvcm0tZ3JvdXA+XG4iXX0=
32
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWktcmFkaW8tZ3JvdXAuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvdWktcmFkaW8tZ3JvdXAvdWktcmFkaW8tZ3JvdXAuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYmFyc2Etc2FwLXVpL3NyYy9saWIvdWktcmFkaW8tZ3JvdXAvdWktcmFkaW8tZ3JvdXAuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUMzRSxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQzs7Ozs7O0FBT3pFLE1BQU0sT0FBTyxxQkFBc0IsU0FBUSw0QkFBNEI7SUFOdkU7O1FBT0ksaUJBQVksR0FBRyxLQUFLLENBQUM7UUFDckIsMkJBQXNCLEdBQUcsS0FBSyxDQUFDO0tBYWxDO0lBWkcsUUFBUTtRQUNKLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUNqQixNQUFNLFVBQVUsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDO1FBQ25DLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsVUFBVSxLQUFLLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUN6RSxJQUFJLENBQUMsc0JBQXNCLEdBQUcsVUFBVSxFQUFFLHNCQUFzQixDQUFDO1FBQ2pFLElBQUksQ0FBQyxZQUFZLEdBQUcsVUFBVSxFQUFFLFlBQVksQ0FBQztJQUNqRCxDQUFDO0lBRUQsY0FBYyxDQUFDLElBQUk7UUFDZixJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQztRQUNsQixJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNoQyxDQUFDOztrSEFkUSxxQkFBcUI7c0dBQXJCLHFCQUFxQixpRkNSbEMsZ3RCQWlCQTsyRkRUYSxxQkFBcUI7a0JBTmpDLFNBQVM7K0JBQ0ksb0JBQW9CLG1CQUdiLHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERldmljZUluZm9GaWVsZEJhc2VDb21wb25lbnQgfSBmcm9tICcuLi9kZXZpY2UtaW5mby1maWVsZC1iYXNlJztcbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnYnN1LXVpLXJhZGlvLWdyb3VwJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vdWktcmFkaW8tZ3JvdXAuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL3VpLXJhZGlvLWdyb3VwLmNvbXBvbmVudC5zY3NzJ10sXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgVWlSYWRpb0dyb3VwQ29tcG9uZW50IGV4dGVuZHMgRGV2aWNlSW5mb0ZpZWxkQmFzZUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gICAgaXNWZXJ0aWNhbGx5ID0gZmFsc2U7XG4gICAgb25seUluTW9iaWxlVmVydGljYWxseSA9IGZhbHNlO1xuICAgIG5nT25Jbml0KCk6IHZvaWQge1xuICAgICAgICBzdXBlci5uZ09uSW5pdCgpO1xuICAgICAgICBjb25zdCBwYXJhbWV0ZXJzID0gdGhpcy5wYXJhbWV0ZXJzO1xuICAgICAgICB0aGlzLnZhbHVlID0gdGhpcy5jb250ZXh0Lml0ZW1zLmZpbmQoKGMpID0+IGMuaW5wdXRWYWx1ZSA9PT0gdGhpcy52YWx1ZSk7XG4gICAgICAgIHRoaXMub25seUluTW9iaWxlVmVydGljYWxseSA9IHBhcmFtZXRlcnM/Lk9ubHlJbk1vYmlsZVZlcnRpY2FsbHk7XG4gICAgICAgIHRoaXMuaXNWZXJ0aWNhbGx5ID0gcGFyYW1ldGVycz8uSXNWZXJ0aWNhbGx5O1xuICAgIH1cblxuICAgIG9uUmFkaW9DbGlja2VkKGl0ZW0pOiB2b2lkIHtcbiAgICAgICAgdGhpcy52YWx1ZSA9IGl0ZW07XG4gICAgICAgIHRoaXMudmFsdWVDaGFuZ2UuZW1pdChpdGVtKTtcbiAgICB9XG59XG4iLCI8ZmQtZm9ybS1ncm91cCBbaXNJbmxpbmVdPVwiIWlzVmVydGljYWxseSAmJiAhKGlzTW9iaWxlRGV2aWNlICYmIG9ubHlJbk1vYmlsZVZlcnRpY2FsbHkpXCI+XG4gICAgPG5nLWNvbnRhaW5lciAqbmdGb3I9XCJsZXQgaXRlbSBvZiBjb250ZXh0Lml0ZW1zOyBsZXQgaSA9IGluZGV4OyBsZXQgZmlyc3QgPSBmaXJzdFwiPlxuICAgICAgICA8ZGl2IGZkLWZvcm0taXRlbT5cbiAgICAgICAgICAgIDxmZC1yYWRpby1idXR0b25cbiAgICAgICAgICAgICAgICAqbmdJZj1cIiFpdGVtLklzRW1wdHlcIlxuICAgICAgICAgICAgICAgIFt2YWx1ZV09XCJpdGVtLmlucHV0VmFsdWVcIlxuICAgICAgICAgICAgICAgIFtpZF09XCIncmFkaW8tJyArIGlkICsgaVwiXG4gICAgICAgICAgICAgICAgW25hbWVdPVwiJ3JhZGlvJyArIGlkICsgaVwiXG4gICAgICAgICAgICAgICAgW2Rpc2FibGVkXT1cIihkaXNhYmxlT3JSZWFkb25seSQgfCBhc3luYykhIVwiXG4gICAgICAgICAgICAgICAgW25nTW9kZWxdPVwidmFsdWU/LmlucHV0VmFsdWVcIlxuICAgICAgICAgICAgICAgIChjbGljayk9XCJvblJhZGlvQ2xpY2tlZChpdGVtKVwiXG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAge3sgaXRlbS5ib3hMYWJlbCB9fVxuICAgICAgICAgICAgPC9mZC1yYWRpby1idXR0b24+XG4gICAgICAgIDwvZGl2PlxuICAgIDwvbmctY29udGFpbmVyPlxuPC9mZC1mb3JtLWdyb3VwPlxuIl19