@rangertechnologies/ngnxt
Version:
This library was used for creating dymanic UI based on the input JSON/data
221 lines • 41.5 kB
JavaScript
import { Component, Input, Output, EventEmitter } from '@angular/core';
import { ChangeWrapper } from '../../model/changeWrapper';
import * as i0 from "@angular/core";
import * as i1 from "../../services/change.service";
import * as i2 from "../../services/data.service";
import * as i3 from "../../i18n.service";
import * as i4 from "@angular/common";
import * as i5 from "@angular/forms";
import * as i6 from "@ng-select/ng-select";
export class CustomDropdownComponent {
changeService;
dataService;
i18nService;
options = [];
placeholder;
apiMeta;
selectedValue;
progressBar;
id;
readOnly = false; // VD 12Jun24 - readonly change
errorMessage;
error;
fromShengel = false;
question;
referenceField;
token; // VD 19JAN24 - getting token as input
valueChange = new EventEmitter();
invalidFieldIds = [];
constructor(changeService, dataService, i18nService) {
this.changeService = changeService;
this.dataService = dataService;
this.i18nService = i18nService;
this.changeService.submitValidate$.subscribe((data) => {
// to get the error message's field id's
this.invalidFieldIds.push(data);
});
}
labelField;
valueField;
subscription;
//public apiObj:APIMeta;
uniqueKey;
apiObj = {};
ngOnInit() {
}
getOptions() {
console.log('test click');
// console.log('inside oninit of custom-dropdown of ' + this.id);
// console.log(this.apiMeta);
//VD 07Aug24 - isDependentField change
// VD 25Oct24 - changes
this.placeholder = this.placeholder ? this.placeholder : '---Select option---';
if (this.apiMeta) {
try {
// MSM-27MAR25 Ensure ques.subText is always an object by parsing it if it's a string
this.apiObj = typeof this.apiMeta === 'object' ? this.apiMeta : JSON.parse(this.apiMeta);
// Check if apiObj and apiObj.field are defined
if (this.apiObj && this.apiObj.field) {
this.labelField = this.apiObj.field;
this.uniqueKey = this.apiObj.uniqueKey;
const cachedOptions = localStorage.getItem(this.uniqueKey);
if (cachedOptions) {
this.options = JSON.parse(cachedOptions);
}
else {
if (!this.apiObj.isDependentField) {
this.options = [];
}
// VD 09Sep24- setup the query param for api call // MR 08JAN24 DependentField API Fix moved below logic from above if condition
let fullEndPoint;
if (this.apiObj.endpoint) {
if (this.apiObj.queryValueReference && this.apiObj.queryField) {
// process the end point with query param
let queryReferences = this.apiObj.queryValueReference.split(',');
let queryFields = this.apiObj.queryField.split(','); // MR 08JAN24 similar to above valuereference get list of QUERY Fields
let queryValues = this.apiObj.queryValue.split(','); // MR 08JAN24 similar to above valuereference get list of QUERY Values (Default)
let queryParams = [];
let qIndex = 0; // MR 08JAN24 Query Index
// Iterate over queryReferences and find the corresponding element in referenceData
queryReferences.forEach(reference => {
// Find the element in referenceData that matches the current reference
// RS 09DEC24 Changed keys
let matchingElement = this.question?.referenceQueryData.find(element => element.referenceField === reference);
// If a matching element is found, get its input value and create a query parameter
if (reference && matchingElement) { // MR 08JAN24 if reference exist & matching element found
queryParams.push(`${queryFields[qIndex]}=${matchingElement.input}`); // MR 08JAN24 removed reference
}
else { // MR 08JAN24 included option for multiple query params and default value in case of reference is not found
queryParams.push(`${queryFields[qIndex]}=${queryValues[qIndex]}`);
}
qIndex++;
});
fullEndPoint = this.apiObj.endpoint + '?' + queryParams.join('&');
console.log(fullEndPoint);
}
else {
// if no query param get the actual endPoint
fullEndPoint = this.apiObj.endpoint;
}
// VD 19JAN24 - added one more param for authentication
this.dataService.apiResponse(fullEndPoint)?.subscribe((apiResponse) => {
// HA 18-JAN-24 Assigned apiresponse directly if we have the response in array also
// VD 19JAN24 - if response has key with value(which is array)
let responses;
if (this.apiObj.variable) {
// VD 21May24 - handling multiple child objects
// VD 22May24 - used common service file
responses = this.dataService.getValue(apiResponse, this.apiObj.variable);
let results = [];
// HA 19JAN24 To avoid undefined error in console
for (let i = 0; i < responses?.length; i++) {
var resp = responses[i];
results.push(resp);
}
this.options = results;
}
else { // VD 19JAN24 - if response has value(which is array) only
responses = apiResponse;
this.options = responses;
}
// VD 25Oct24 - Store fetched options in local storage
if (this.uniqueKey) {
localStorage.setItem(this.uniqueKey, JSON.stringify(this.options));
}
// Reference https://www.npmjs.com/package/@ng-select/ng-select
});
}
// VD NOV23 - handle the dependent update for dropdown
// VD 09Sep24- push the dependent field values for dropdown
let sourceId = this.apiObj.sourceQuestionId;
if (sourceId && this.apiObj.variable || this.apiObj.valueField) {
// Subscribe for the changes
this.subscription = this.changeService.changeAnnounced$.subscribe((changeValue) => {
if (changeValue != undefined) {
// console.log('inside subscription for the change');
if (changeValue.valueObj != undefined && changeValue.fromQuestionId == this.apiObj.sourceQuestionId) {
// this.selectedValue = changeValue.valueObj[this.apiObj.valueField];
// let value ={};
// value['name'] = this.selectedValue;
let responses;
if (this.apiObj.variable) {
responses = this.dataService.getValue(changeValue.valueObj, this.apiObj.variable);
let results = [];
for (let i = 0; i < responses?.length; i++) {
var resp = responses[i];
results.push(resp);
}
this.options = results;
}
else {
responses = changeValue.valueObj;
this.options = responses;
}
// VD 25Oct24 - Store fetched options in local storage
if (this.uniqueKey) {
localStorage.setItem(this.uniqueKey, JSON.stringify(this.options));
}
}
this.changeService.confirmChange(this.apiObj.sourceQuestionId);
}
});
}
}
}
}
catch (error) {
console.error('Error parsing apiMeta:', error);
}
}
}
// VD 22May24 - used common service file
selectChange(event) {
console.log('inside selectChange from ' + this.id);
// console.log(event);
let change = new ChangeWrapper(); // ChangeWrapper = JSON.parse('{}');
change.fromQuestionId = this.id;
change.valueObj = event ? event : '';
change.referenceField = this.referenceField;
change.selectedObj = event ? event[this.labelField] : '';
this.valueChange.emit(change);
// once got value in dropdown remove the error validation
if (event) {
this.invalidFieldIds = [];
}
}
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CustomDropdownComponent, deps: [{ token: i1.ChangeService }, { token: i2.DataService }, { token: i3.I18nService }], target: i0.ɵɵFactoryTarget.Component });
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CustomDropdownComponent, selector: "app-custom-dropdown", inputs: { options: "options", placeholder: "placeholder", apiMeta: "apiMeta", selectedValue: "selectedValue", progressBar: "progressBar", id: "id", readOnly: "readOnly", errorMessage: "errorMessage", error: "error", fromShengel: "fromShengel", question: "question", referenceField: "referenceField", token: "token" }, outputs: { valueChange: "valueChange" }, ngImport: i0, template: "<!-- HA 18-JAN-24 Commenting these lines as we don't have to use shengel here -->\n<!-- <select\n [ngClass]=\"{\n 'dt-line dpDown down myt-dropbox myt-border-r myt-font1': progressBar,\n 'custom-select': !progressBar\n }\" class=\"custom-select mr-sm-2 dd-height\" \n [id]=\"id\" \n [(ngModel)]=\"selectedValue\"\n (change)=\"selectChange($event.target.value);\" \n [style.borderColor]=\"error ? 'red' : '#858585'\"\n [style.color]=\"error ? 'red' : ''\">\n <option *ngFor=\"let option of options\" [value]=\"this.apiMeta !== undefined ? option.title : option.value\" class=\"option\">{{ this.apiMeta !== undefined ? option.title : option.value }}</option>\n <option *ngIf=\"errorMessage\" value=\"\" disabled hidden>{{ errorMessage }}</option>\n</select> -->\n<!-- // VD 12Jun24 - readonly change-->\n<!-- VD 01Aug24 - validation change-->\n<!-- VD 07Aug24 - isDependentField change-->\n<!-- VD 25Oct24 - changes-->\n<!-- RS 09DEC24 Changed keys--> \n <!-- AP 28MAR25 LabelField Checking -->\n <!-- AP 02APR25 If apiObj exists and is not a dependent field, use option[labelField], otherwise use option.value -->\n<ng-select\n [class]=\"invalidFieldIds.includes(id) || error ? 'shengel-custom-select invalid' : 'shengel-custom-select'\"\n [(ngModel)]=\"selectedValue\" \n [placeholder]=\"placeholder\"\n [disabled]=\"readOnly\"\n (click)=\"getOptions()\"\n (change)=\"selectChange($event)\"\n [id]=\"id\">\n <ng-option \n *ngFor=\"let option of options\" \n [value]=\"apiObj && !apiObj.isDependentField && option[labelField] ? option[labelField] : option?.value\">\n {{ apiObj && !apiObj.isDependentField && option[labelField] ? option[labelField] : option?.value }}\n </ng-option> \n</ng-select>\n<span *ngIf=\"error || invalidFieldIds.includes(id)\" class=\"error-msg\">{{errorMessage}}</span>\n", styles: [".ng-select{width:100%}.invalid{border:1px solid red!important}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { 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: "component", type: i6.NgSelectComponent, selector: "ng-select", inputs: ["ariaLabelDropdown", "bindLabel", "bindValue", "ariaLabel", "markFirst", "placeholder", "fixedPlaceholder", "notFoundText", "typeToSearchText", "preventToggleOnRightClick", "addTagText", "loadingText", "clearAllText", "appearance", "dropdownPosition", "appendTo", "loading", "closeOnSelect", "hideSelected", "selectOnTab", "openOnEnter", "maxSelectedItems", "groupBy", "groupValue", "bufferAmount", "virtualScroll", "selectableGroup", "selectableGroupAsModel", "searchFn", "trackByFn", "clearOnBackspace", "labelForId", "inputAttrs", "tabIndex", "readonly", "searchWhileComposing", "minTermLength", "editableSearchTerm", "ngClass", "typeahead", "multiple", "addTag", "searchable", "clearable", "isOpen", "items", "compareWith", "clearSearchOnAdd", "deselectOnClick", "keyDownFn"], outputs: ["blur", "focus", "change", "open", "close", "search", "clear", "add", "remove", "scroll", "scrollToEnd"] }, { kind: "component", type: i6.NgOptionComponent, selector: "ng-option", inputs: ["value", "disabled"] }] });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CustomDropdownComponent, decorators: [{
type: Component,
args: [{ selector: 'app-custom-dropdown', template: "<!-- HA 18-JAN-24 Commenting these lines as we don't have to use shengel here -->\n<!-- <select\n [ngClass]=\"{\n 'dt-line dpDown down myt-dropbox myt-border-r myt-font1': progressBar,\n 'custom-select': !progressBar\n }\" class=\"custom-select mr-sm-2 dd-height\" \n [id]=\"id\" \n [(ngModel)]=\"selectedValue\"\n (change)=\"selectChange($event.target.value);\" \n [style.borderColor]=\"error ? 'red' : '#858585'\"\n [style.color]=\"error ? 'red' : ''\">\n <option *ngFor=\"let option of options\" [value]=\"this.apiMeta !== undefined ? option.title : option.value\" class=\"option\">{{ this.apiMeta !== undefined ? option.title : option.value }}</option>\n <option *ngIf=\"errorMessage\" value=\"\" disabled hidden>{{ errorMessage }}</option>\n</select> -->\n<!-- // VD 12Jun24 - readonly change-->\n<!-- VD 01Aug24 - validation change-->\n<!-- VD 07Aug24 - isDependentField change-->\n<!-- VD 25Oct24 - changes-->\n<!-- RS 09DEC24 Changed keys--> \n <!-- AP 28MAR25 LabelField Checking -->\n <!-- AP 02APR25 If apiObj exists and is not a dependent field, use option[labelField], otherwise use option.value -->\n<ng-select\n [class]=\"invalidFieldIds.includes(id) || error ? 'shengel-custom-select invalid' : 'shengel-custom-select'\"\n [(ngModel)]=\"selectedValue\" \n [placeholder]=\"placeholder\"\n [disabled]=\"readOnly\"\n (click)=\"getOptions()\"\n (change)=\"selectChange($event)\"\n [id]=\"id\">\n <ng-option \n *ngFor=\"let option of options\" \n [value]=\"apiObj && !apiObj.isDependentField && option[labelField] ? option[labelField] : option?.value\">\n {{ apiObj && !apiObj.isDependentField && option[labelField] ? option[labelField] : option?.value }}\n </ng-option> \n</ng-select>\n<span *ngIf=\"error || invalidFieldIds.includes(id)\" class=\"error-msg\">{{errorMessage}}</span>\n", styles: [".ng-select{width:100%}.invalid{border:1px solid red!important}\n"] }]
}], ctorParameters: () => [{ type: i1.ChangeService }, { type: i2.DataService }, { type: i3.I18nService }], propDecorators: { options: [{
type: Input
}], placeholder: [{
type: Input
}], apiMeta: [{
type: Input
}], selectedValue: [{
type: Input
}], progressBar: [{
type: Input
}], id: [{
type: Input
}], readOnly: [{
type: Input
}], errorMessage: [{
type: Input
}], error: [{
type: Input
}], fromShengel: [{
type: Input
}], question: [{
type: Input
}], referenceField: [{
type: Input
}], token: [{
type: Input
}], valueChange: [{
type: Output
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-dropdown.component.js","sourceRoot":"","sources":["../../../../../../projects/nxt-app/src/lib/components/custom-dropdown/custom-dropdown.component.ts","../../../../../../projects/nxt-app/src/lib/components/custom-dropdown/custom-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit,Input,Output,EventEmitter, Optional } from '@angular/core';\nimport { Observable, Subscription } from 'rxjs';\nimport { APIMeta } from '../../interfaces/apimeta';\nimport { ChangeWrapper } from '../../model/changeWrapper';\nimport { ChangeService } from '../../services/change.service';\n// HA 19DEC23 imported translation service\nimport { I18nService } from '../../i18n.service';\n// VD 23JAN24 used service file for callout\nimport { DataService } from '../../services/data.service';\n\n@Component({\n  selector: 'app-custom-dropdown',\n  templateUrl: './custom-dropdown.component.html',\n  styleUrls: ['./custom-dropdown.component.css']\n})\nexport class CustomDropdownComponent implements OnInit {\n  @Input() options: any[] = []; \n  @Input() placeholder: string;\n  @Input() apiMeta: string;\n  @Input() selectedValue: string;\n  @Input() progressBar: boolean;\n  @Input() id:string;\n  @Input() readOnly : boolean = false; // VD 12Jun24 - readonly change\n  @Input() errorMessage: string;\n  @Input() error:any;\n  @Input() fromShengel: boolean = false;\n  @Input() question:any;\n  @Input() referenceField:string;\n  @Input() token:string;    // VD 19JAN24 - getting token as input\n  @Output() valueChange: EventEmitter<ChangeWrapper> = new EventEmitter<ChangeWrapper>();\n  invalidFieldIds:string[] = [];\n  constructor( \n    private changeService: ChangeService, \n    private dataService: DataService,\n    public i18nService: I18nService,\n        ) { \n    this.changeService.submitValidate$.subscribe((data)=>{\n      // to get the error message's field id's\n      this.invalidFieldIds.push(data);\n    })\n  }\n\n  public labelField: string;\n  public valueField: string;\n  subscription: Subscription;\n  //public apiObj:APIMeta;\n  public uniqueKey:string;\n  apiObj: any = {};\n\n\n  ngOnInit(): void {\n    \n  }\n  getOptions(){\n    console.log('test click');\n    // console.log('inside oninit of custom-dropdown of ' + this.id);\n    // console.log(this.apiMeta);\n    //VD 07Aug24 - isDependentField change\n    // VD 25Oct24 - changes\n    this.placeholder = this.placeholder ? this.placeholder : '---Select option---';\n    if(this.apiMeta) {\n    try {\n      // MSM-27MAR25 Ensure ques.subText is always an object by parsing it if it's a string\n      this.apiObj = typeof this.apiMeta === 'object' ? this.apiMeta : JSON.parse(this.apiMeta);\n\n      // Check if apiObj and apiObj.field are defined\n      if (this.apiObj && this.apiObj.field) {\n        this.labelField = this.apiObj.field;\n        this.uniqueKey = this.apiObj.uniqueKey;\n        const cachedOptions = localStorage.getItem(this.uniqueKey);\n        if (cachedOptions) {\n          this.options = JSON.parse(cachedOptions);\n        }else {\n          if(!this.apiObj.isDependentField){\n            this.options = [];\n          }\n\n          // VD 09Sep24- setup the query param for api call // MR 08JAN24 DependentField API Fix moved below logic from above if condition\n          let fullEndPoint ;\n          if(this.apiObj.endpoint) {\n            if(this.apiObj.queryValueReference && this.apiObj.queryField) {\n              // process the end point with query param\n              let queryReferences = this.apiObj.queryValueReference.split(',');\n              let queryFields = this.apiObj.queryField.split(',');    // MR 08JAN24 similar to above valuereference get list of QUERY Fields\n              let queryValues = this.apiObj.queryValue.split(',');    // MR 08JAN24 similar to above valuereference get list of QUERY Values (Default)\n              let queryParams = [];\n              let qIndex = 0;                                         // MR 08JAN24 Query Index\n              // Iterate over queryReferences and find the corresponding element in referenceData\n              queryReferences.forEach(reference => {\n                // Find the element in referenceData that matches the current reference\n                // RS 09DEC24 Changed keys\n                let matchingElement = this.question?.referenceQueryData.find(element => element.referenceField === reference);\n              // If a matching element is found, get its input value and create a query parameter\n                if (reference && matchingElement) {   // MR 08JAN24 if reference exist & matching element found\n                  queryParams.push(`${queryFields[qIndex]}=${matchingElement.input}`);    // MR 08JAN24 removed reference\n                } else {    // MR 08JAN24 included option for multiple query params and default value in case of reference is not found\n                  queryParams.push(`${queryFields[qIndex]}=${queryValues[qIndex]}`);\n                }\n\n                qIndex++;\n              });\n              fullEndPoint = this.apiObj.endpoint + '?' + queryParams.join('&');\n              console.log(fullEndPoint);\n            } else {\n                // if no query param get the actual endPoint\n              fullEndPoint = this.apiObj.endpoint;\n            }\n\n            // VD 19JAN24 - added one more param for authentication\n            this.dataService.apiResponse(fullEndPoint)?.subscribe((apiResponse) => {\n              // HA 18-JAN-24 Assigned apiresponse directly if we have the response in array also\n              // VD 19JAN24 - if response has key with value(which is array)\n              let responses;\n              if(this.apiObj.variable){\n                // VD 21May24 - handling multiple child objects\n                // VD 22May24 - used common service file\n                responses = this.dataService.getValue(apiResponse,this.apiObj.variable);\n                let results = [];\n                // HA 19JAN24 To avoid undefined error in console\n                for (let i = 0; i < responses?.length; i++) {\n                  var resp = responses[i];\n                  results.push(resp);\n                }\n                this.options = results;\n              }else{  // VD 19JAN24 - if response has value(which is array) only\n                responses = apiResponse;\n                this.options = responses;\n              }\n              // VD 25Oct24 - Store fetched options in local storage\n              if(this.uniqueKey){\n                localStorage.setItem(this.uniqueKey, JSON.stringify(this.options));\n              }\n              // Reference https://www.npmjs.com/package/@ng-select/ng-select\n            })\n          }\n\n          // VD NOV23 - handle the dependent update for dropdown\n          // VD 09Sep24- push the dependent field values for dropdown\n          let sourceId = this.apiObj.sourceQuestionId;\n          if(sourceId && this.apiObj.variable || this.apiObj.valueField){\n            // Subscribe for the changes\n            this.subscription = this.changeService.changeAnnounced$.subscribe(\n              (changeValue) => {\n                if(changeValue != undefined) {\n                  // console.log('inside subscription for the change');\n                  if(changeValue.valueObj != undefined && changeValue.fromQuestionId == this.apiObj.sourceQuestionId) {\n                    //  this.selectedValue = changeValue.valueObj[this.apiObj.valueField];\n                    //  let value ={};\n                    //  value['name'] = this.selectedValue;\n                      let responses;\n                      if(this.apiObj.variable){\n                        responses = this.dataService.getValue(changeValue.valueObj,this.apiObj.variable);\n                        let results = [];\n                        for (let i = 0; i < responses?.length; i++) {\n                          var resp = responses[i];\n                          results.push(resp);\n                        }\n                        this.options = results;\n                      }else{\n                        responses = changeValue.valueObj;\n                        this.options = responses;\n                      }\n                    // VD 25Oct24 - Store fetched options in local storage\n                    if(this.uniqueKey){\n                      localStorage.setItem(this.uniqueKey, JSON.stringify(this.options));\n                    }\n                    }\n                  this.changeService.confirmChange(this.apiObj.sourceQuestionId);\n                }\n            }\n          );\n          }\n        }\n      }\n    } catch (error) {\n      console.error('Error parsing apiMeta:', error);\n    }\n  } \n}\n// VD 22May24 - used common service file\n\n  selectChange(event:any) {\n    console.log('inside selectChange from ' + this.id);\n    // console.log(event);\n    let change = new ChangeWrapper(); // ChangeWrapper = JSON.parse('{}');\n    change.fromQuestionId = this.id;\n    change.valueObj = event ? event : '';\n    change.referenceField = this.referenceField;\n    change.selectedObj = event ? event[this.labelField] : '';\n    this.valueChange.emit(change);\n    // once got value in dropdown remove the error validation\n    if(event){\n      this.invalidFieldIds =[];\n    }\n  }\n}\n","<!-- HA 18-JAN-24 Commenting these lines as we don't have to use shengel here -->\n<!-- <select\n  [ngClass]=\"{\n    'dt-line dpDown down myt-dropbox myt-border-r myt-font1': progressBar,\n    'custom-select': !progressBar\n  }\" class=\"custom-select mr-sm-2 dd-height\" \n  [id]=\"id\" \n  [(ngModel)]=\"selectedValue\"\n  (change)=\"selectChange($event.target.value);\" \n  [style.borderColor]=\"error ? 'red' : '#858585'\"\n  [style.color]=\"error ? 'red' : ''\">\n    <option *ngFor=\"let option of options\" [value]=\"this.apiMeta !== undefined ? option.title : option.value\" class=\"option\">{{ this.apiMeta !== undefined ? option.title : option.value }}</option>\n    <option *ngIf=\"errorMessage\" value=\"\" disabled hidden>{{ errorMessage }}</option>\n</select> -->\n<!-- // VD 12Jun24 - readonly change-->\n<!-- VD 01Aug24 - validation change-->\n<!-- VD 07Aug24 - isDependentField change-->\n<!-- VD 25Oct24 - changes-->\n<!-- RS 09DEC24 Changed keys--> \n <!-- AP 28MAR25 LabelField Checking -->\n  <!-- AP 02APR25 If apiObj exists and is not a dependent field, use option[labelField], otherwise use option.value -->\n<ng-select\n  [class]=\"invalidFieldIds.includes(id) || error ? 'shengel-custom-select invalid' : 'shengel-custom-select'\"\n  [(ngModel)]=\"selectedValue\" \n  [placeholder]=\"placeholder\"\n  [disabled]=\"readOnly\"\n  (click)=\"getOptions()\"\n  (change)=\"selectChange($event)\"\n  [id]=\"id\">\n  <ng-option \n    *ngFor=\"let option of options\" \n    [value]=\"apiObj && !apiObj.isDependentField && option[labelField] ? option[labelField] : option?.value\">\n    {{ apiObj && !apiObj.isDependentField && option[labelField] ? option[labelField] : option?.value }}\n  </ng-option> \n</ng-select>\n<span *ngIf=\"error || invalidFieldIds.includes(id)\" class=\"error-msg\">{{errorMessage}}</span>\n"]}