tin-spa 2.9.4 → 2.9.6

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.
@@ -72,7 +72,7 @@ export class FormComponent {
72
72
  this.buttonDisplay = this.config.button.display;
73
73
  }
74
74
  this.fileField = this.fields.find(x => x.type == 'file');
75
- if (this.config?.button?.action && this.fileField) {
75
+ if (this.config?.button?.action && this.fileField || this.config?.button?.action.url.includes("/form")) {
76
76
  this.config.button.action.isFormData = true;
77
77
  }
78
78
  this.childFields = this.fields.filter(x => x.masterField);
@@ -231,4 +231,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
231
231
  }], inputChange: [{
232
232
  type: Output
233
233
  }] } });
234
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/form/form.component.ts","../../../../../../projects/tin-spa/src/lib/components/form/form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ContentChild, EventEmitter, Input, OnInit, Output, TemplateRef } from '@angular/core';\r\nimport { FormConfig, Field, Button, ApiResponse } from '../../classes/Classes';\r\nimport { Core } from '../../classes/TinCore';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { DataServiceLib } from '../../services/datalib.service';\r\nimport { BehaviorSubject } from 'rxjs';\r\nimport { AuthService } from '../../services/auth.service';\r\n\r\n\r\n@Component({\r\n  selector: 'spa-form',\r\n  templateUrl: './form.component.html',\r\n  styleUrls: ['./form.component.css']\r\n})\r\nexport class FormComponent implements OnInit {\r\n\r\n  constructor(private messageService: MessageService, private dataService: DataServiceLib, private authService: AuthService) { }\r\n\r\n  ngOnInit() {\r\n\r\n    this.hasAccess = Core.hasFormAccess(this.config, this.authService.currentRoleSource.value);\r\n\r\n    if (!this.hasAccess) {\r\n      // this.messageService.toast('Access denied'); // Optional - notify user\r\n      return;\r\n    }\r\n\r\n    if (!this.config.fields){\r\n      this.messageService.toast(\"Please Configure Form Fields\")\r\n      return;\r\n    }\r\n\r\n    if (!this.data) {\r\n      this.messageService.toast(\"Please Configure Form Data\")\r\n      return;\r\n    }\r\n\r\n    this.fields = this.config.fields;\r\n\r\n    // Initialize BehaviorSubjects for fields with loadActions\r\n    this.fields?.forEach(field => {\r\n      if (field.loadAction && !field.optionsSubject && !field.masterField) {\r\n        field.optionsSubject = new BehaviorSubject<any[]>([]);\r\n\r\n        // Subscribe to options changes\r\n        field.optionsSubject.subscribe(newOptions => {\r\n          field.options = newOptions;\r\n\r\n          // Update child fields that depend on this field\r\n          if (this.childFields?.some(x => x.masterField === field.name)) {\r\n            this.updateChildOptions(field.name);\r\n          }\r\n        });\r\n      }\r\n    });\r\n\r\n\r\n    if (this.config.multiColumn){\r\n      this.multiColumn = this.config.multiColumn\r\n    }else{\r\n      this.multiColumn = this.fields.length > 2\r\n    }\r\n\r\n    if (this.config?.button?.display){\r\n      this.buttonDisplay = this.config.button.display;\r\n    }\r\n\r\n    this.fileField = this.fields.find(x => x.type == 'file')\r\n\r\n    if (this.config?.button?.action && this.fileField) {\r\n      this.config.button.action.isFormData = true;\r\n\r\n    }\r\n\r\n    this.childFields = this.fields.filter(x => x.masterField)\r\n\r\n\r\n    this.childFields.forEach(child => {\r\n      let master = this.fields.find(x => x.name == child.masterField)\r\n      if (child.loadAction) {\r\n        this.loadChildMasterOptions(child);\r\n      }else{\r\n        this.updateChildOptions(master.name);\r\n      }\r\n\r\n    });\r\n\r\n    this.fields.forEach(field => {\r\n      if (field.loadAction) {\r\n        this.loadChildMasterOptions(field);\r\n      }\r\n    });\r\n\r\n    this.initializeCompositeFields();\r\n\r\n\r\n  }\r\n\r\n  initializeCompositeFields() {\r\n    this.fields.forEach(field => {\r\n      if (field.type === 'composite' && field.subfields) {\r\n        field.subfields.forEach(subfield => {\r\n          if (this.data[subfield.name] === undefined) {\r\n            this.data[subfield.name] = Core.getInitialValue(subfield);\r\n          }\r\n        });\r\n      }\r\n    });\r\n  }\r\n\r\n  getVisibleSubfields(field : Field){\r\n    return Core.getVisibleSubfields(this.config, this.data, field, this.authService.currentRoleSource.value);\r\n  }\r\n\r\n\r\n  getVisibleFields(){\r\n    return this.fields?.filter(x => Core.testVisible(this.config, this.data, x, this.authService.currentRoleSource.value))\r\n  }\r\n\r\n  testReadOnly(field: Field): boolean {\r\n    return Core.testReadOnly(this.config, this.data, field);\r\n  }\r\n\r\n\r\n  @ContentChild('dynamicSelect') dynamicSelectTemplate: TemplateRef<any>;\r\n\r\n  hasAccess = false;\r\n  fileNames\r\n  fileField: Field;\r\n  fileViewField: Field;\r\n  @Input() files: any[] = [];\r\n  fields: Field[];\r\n  buttonDisplay = \"Submit\";\r\n  isProcessing : boolean = false;\r\n  multiColumn : boolean = false;\r\n\r\n  childFields : Field[];\r\n\r\n  @Input() data: any;\r\n  @Input() config: FormConfig;\r\n  @Output() buttonClick = new EventEmitter();\r\n  @Output() inputChange = new EventEmitter();\r\n\r\n  selectChanged(field: Field){\r\n    this.inputChanged(field, this.data[field.name] )\r\n  }\r\n\r\n  inputChanged(field : Field, value){\r\n\r\n    this.inputChange.emit({ field: field, value: value})\r\n\r\n    this.updateChildOptions(field.name)\r\n\r\n\r\n    if (this.config.mode == 'create' && field.children){\r\n      field.children.forEach(childConfig => {\r\n        let child = this.fields.find(x => x.name == childConfig.childField)\r\n        this.data[child.name] = field.options.find(x => x[field.optionValue ?? 'value'] == value)[childConfig.childValueField]\r\n      });\r\n    }\r\n\r\n  }\r\n\r\n  updateChildOptions(masterFieldName: string){\r\n\r\n    let child = this.childFields.find(x => x.masterField == masterFieldName)\r\n    if (child != null) {\r\n\r\n      //current is master\r\n\r\n\r\n      if (child.masterOptions){\r\n        child.options = child.masterOptions.filter(x => x[child.masterOptionValue ?? 'masterValue'] == this.data[masterFieldName])\r\n      }else{\r\n        console.log(\"Master Options not found\")\r\n      }\r\n\r\n    }\r\n  }\r\n\r\n  private loadChildMasterOptions(child: Field) {\r\n    if (!child.loadAction) return;\r\n\r\n    this.dataService.CallApi(child.loadAction).subscribe((apiResponse: ApiResponse) => {\r\n      if (apiResponse.success) {\r\n\r\n        child.masterOptions = apiResponse.data;\r\n        this.updateChildOptions(child.masterField);\r\n      }\r\n    });\r\n  }\r\n\r\n\r\n  buttonClicked(){\r\n\r\n    this.buttonClick.emit(this.data);\r\n\r\n    let button = this.config.button;\r\n\r\n    if (!button) {\r\n      return;\r\n    }\r\n\r\n    //validation\r\n    let resp = Core.validateObject(this.getVisibleFields(),this.data);\r\n    if (resp != ''){\r\n      this.messageService.toast(resp)\r\n      return;\r\n    }\r\n\r\n\r\n\r\n    if (this.files.length < 1 && this.fileField?.required && this.config.mode =='create') {\r\n      this.messageService.toast(\"Please attach file(s)\");\r\n      return;\r\n    }\r\n\r\n\r\n    if (button.confirm){\r\n\r\n      this.messageService.confirm(`${button.confirm.message}`).subscribe((result) => {\r\n        if (result == \"yes\") {\r\n          this.processCall(button)\r\n        }\r\n      });\r\n\r\n    }else{\r\n      this.processCall(button)\r\n    }\r\n\r\n\r\n\r\n\r\n  }\r\n\r\n  processCall(button: Button){\r\n\r\n    if (!button.action) return\r\n\r\n    let dataOut;\r\n\r\n    if (button.action.isFormData){\r\n\r\n      let formData: FormData = new FormData();\r\n      for (let i = 0; i < this.files.length; i++) {\r\n        formData.append(`uploadFile${i}`, this.files[i], this.files[i].name);\r\n      }\r\n\r\n      formData.append(\"data\", JSON.stringify(this.data));\r\n\r\n\r\n      dataOut = formData\r\n    }else{\r\n\r\n      dataOut = this.data\r\n    }\r\n\r\n\r\n\r\n\r\n    this.isProcessing = true\r\n    this.dataService.CallApi(button.action, dataOut).subscribe((apiResponse) => {\r\n      this.isProcessing = false\r\n\r\n      if (apiResponse.success) {\r\n\r\n        if (button.action.successMessage) {\r\n          this.messageService.toast(button.action.successMessage);\r\n        } else {\r\n          this.messageService.toast(\"Submitted\");\r\n        }\r\n\r\n        if (this.config.reset) {\r\n          Core.resetObject(this.fields, this.data)\r\n          this.files = [];\r\n        }\r\n\r\n\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse.message);\r\n      }\r\n    });\r\n  }\r\n\r\n  processForm(){\r\n\r\n\r\n\r\n\r\n\r\n  }\r\n\r\n}\r\n\r\n\r\n","\r\n<div [ngClass]=\"multiColumn ? 'tin-grid' : 'tin-col'\" >\r\n\r\n  <div *ngIf=\"!hasAccess\" class=\"tin-center\">\r\n    <p><em>Access Restricted</em></p>\r\n  </div>\r\n\r\n  <div [ngClass]=\"field.span || field.type =='section' || field.type =='file' || field.type =='file-view'  ? 'span-col' : ''\" *ngFor=\"let field of getVisibleFields()\">\r\n\r\n    <ng-container  >\r\n\r\n      <ng-container [ngSwitch]=\"field.type\" class=\"highlight\">\r\n\r\n        <div *ngSwitchCase=\"'section'\" class=\"title\">\r\n          <label style=\"font-size: larger;\">{{field.alias ?? field.name | camelToWords}}</label>\r\n        </div>\r\n\r\n        <ng-container *ngSwitchCase=\"'file'\">\r\n          <div class=\"mt-1 mb-2\" *ngIf=\"config.mode !='view'\">\r\n            <spa-attach [message]=\"field.alias ?? 'Drag and Drop files here'\" [(files)]=\"files\" [fileOptions]=\"field.fileOptions\"></spa-attach>\r\n          </div>\r\n        </ng-container>\r\n\r\n        <ng-container *ngSwitchCase=\"'file-view'\">\r\n          <div class=\"mt-1 mb-2\" *ngIf=\"config.mode && config.mode !='create'\">\r\n            <spa-viewer [fileAction]=\"field.loadAction\" [path]=\"field.path\" [folderName]=\"data[field.keyField]\" ></spa-viewer>\r\n          </div>\r\n        </ng-container>\r\n\r\n\r\n        <label *ngSwitchCase=\"'blank'\"></label>\r\n\r\n        <label *ngSwitchCase=\"'string'\" [ngStyle]=\"{'font-size':field.size ?? '14px'}\" >{{data[field.name] ?? field.alias ?? field.name}} {{field.suffix ?? ''}}</label>\r\n\r\n        <spa-label *ngSwitchCase=\"'label'\" [display]=\"field.alias ?? field.name | camelToWords\" [value]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [format]=\"field.format ?? 'text'\" [suffix]=\"field.suffix\"></spa-label>\r\n\r\n        <spa-number *ngSwitchCase=\"'number'\" [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [required]=\"field.required\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\"></spa-number>\r\n\r\n        <spa-money *ngSwitchCase=\"'money'\" [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [required]=\"field.required\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\"></spa-money>\r\n\r\n        <spa-check *ngSwitchCase=\"'checkbox'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [readonly]=\"testReadOnly(field)\" [infoMessage]=\"field.infoMessage\" ></spa-check>\r\n\r\n        <spa-date *ngSwitchCase=\"'date'\" [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [min]=\"field?.min\" [max]=\"field?.max\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" ></spa-date>\r\n\r\n        <spa-datetime *ngSwitchCase=\"'datetime'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [readonly]=\"testReadOnly(field)\" [min]=\"field.min\" [max]=\"field.max\" [infoMessage]=\"field.infoMessage\" ></spa-datetime>\r\n\r\n        <spa-email *ngSwitchCase=\"'email'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field,data[field.name])\" [required]=\"field.required\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\"  [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\"></spa-email>\r\n\r\n        <spa-text *ngSwitchCase=\"'password'\" [format]=\"'password'\" [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [options]=\"field.options\" [optionValue]=\"field.optionValue ?? 'value'\" [rows]=\"field.rows\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field,data[field.name])\" [required]=\"field.required\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\"></spa-text>\r\n\r\n\r\n        <ng-container *ngSwitchCase=\"'select'\">\r\n          <ng-container *ngTemplateOutlet=\"dynamicSelectTemplate; context: {\r\n                  $implicit: field,\r\n                  field: field,\r\n                  data: data,\r\n                  testReadOnly: testReadOnly.bind(this),\r\n                  selectChanged: selectChanged.bind(this)\r\n                }\">\r\n          </ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <spa-multi-select *ngSwitchCase=\"'multi-select'\" [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [options]=\"field.options\" [optionDisplay]=\"field.optionDisplay ?? 'name'\" [optionValue]=\"field.optionValue ?? 'value'\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [required]=\"field.required\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\" [loadAction]=\"field.loadAction\">\r\n        </spa-multi-select>\r\n\r\n        <spa-multi-text *ngSwitchCase=\"'multi-text'\" [strict]=\"field.strict\" [display]=\"field.alias ?? field.name | camelToWords\" [options]=\"field.options\" [optionDisplay]=\"field.optionDisplay ?? 'name'\" [optionValue]=\"field.optionValue ?? 'value'\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field,data[field.name])\" [required]=\"field.required\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\" [loadAction]=\"field.loadAction\"></spa-multi-text>\r\n\r\n\r\n\r\n        <ng-container *ngSwitchCase=\"'composite'\">\r\n          <div class=\"composite-field-container\">\r\n            <div class=\"composite-field-group\">\r\n              <ng-container *ngFor=\"let subfield of getVisibleSubfields(field)\">\r\n                <ng-container [ngSwitch]=\"subfield.type\">\r\n\r\n                  <spa-number *ngSwitchCase=\"'number'\" [display]=\"subfield.alias ?? subfield.name | camelToWords\" [width]=\"subfield.width\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [required]=\"subfield.required\" [min]=\"subfield.min\" [max]=\"subfield.max\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [hint]=\"subfield.hint\" [infoMessage]=\"subfield.infoMessage\"  [suffix]=\"subfield.suffix\" [copyContent]=\"subfield.copyContent\" [clearContent]=\"subfield.clearContent\"></spa-number>\r\n\r\n                  <spa-money *ngSwitchCase=\"'money'\" [display]=\"subfield.alias ?? subfield.name | camelToWords\" [width]=\"subfield.width\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [required]=\"subfield.required\" [min]=\"subfield.min\" [max]=\"subfield.max\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [hint]=\"subfield.hint\" [infoMessage]=\"subfield.infoMessage\" [suffix]=\"subfield.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\"></spa-money>\r\n\r\n                  <spa-check *ngSwitchCase=\"'checkbox'\" [display]=\"subfield.alias ?? subfield.name | camelToWords\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [infoMessage]=\"subfield.infoMessage\" ></spa-check>\r\n\r\n                  <spa-date *ngSwitchCase=\"'date'\" [display]=\"subfield.alias ?? subfield.name | camelToWords\" [width]=\"subfield.width\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [min]=\"subfield.min\" [max]=\"subfield.max\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [hint]=\"subfield.hint\" [infoMessage]=\"subfield.infoMessage\" ></spa-date>\r\n\r\n                  <spa-datetime *ngSwitchCase=\"'datetime'\" [display]=\"subfield.alias ?? subfield.name | camelToWords\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [min]=\"subfield.min\" [max]=\"subfield.max\" [infoMessage]=\"subfield.infoMessage\" ></spa-datetime>\r\n\r\n                  <ng-container *ngSwitchCase=\"'select'\">\r\n                    <ng-container *ngTemplateOutlet=\"dynamicSelectTemplate; context: {\r\n                                    $implicit: field,\r\n                                    field: field,\r\n                                    data: data,\r\n                                    testReadOnly: testReadOnly.bind(this),\r\n                                    selectChanged: selectChanged.bind(this)\r\n                                  }\">\r\n                    </ng-container>\r\n                  </ng-container>\r\n\r\n                  <spa-text *ngSwitchDefault [display]=\"subfield.alias ?? subfield.name | camelToWords\" [width]=\"subfield.width\"  [options]=\"subfield.options\" [optionDisplay]=\"subfield.optionDisplay ?? 'name'\" [optionValue]=\"subfield.optionValue ?? 'value'\" [rows]=\"subfield.rows\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [required]=\"subfield.required\" [min]=\"subfield.min\" [max]=\"subfield.max\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [hint]=\"subfield.hint\" [infoMessage]=\"subfield.infoMessage\"  [suffix]=\"subfield.suffix\" [copyContent]=\"subfield.copyContent\" [clearContent]=\"subfield.clearContent\" [loadAction]=\"subfield.loadAction\"></spa-text>\r\n\r\n\r\n                </ng-container>\r\n              </ng-container>\r\n            </div>\r\n          </div>\r\n        </ng-container>\r\n\r\n\r\n        <spa-text *ngSwitchDefault [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [options]=\"field.options\" [optionDisplay]=\"field.optionDisplay ?? 'name'\" [optionValue]=\"field.optionValue ?? 'value'\" [rows]=\"field.rows\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field,data[field.name])\" [required]=\"field.required\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\"  [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\" [loadAction]=\"field.loadAction\"></spa-text>\r\n\r\n      </ng-container>\r\n\r\n    </ng-container>\r\n\r\n  </div>\r\n\r\n\r\n  <div class=\"span-col-center\" *ngIf=\"config.button\">\r\n    <button mat-raised-button color=\"primary\"  (click)=\"buttonClicked()\"  cdkFocusInitial>{{buttonDisplay}}</button>\r\n  </div>\r\n\r\n\r\n</div>\r\n"]}
234
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/form/form.component.ts","../../../../../../projects/tin-spa/src/lib/components/form/form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ContentChild, EventEmitter, Input, OnInit, Output, TemplateRef } from '@angular/core';\r\nimport { FormConfig, Field, Button, ApiResponse } from '../../classes/Classes';\r\nimport { Core } from '../../classes/TinCore';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { DataServiceLib } from '../../services/datalib.service';\r\nimport { BehaviorSubject } from 'rxjs';\r\nimport { AuthService } from '../../services/auth.service';\r\n\r\n\r\n@Component({\r\n  selector: 'spa-form',\r\n  templateUrl: './form.component.html',\r\n  styleUrls: ['./form.component.css']\r\n})\r\nexport class FormComponent implements OnInit {\r\n\r\n  constructor(private messageService: MessageService, private dataService: DataServiceLib, private authService: AuthService) { }\r\n\r\n  ngOnInit() {\r\n\r\n    this.hasAccess = Core.hasFormAccess(this.config, this.authService.currentRoleSource.value);\r\n\r\n    if (!this.hasAccess) {\r\n      // this.messageService.toast('Access denied'); // Optional - notify user\r\n      return;\r\n    }\r\n\r\n    if (!this.config.fields){\r\n      this.messageService.toast(\"Please Configure Form Fields\")\r\n      return;\r\n    }\r\n\r\n    if (!this.data) {\r\n      this.messageService.toast(\"Please Configure Form Data\")\r\n      return;\r\n    }\r\n\r\n    this.fields = this.config.fields;\r\n\r\n    // Initialize BehaviorSubjects for fields with loadActions\r\n    this.fields?.forEach(field => {\r\n      if (field.loadAction && !field.optionsSubject && !field.masterField) {\r\n        field.optionsSubject = new BehaviorSubject<any[]>([]);\r\n\r\n        // Subscribe to options changes\r\n        field.optionsSubject.subscribe(newOptions => {\r\n          field.options = newOptions;\r\n\r\n          // Update child fields that depend on this field\r\n          if (this.childFields?.some(x => x.masterField === field.name)) {\r\n            this.updateChildOptions(field.name);\r\n          }\r\n        });\r\n      }\r\n    });\r\n\r\n\r\n    if (this.config.multiColumn){\r\n      this.multiColumn = this.config.multiColumn\r\n    }else{\r\n      this.multiColumn = this.fields.length > 2\r\n    }\r\n\r\n    if (this.config?.button?.display){\r\n      this.buttonDisplay = this.config.button.display;\r\n    }\r\n\r\n    this.fileField = this.fields.find(x => x.type == 'file')\r\n\r\n    if (this.config?.button?.action && this.fileField || this.config?.button?.action.url.includes(\"/form\")) {\r\n      this.config.button.action.isFormData = true;\r\n\r\n    }\r\n\r\n    this.childFields = this.fields.filter(x => x.masterField)\r\n\r\n\r\n    this.childFields.forEach(child => {\r\n      let master = this.fields.find(x => x.name == child.masterField)\r\n      if (child.loadAction) {\r\n        this.loadChildMasterOptions(child);\r\n      }else{\r\n        this.updateChildOptions(master.name);\r\n      }\r\n\r\n    });\r\n\r\n    this.fields.forEach(field => {\r\n      if (field.loadAction) {\r\n        this.loadChildMasterOptions(field);\r\n      }\r\n    });\r\n\r\n    this.initializeCompositeFields();\r\n\r\n\r\n  }\r\n\r\n  initializeCompositeFields() {\r\n    this.fields.forEach(field => {\r\n      if (field.type === 'composite' && field.subfields) {\r\n        field.subfields.forEach(subfield => {\r\n          if (this.data[subfield.name] === undefined) {\r\n            this.data[subfield.name] = Core.getInitialValue(subfield);\r\n          }\r\n        });\r\n      }\r\n    });\r\n  }\r\n\r\n  getVisibleSubfields(field : Field){\r\n    return Core.getVisibleSubfields(this.config, this.data, field, this.authService.currentRoleSource.value);\r\n  }\r\n\r\n\r\n  getVisibleFields(){\r\n    return this.fields?.filter(x => Core.testVisible(this.config, this.data, x, this.authService.currentRoleSource.value))\r\n  }\r\n\r\n  testReadOnly(field: Field): boolean {\r\n    return Core.testReadOnly(this.config, this.data, field);\r\n  }\r\n\r\n\r\n  @ContentChild('dynamicSelect') dynamicSelectTemplate: TemplateRef<any>;\r\n\r\n  hasAccess = false;\r\n  fileNames\r\n  fileField: Field;\r\n  fileViewField: Field;\r\n  @Input() files: any[] = [];\r\n  fields: Field[];\r\n  buttonDisplay = \"Submit\";\r\n  isProcessing : boolean = false;\r\n  multiColumn : boolean = false;\r\n\r\n  childFields : Field[];\r\n\r\n  @Input() data: any;\r\n  @Input() config: FormConfig;\r\n  @Output() buttonClick = new EventEmitter();\r\n  @Output() inputChange = new EventEmitter();\r\n\r\n  selectChanged(field: Field){\r\n    this.inputChanged(field, this.data[field.name] )\r\n  }\r\n\r\n  inputChanged(field : Field, value){\r\n\r\n    this.inputChange.emit({ field: field, value: value})\r\n\r\n    this.updateChildOptions(field.name)\r\n\r\n\r\n    if (this.config.mode == 'create' && field.children){\r\n      field.children.forEach(childConfig => {\r\n        let child = this.fields.find(x => x.name == childConfig.childField)\r\n        this.data[child.name] = field.options.find(x => x[field.optionValue ?? 'value'] == value)[childConfig.childValueField]\r\n      });\r\n    }\r\n\r\n  }\r\n\r\n  updateChildOptions(masterFieldName: string){\r\n\r\n    let child = this.childFields.find(x => x.masterField == masterFieldName)\r\n    if (child != null) {\r\n\r\n      //current is master\r\n\r\n\r\n      if (child.masterOptions){\r\n        child.options = child.masterOptions.filter(x => x[child.masterOptionValue ?? 'masterValue'] == this.data[masterFieldName])\r\n      }else{\r\n        console.log(\"Master Options not found\")\r\n      }\r\n\r\n    }\r\n  }\r\n\r\n  private loadChildMasterOptions(child: Field) {\r\n    if (!child.loadAction) return;\r\n\r\n    this.dataService.CallApi(child.loadAction).subscribe((apiResponse: ApiResponse) => {\r\n      if (apiResponse.success) {\r\n\r\n        child.masterOptions = apiResponse.data;\r\n        this.updateChildOptions(child.masterField);\r\n      }\r\n    });\r\n  }\r\n\r\n\r\n  buttonClicked(){\r\n\r\n    this.buttonClick.emit(this.data);\r\n\r\n    let button = this.config.button;\r\n\r\n    if (!button) {\r\n      return;\r\n    }\r\n\r\n    //validation\r\n    let resp = Core.validateObject(this.getVisibleFields(),this.data);\r\n    if (resp != ''){\r\n      this.messageService.toast(resp)\r\n      return;\r\n    }\r\n\r\n\r\n\r\n    if (this.files.length < 1 && this.fileField?.required && this.config.mode =='create') {\r\n      this.messageService.toast(\"Please attach file(s)\");\r\n      return;\r\n    }\r\n\r\n\r\n    if (button.confirm){\r\n\r\n      this.messageService.confirm(`${button.confirm.message}`).subscribe((result) => {\r\n        if (result == \"yes\") {\r\n          this.processCall(button)\r\n        }\r\n      });\r\n\r\n    }else{\r\n      this.processCall(button)\r\n    }\r\n\r\n\r\n\r\n\r\n  }\r\n\r\n  processCall(button: Button){\r\n\r\n    if (!button.action) return\r\n\r\n    let dataOut;\r\n\r\n    if (button.action.isFormData){\r\n\r\n      let formData: FormData = new FormData();\r\n      for (let i = 0; i < this.files.length; i++) {\r\n        formData.append(`uploadFile${i}`, this.files[i], this.files[i].name);\r\n      }\r\n\r\n      formData.append(\"data\", JSON.stringify(this.data));\r\n\r\n\r\n      dataOut = formData\r\n    }else{\r\n\r\n      dataOut = this.data\r\n    }\r\n\r\n\r\n\r\n\r\n    this.isProcessing = true\r\n    this.dataService.CallApi(button.action, dataOut).subscribe((apiResponse) => {\r\n      this.isProcessing = false\r\n\r\n      if (apiResponse.success) {\r\n\r\n        if (button.action.successMessage) {\r\n          this.messageService.toast(button.action.successMessage);\r\n        } else {\r\n          this.messageService.toast(\"Submitted\");\r\n        }\r\n\r\n        if (this.config.reset) {\r\n          Core.resetObject(this.fields, this.data)\r\n          this.files = [];\r\n        }\r\n\r\n\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse.message);\r\n      }\r\n    });\r\n  }\r\n\r\n  processForm(){\r\n\r\n\r\n\r\n\r\n\r\n  }\r\n\r\n}\r\n\r\n\r\n","\r\n<div [ngClass]=\"multiColumn ? 'tin-grid' : 'tin-col'\" >\r\n\r\n  <div *ngIf=\"!hasAccess\" class=\"tin-center\">\r\n    <p><em>Access Restricted</em></p>\r\n  </div>\r\n\r\n  <div [ngClass]=\"field.span || field.type =='section' || field.type =='file' || field.type =='file-view'  ? 'span-col' : ''\" *ngFor=\"let field of getVisibleFields()\">\r\n\r\n    <ng-container  >\r\n\r\n      <ng-container [ngSwitch]=\"field.type\" class=\"highlight\">\r\n\r\n        <div *ngSwitchCase=\"'section'\" class=\"title\">\r\n          <label style=\"font-size: larger;\">{{field.alias ?? field.name | camelToWords}}</label>\r\n        </div>\r\n\r\n        <ng-container *ngSwitchCase=\"'file'\">\r\n          <div class=\"mt-1 mb-2\" *ngIf=\"config.mode !='view'\">\r\n            <spa-attach [message]=\"field.alias ?? 'Drag and Drop files here'\" [(files)]=\"files\" [fileOptions]=\"field.fileOptions\"></spa-attach>\r\n          </div>\r\n        </ng-container>\r\n\r\n        <ng-container *ngSwitchCase=\"'file-view'\">\r\n          <div class=\"mt-1 mb-2\" *ngIf=\"config.mode && config.mode !='create'\">\r\n            <spa-viewer [fileAction]=\"field.loadAction\" [path]=\"field.path\" [folderName]=\"data[field.keyField]\" ></spa-viewer>\r\n          </div>\r\n        </ng-container>\r\n\r\n\r\n        <label *ngSwitchCase=\"'blank'\"></label>\r\n\r\n        <label *ngSwitchCase=\"'string'\" [ngStyle]=\"{'font-size':field.size ?? '14px'}\" >{{data[field.name] ?? field.alias ?? field.name}} {{field.suffix ?? ''}}</label>\r\n\r\n        <spa-label *ngSwitchCase=\"'label'\" [display]=\"field.alias ?? field.name | camelToWords\" [value]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [format]=\"field.format ?? 'text'\" [suffix]=\"field.suffix\"></spa-label>\r\n\r\n        <spa-number *ngSwitchCase=\"'number'\" [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [required]=\"field.required\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\"></spa-number>\r\n\r\n        <spa-money *ngSwitchCase=\"'money'\" [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [required]=\"field.required\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\"></spa-money>\r\n\r\n        <spa-check *ngSwitchCase=\"'checkbox'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [readonly]=\"testReadOnly(field)\" [infoMessage]=\"field.infoMessage\" ></spa-check>\r\n\r\n        <spa-date *ngSwitchCase=\"'date'\" [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [min]=\"field?.min\" [max]=\"field?.max\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" ></spa-date>\r\n\r\n        <spa-datetime *ngSwitchCase=\"'datetime'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [readonly]=\"testReadOnly(field)\" [min]=\"field.min\" [max]=\"field.max\" [infoMessage]=\"field.infoMessage\" ></spa-datetime>\r\n\r\n        <spa-email *ngSwitchCase=\"'email'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field,data[field.name])\" [required]=\"field.required\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\"  [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\"></spa-email>\r\n\r\n        <spa-text *ngSwitchCase=\"'password'\" [format]=\"'password'\" [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [options]=\"field.options\" [optionValue]=\"field.optionValue ?? 'value'\" [rows]=\"field.rows\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field,data[field.name])\" [required]=\"field.required\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\"></spa-text>\r\n\r\n\r\n        <ng-container *ngSwitchCase=\"'select'\">\r\n          <ng-container *ngTemplateOutlet=\"dynamicSelectTemplate; context: {\r\n                  $implicit: field,\r\n                  field: field,\r\n                  data: data,\r\n                  testReadOnly: testReadOnly.bind(this),\r\n                  selectChanged: selectChanged.bind(this)\r\n                }\">\r\n          </ng-container>\r\n        </ng-container>\r\n\r\n\r\n        <spa-multi-select *ngSwitchCase=\"'multi-select'\" [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [options]=\"field.options\" [optionDisplay]=\"field.optionDisplay ?? 'name'\" [optionValue]=\"field.optionValue ?? 'value'\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [required]=\"field.required\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\" [loadAction]=\"field.loadAction\">\r\n        </spa-multi-select>\r\n\r\n        <spa-multi-text *ngSwitchCase=\"'multi-text'\" [strict]=\"field.strict\" [display]=\"field.alias ?? field.name | camelToWords\" [options]=\"field.options\" [optionDisplay]=\"field.optionDisplay ?? 'name'\" [optionValue]=\"field.optionValue ?? 'value'\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field,data[field.name])\" [required]=\"field.required\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\" [loadAction]=\"field.loadAction\"></spa-multi-text>\r\n\r\n\r\n\r\n        <ng-container *ngSwitchCase=\"'composite'\">\r\n          <div class=\"composite-field-container\">\r\n            <div class=\"composite-field-group\">\r\n              <ng-container *ngFor=\"let subfield of getVisibleSubfields(field)\">\r\n                <ng-container [ngSwitch]=\"subfield.type\">\r\n\r\n                  <spa-number *ngSwitchCase=\"'number'\" [display]=\"subfield.alias ?? subfield.name | camelToWords\" [width]=\"subfield.width\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [required]=\"subfield.required\" [min]=\"subfield.min\" [max]=\"subfield.max\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [hint]=\"subfield.hint\" [infoMessage]=\"subfield.infoMessage\"  [suffix]=\"subfield.suffix\" [copyContent]=\"subfield.copyContent\" [clearContent]=\"subfield.clearContent\"></spa-number>\r\n\r\n                  <spa-money *ngSwitchCase=\"'money'\" [display]=\"subfield.alias ?? subfield.name | camelToWords\" [width]=\"subfield.width\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [required]=\"subfield.required\" [min]=\"subfield.min\" [max]=\"subfield.max\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [hint]=\"subfield.hint\" [infoMessage]=\"subfield.infoMessage\" [suffix]=\"subfield.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\"></spa-money>\r\n\r\n                  <spa-check *ngSwitchCase=\"'checkbox'\" [display]=\"subfield.alias ?? subfield.name | camelToWords\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [infoMessage]=\"subfield.infoMessage\" ></spa-check>\r\n\r\n                  <spa-date *ngSwitchCase=\"'date'\" [display]=\"subfield.alias ?? subfield.name | camelToWords\" [width]=\"subfield.width\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [min]=\"subfield.min\" [max]=\"subfield.max\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [hint]=\"subfield.hint\" [infoMessage]=\"subfield.infoMessage\" ></spa-date>\r\n\r\n                  <spa-datetime *ngSwitchCase=\"'datetime'\" [display]=\"subfield.alias ?? subfield.name | camelToWords\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [min]=\"subfield.min\" [max]=\"subfield.max\" [infoMessage]=\"subfield.infoMessage\" ></spa-datetime>\r\n\r\n                  <ng-container *ngSwitchCase=\"'select'\">\r\n                    <ng-container *ngTemplateOutlet=\"dynamicSelectTemplate; context: {\r\n                                    $implicit: field,\r\n                                    field: field,\r\n                                    data: data,\r\n                                    testReadOnly: testReadOnly.bind(this),\r\n                                    selectChanged: selectChanged.bind(this)\r\n                                  }\">\r\n                    </ng-container>\r\n                  </ng-container>\r\n\r\n                  <spa-text *ngSwitchDefault [display]=\"subfield.alias ?? subfield.name | camelToWords\" [width]=\"subfield.width\"  [options]=\"subfield.options\" [optionDisplay]=\"subfield.optionDisplay ?? 'name'\" [optionValue]=\"subfield.optionValue ?? 'value'\" [rows]=\"subfield.rows\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [required]=\"subfield.required\" [min]=\"subfield.min\" [max]=\"subfield.max\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [hint]=\"subfield.hint\" [infoMessage]=\"subfield.infoMessage\"  [suffix]=\"subfield.suffix\" [copyContent]=\"subfield.copyContent\" [clearContent]=\"subfield.clearContent\" [loadAction]=\"subfield.loadAction\"></spa-text>\r\n\r\n\r\n                </ng-container>\r\n              </ng-container>\r\n            </div>\r\n          </div>\r\n        </ng-container>\r\n\r\n\r\n        <spa-text *ngSwitchDefault [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [options]=\"field.options\" [optionDisplay]=\"field.optionDisplay ?? 'name'\" [optionValue]=\"field.optionValue ?? 'value'\" [rows]=\"field.rows\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field,data[field.name])\" [required]=\"field.required\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\"  [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\" [loadAction]=\"field.loadAction\"></spa-text>\r\n\r\n      </ng-container>\r\n\r\n    </ng-container>\r\n\r\n  </div>\r\n\r\n\r\n  <div class=\"span-col-center\" *ngIf=\"config.button\">\r\n    <button mat-raised-button color=\"primary\"  (click)=\"buttonClicked()\"  cdkFocusInitial>{{buttonDisplay}}</button>\r\n  </div>\r\n\r\n\r\n</div>\r\n"]}
@@ -19,6 +19,11 @@ export class SelectComponent extends SelectCommonComponent {
19
19
  this.dialogService = dialogService;
20
20
  this.buttonService = buttonService;
21
21
  }
22
+ ngOnInit() {
23
+ if (this.options == null || this.options == undefined || this.options.length == 0) {
24
+ this.getData(this.loadAction);
25
+ }
26
+ }
22
27
  onHoverChange(isHovered) {
23
28
  this.isHovered = isHovered;
24
29
  }
@@ -67,4 +72,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
67
72
  }], ctorParameters: function () { return [{ type: i1.MessageService }, { type: i2.DataServiceLib }, { type: i3.DialogService }, { type: i4.ButtonService }]; }, propDecorators: { detailsConfig: [{
68
73
  type: Input
69
74
  }] } });
70
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/select/select.component.ts","../../../../../../projects/tin-spa/src/lib/components/select/select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport {  Action, ApiResponse, Button, DetailsDialogConfig, TableConfig } from '../../classes/Classes';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { DialogService } from '../../services/dialog.service';\r\nimport { SelectCommonComponent } from '../select-common/select-common.component';\r\nimport { DetailsDialogInternal } from '../table-internal/detailsDialog-internal.component';\r\nimport { DataServiceLib } from '../../services/datalib.service';\r\nimport { ButtonService } from '../../services/button.service';\r\n\r\n@Component({\r\n  selector: 'spa-select',\r\n  templateUrl: './select.component.html',\r\n  styleUrls: ['./select.component.css']\r\n})\r\nexport class SelectComponent extends SelectCommonComponent {\r\n\r\n  constructor(\r\n    protected override messageService: MessageService, protected override dataService: DataServiceLib,\r\n    private dialogService: DialogService, private buttonService: ButtonService ,\r\n\r\n  ) {\r\n    super(messageService,dataService);\r\n  }\r\n\r\n  @Input() detailsConfig: DetailsDialogConfig;\r\n\r\n\r\n\r\n  onHoverChange(isHovered: boolean): void {\r\n    this.isHovered = isHovered;\r\n  }\r\n\r\n  canCreate(): boolean {\r\n    if (!this.detailsConfig?.buttons) return false;\r\n    const createButton : Button = this.detailsConfig.buttons.find(b => b.name === 'create');\r\n    const tmpTableConfig : TableConfig = {formConfig: this.detailsConfig.formConfig};\r\n    return createButton && (!createButton.disabled || !createButton.disabled(this.value)) && this.buttonService.testVisible(createButton, null, tmpTableConfig)    ;\r\n  }\r\n\r\n  canView(): boolean {\r\n    if (!this.detailsConfig?.buttons) return false;\r\n    let viewButton : Button = this.detailsConfig.buttons.find(b => b.name === 'view');\r\n    if (!viewButton) {\r\n      // Add default view button if not exists\r\n      viewButton = { name: 'view', dialog: true };\r\n      this.detailsConfig.buttons.push(viewButton);\r\n    }\r\n    const tmpTableConfig: TableConfig = { formConfig: this.detailsConfig.formConfig };\r\n    return this.value && viewButton && this.buttonService.testVisible(viewButton, null, tmpTableConfig);\r\n  }\r\n\r\n  onPeekClick(event: MouseEvent, mode: 'create' | 'view'): void {\r\n    event.stopPropagation();\r\n\r\n    if (this.detailsConfig) {\r\n      const dynamicData = mode === 'create' ? {} : { [this.detailsConfig.heroField]: this.value };\r\n\r\n      let button = this.detailsConfig.buttons.find(b => b.name === mode);\r\n      button.detailsConfig = this.detailsConfig;\r\n\r\n      this.dialogService.openConfiguredDetailsDialog( button, dynamicData, DetailsDialogInternal ).subscribe(result => {\r\n        // console.log(result);\r\n\r\n        if (result.message === 'success'){\r\n          this.refresh(event);\r\n        }\r\n\r\n      });\r\n\r\n    } else {\r\n      this.messageService.toast(\"Peek configuration error\");\r\n    }\r\n  }\r\n\r\n\r\n\r\n}\r\n\r\n","<spa-select-common [width]=\"width\" [readonly]=\"readonly\" [required]=\"required\" [defaultFirstValue]=\"defaultFirstValue\"\r\n                   [readonlyMode]=\"readonlyMode\" [hint]=\"hint\" [placeholder]=\"placeholder\" [multiple]=\"multiple\"\r\n                   [display]=\"display\" [(value)]=\"value\" [options]=\"options\" [masterOptions]=\"masterOptions\" [masterField]=\"masterField\"\r\n                   [optionValue]=\"optionValue\" [optionDisplay]=\"optionDisplay\" [optionDisplayExtra]=\"optionDisplayExtra\"\r\n                   [nullable]=\"nullable\" [infoMessage]=\"infoMessage\" [copyContent]=\"copyContent\" [loadAction]=\"loadAction\" [loadIDField]=\"loadIDField\" [field]=\"field\" [data]=\"data\"\r\n                   (valueChange)=\"valueChange.emit($event)\"\r\n                   (hoverChange)=\"onHoverChange($event)\">\r\n  <ng-container additionalButtons>\r\n    <button mat-icon-button *ngIf=\"detailsConfig && canCreate() && isHovered\" (click)=\"onPeekClick($event, 'create')\" matTooltip=\"Add\" matTooltipPosition=\"above\">\r\n      <mat-icon style=\"color: green;\">add</mat-icon>\r\n    </button>\r\n    <button mat-icon-button *ngIf=\"detailsConfig && canView() && isHovered && value\" (click)=\"onPeekClick($event, 'view')\" matTooltip=\"View\" matTooltipPosition=\"above\">\r\n      <mat-icon color=\"primary\">launch</mat-icon>\r\n    </button>\r\n\r\n  </ng-container>\r\n</spa-select-common>\r\n"]}
75
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/select/select.component.ts","../../../../../../projects/tin-spa/src/lib/components/select/select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport {  Action, ApiResponse, Button, DetailsDialogConfig, TableConfig } from '../../classes/Classes';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { DialogService } from '../../services/dialog.service';\r\nimport { SelectCommonComponent } from '../select-common/select-common.component';\r\nimport { DetailsDialogInternal } from '../table-internal/detailsDialog-internal.component';\r\nimport { DataServiceLib } from '../../services/datalib.service';\r\nimport { ButtonService } from '../../services/button.service';\r\n\r\n@Component({\r\n  selector: 'spa-select',\r\n  templateUrl: './select.component.html',\r\n  styleUrls: ['./select.component.css']\r\n})\r\nexport class SelectComponent extends SelectCommonComponent implements OnInit {\r\n\r\n  constructor(\r\n    protected override messageService: MessageService, protected override dataService: DataServiceLib,\r\n    private dialogService: DialogService, private buttonService: ButtonService ,\r\n\r\n  ) {\r\n    super(messageService,dataService);\r\n  }\r\n\r\n  override ngOnInit(): void {\r\n\r\n    if (this.options == null || this.options == undefined || this.options.length == 0) {\r\n      this.getData(this.loadAction);\r\n    }\r\n\r\n  }\r\n\r\n  @Input() detailsConfig: DetailsDialogConfig;\r\n\r\n\r\n  onHoverChange(isHovered: boolean): void {\r\n    this.isHovered = isHovered;\r\n  }\r\n\r\n  canCreate(): boolean {\r\n    if (!this.detailsConfig?.buttons) return false;\r\n    const createButton : Button = this.detailsConfig.buttons.find(b => b.name === 'create');\r\n    const tmpTableConfig : TableConfig = {formConfig: this.detailsConfig.formConfig};\r\n    return createButton && (!createButton.disabled || !createButton.disabled(this.value)) && this.buttonService.testVisible(createButton, null, tmpTableConfig)    ;\r\n  }\r\n\r\n  canView(): boolean {\r\n    if (!this.detailsConfig?.buttons) return false;\r\n    let viewButton : Button = this.detailsConfig.buttons.find(b => b.name === 'view');\r\n    if (!viewButton) {\r\n      // Add default view button if not exists\r\n      viewButton = { name: 'view', dialog: true };\r\n      this.detailsConfig.buttons.push(viewButton);\r\n    }\r\n    const tmpTableConfig: TableConfig = { formConfig: this.detailsConfig.formConfig };\r\n    return this.value && viewButton && this.buttonService.testVisible(viewButton, null, tmpTableConfig);\r\n  }\r\n\r\n  onPeekClick(event: MouseEvent, mode: 'create' | 'view'): void {\r\n    event.stopPropagation();\r\n\r\n    if (this.detailsConfig) {\r\n      const dynamicData = mode === 'create' ? {} : { [this.detailsConfig.heroField]: this.value };\r\n\r\n      let button = this.detailsConfig.buttons.find(b => b.name === mode);\r\n      button.detailsConfig = this.detailsConfig;\r\n\r\n      this.dialogService.openConfiguredDetailsDialog( button, dynamicData, DetailsDialogInternal ).subscribe(result => {\r\n        // console.log(result);\r\n\r\n        if (result.message === 'success'){\r\n          this.refresh(event);\r\n        }\r\n\r\n      });\r\n\r\n    } else {\r\n      this.messageService.toast(\"Peek configuration error\");\r\n    }\r\n  }\r\n\r\n\r\n\r\n}\r\n\r\n","<spa-select-common [width]=\"width\" [readonly]=\"readonly\" [required]=\"required\" [defaultFirstValue]=\"defaultFirstValue\"\r\n                   [readonlyMode]=\"readonlyMode\" [hint]=\"hint\" [placeholder]=\"placeholder\" [multiple]=\"multiple\"\r\n                   [display]=\"display\" [(value)]=\"value\" [options]=\"options\" [masterOptions]=\"masterOptions\" [masterField]=\"masterField\"\r\n                   [optionValue]=\"optionValue\" [optionDisplay]=\"optionDisplay\" [optionDisplayExtra]=\"optionDisplayExtra\"\r\n                   [nullable]=\"nullable\" [infoMessage]=\"infoMessage\" [copyContent]=\"copyContent\" [loadAction]=\"loadAction\" [loadIDField]=\"loadIDField\" [field]=\"field\" [data]=\"data\"\r\n                   (valueChange)=\"valueChange.emit($event)\"\r\n                   (hoverChange)=\"onHoverChange($event)\">\r\n  <ng-container additionalButtons>\r\n    <button mat-icon-button *ngIf=\"detailsConfig && canCreate() && isHovered\" (click)=\"onPeekClick($event, 'create')\" matTooltip=\"Add\" matTooltipPosition=\"above\">\r\n      <mat-icon style=\"color: green;\">add</mat-icon>\r\n    </button>\r\n    <button mat-icon-button *ngIf=\"detailsConfig && canView() && isHovered && value\" (click)=\"onPeekClick($event, 'view')\" matTooltip=\"View\" matTooltipPosition=\"above\">\r\n      <mat-icon color=\"primary\">launch</mat-icon>\r\n    </button>\r\n\r\n  </ng-container>\r\n</spa-select-common>\r\n"]}
@@ -34,21 +34,19 @@ export class SelectCommonComponent {
34
34
  this.hoverChange = new EventEmitter();
35
35
  }
36
36
  ngOnInit() {
37
+ console.log("ngOnInit");
37
38
  if (this.placeholder == "") {
38
39
  this.placeholder = "Select " + this.display;
39
40
  }
40
- if (this.options == null || this.options == undefined || this.options.length == 0) {
41
- this.getData(this.loadAction);
41
+ this.setDefaultValue();
42
+ if (this.field?.optionsSubject) {
43
+ this.subscription = this.field.optionsSubject.subscribe(newOptions => {
44
+ if (newOptions) {
45
+ this.options = newOptions;
46
+ // this.initFilter();
47
+ }
48
+ });
42
49
  }
43
- // this.setDefaultValue();
44
- // if (this.field?.optionsSubject) {
45
- // this.subscription = this.field.optionsSubject.subscribe(newOptions => {
46
- // if (newOptions) {
47
- // this.options = newOptions;
48
- // // this.initFilter();
49
- // }
50
- // });
51
- // }
52
50
  }
53
51
  ngOnChanges() {
54
52
  if (this.readonlyMode != "" && this.options.length > 0) {
@@ -90,6 +88,7 @@ export class SelectCommonComponent {
90
88
  this.getData(refreshAction);
91
89
  }
92
90
  transformLoadUrl(action) {
91
+ // console.log("Transforming", action);
93
92
  if (!action?.url || !this.loadIDField || !this.data)
94
93
  return action;
95
94
  // Get the ID value from data using loadIDField
@@ -109,8 +108,7 @@ export class SelectCommonComponent {
109
108
  if (this.masterField)
110
109
  return; //if master field is set, then it will be loaded by the master field
111
110
  const transformedAction = this.transformLoadUrl(loadAction);
112
- console.log("TransformedLoadUrl", transformedAction);
113
- // return;
111
+ // console.log("TransformedLoadUrl", transformedAction);
114
112
  this.dataService.CallApi(transformedAction, "").subscribe((apiResponse) => {
115
113
  if (apiResponse.success) {
116
114
  this.options = apiResponse.data;
@@ -189,4 +187,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
189
187
  }], hoverChange: [{
190
188
  type: Output
191
189
  }] } });
192
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-common.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/select-common/select-common.component.ts","../../../../../../projects/tin-spa/src/lib/components/select-common/select-common.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, OnInit, Output } from '@angular/core';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { Action, ApiResponse, Field } from '../../classes/Classes';\r\nimport { DataServiceLib } from '../../services/datalib.service';\r\nimport { BehaviorSubject, Subscription } from 'rxjs';\r\n\r\n@Component({\r\n  selector: 'spa-select-common',\r\n  templateUrl: './select-common.component.html',\r\n  styleUrls: ['./select-common.component.css']\r\n})\r\nexport class SelectCommonComponent implements OnInit, OnDestroy {\r\n\r\n  constructor(protected messageService: MessageService, protected dataService: DataServiceLib,) { }\r\n\r\n  ngOnInit(): void {\r\n\r\n    if (this.placeholder == \"\") {\r\n      this.placeholder = \"Select \" + this.display;\r\n    }\r\n\r\n    if(this.options == null || this.options == undefined || this.options.length == 0){\r\n      this.getData(this.loadAction);\r\n    }\r\n\r\n\r\n    // this.setDefaultValue();\r\n\r\n    // if (this.field?.optionsSubject) {\r\n    //   this.subscription = this.field.optionsSubject.subscribe(newOptions => {\r\n    //     if (newOptions) {\r\n    //       this.options = newOptions;\r\n    //       // this.initFilter();\r\n    //     }\r\n    //   });\r\n    // }\r\n\r\n  }\r\n\r\n  ngOnChanges() {\r\n\r\n    if (this.readonlyMode != \"\" && this.options.length > 0) {\r\n      this.displayValue = this.options.filter((m) => m[`${this.optionValue}`] == this.value)[0][`${this.optionDisplay}`]\r\n    }\r\n\r\n    //add a null option\r\n    if (this.nullable && this.options && this.options.length > 0 && this.options[0][this.optionValue] != null) {\r\n      this.options.unshift({ [this.optionValue]: null, [this.optionDisplay]: \"None\" })\r\n    }\r\n\r\n  }\r\n\r\n  displayValue;\r\n  isHovered = false;\r\n\r\n  private subscription: Subscription;\r\n\r\n  @Input() width = \"100%\"\r\n  @Input() readonly = false;\r\n  @Input() required = true;\r\n  @Input() defaultFirstValue = false;\r\n  @Input() readonlyMode = \"\";\r\n  @Input() hint = \"\";\r\n  @Input() placeholder = \"\";\r\n  @Input() multiple: boolean = false;\r\n\r\n  @Input() display = \"\";\r\n  @Input() value;\r\n  @Input() options: any;\r\n  @Input() masterOptions: any;\r\n  @Input() masterField: string;\r\n  @Input() optionValue = \"\";\r\n  @Input() optionDisplay = \"\";\r\n  @Input() optionDisplayExtra = \"\";\r\n  @Input() nullable = false;\r\n\r\n\r\n  @Input() infoMessage: string;\r\n  @Input() copyContent = false;\r\n  @Input() loadAction: Action;\r\n  @Input() loadIDField: string;\r\n  @Input() field: Field;\r\n  @Input() data: any;\r\n\r\n  @Output() valueChange = new EventEmitter();\r\n  @Output() hoverChange = new EventEmitter<boolean>();\r\n\r\n  setDefaultValue(){\r\n    if (\r\n      this.defaultFirstValue && this.options && this.options.length > 0 &&\r\n      (this.value == null || this.value == undefined || (typeof (this.value) == 'string' && this.value == '') || (typeof (this.value) == 'number' && this.value == 0))\r\n      ) {\r\n\r\n      this.value = this.options[0][this.optionValue]\r\n      this.changed();\r\n    }\r\n  }\r\n\r\n  changed() {\r\n    this.valueChange.emit(this.value);\r\n  }\r\n\r\n  onMouseEnter(): void {\r\n    this.isHovered = true;\r\n    this.hoverChange.emit(true);\r\n  }\r\n\r\n  onMouseLeave(): void {\r\n    this.isHovered = false;\r\n    this.hoverChange.emit(false);\r\n  }\r\n\r\n  refresh(event: MouseEvent): void {\r\n    console.log(\"refresh clicked\")\r\n    event.stopPropagation();\r\n    if (!this.loadAction) {\r\n      return;\r\n    }\r\n\r\n    const refreshAction : Action = {\r\n      ...this.loadAction,\r\n      skipCache: true\r\n    };\r\n\r\n    this.getData(refreshAction);\r\n  }\r\n\r\n  private transformLoadUrl(action: Action): Action {\r\n\r\n    if (!action?.url || !this.loadIDField || !this.data) return action;\r\n\r\n    // Get the ID value from data using loadIDField\r\n    const idValue = this.data[this.loadIDField];\r\n    if (!idValue) return action;\r\n\r\n    // Transform URL similar to table component\r\n    const urlParts = action.url.split('/');\r\n    return {\r\n      ...action,\r\n      url: `${urlParts[0]}/${urlParts[1]}/${idValue}`\r\n    };\r\n  }\r\n\r\n  getData(loadAction: Action) {\r\n\r\n    if (!loadAction) return;\r\n    if (this.masterField) return; //if master field is set, then it will be loaded by the master field\r\n\r\n    const transformedAction = this.transformLoadUrl(loadAction);\r\n\r\n    console.log(\"TransformedLoadUrl\", transformedAction);\r\n    // return;\r\n\r\n    this.dataService.CallApi(transformedAction, \"\").subscribe((apiResponse: ApiResponse) => {\r\n      if (apiResponse.success) {\r\n        this.options = apiResponse.data;\r\n\r\n        if (this.field) {\r\n          this.field.options = apiResponse.data;\r\n\r\n          this.setDefaultValue();\r\n\r\n          if (!this.field.optionsSubject) {\r\n            this.field.optionsSubject = new BehaviorSubject(apiResponse.data);\r\n          } else {\r\n            this.field.optionsSubject.next(apiResponse.data);\r\n          }\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    if (this.subscription) {\r\n      this.subscription.unsubscribe();\r\n    }\r\n  }\r\n\r\n}\r\n","<mat-form-field *ngIf=\"readonlyMode==''\" floatLabel=\"always\" [hintLabel]=\"hint\" [ngStyle]=\"{'width':width ?? '100%'}\" [hideRequiredMarker]=\"!required\" (mouseenter)=\"onMouseEnter()\" (mouseleave)=\"onMouseLeave()\">\r\n\r\n  <mat-label>{{display}}</mat-label>\r\n  <mat-select [(value)]=\"value\" (selectionChange)=\"changed()\" [multiple]=\"multiple\" [disabled]=\"readonly\" [placeholder]=\"placeholder\">\r\n    <mat-option *ngFor=\"let row of options\" [value]=\"row[optionValue]\">\r\n      {{row[optionDisplay]}} <label *ngIf=\"optionDisplayExtra!='' && row[optionDisplayExtra] && row[optionDisplayExtra] != ''\">({{row[optionDisplayExtra]}})</label>\r\n    </mat-option>\r\n  </mat-select>\r\n\r\n  <div matSuffix class=\"suffix-icons\">\r\n    <ng-content select=\"[additionalButtons]\"></ng-content>\r\n    <button mat-icon-button *ngIf=\"loadAction && isHovered && !masterField\" (click)=\"refresh($event)\" matTooltip=\"Refresh\" matTooltipPosition=\"above\">\r\n      <mat-icon color=\"primary\">cached</mat-icon>\r\n    </button>\r\n    <spa-suffix [infoMessage]=\"infoMessage\" [copyContent]=\"copyContent\" [isHovered]=\"isHovered\" [(value)]=\"value\"></spa-suffix>\r\n  </div>\r\n\r\n</mat-form-field>\r\n"]}
190
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-common.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/select-common/select-common.component.ts","../../../../../../projects/tin-spa/src/lib/components/select-common/select-common.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, OnInit, Output } from '@angular/core';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { Action, ApiResponse, Field } from '../../classes/Classes';\r\nimport { DataServiceLib } from '../../services/datalib.service';\r\nimport { BehaviorSubject, Subscription } from 'rxjs';\r\n\r\n@Component({\r\n  selector: 'spa-select-common',\r\n  templateUrl: './select-common.component.html',\r\n  styleUrls: ['./select-common.component.css']\r\n})\r\nexport class SelectCommonComponent implements OnInit, OnDestroy {\r\n\r\n  constructor(protected messageService: MessageService, protected dataService: DataServiceLib,) { }\r\n\r\n  ngOnInit(): void {\r\n\r\n    console.log(\"ngOnInit\");\r\n\r\n    if (this.placeholder == \"\") {\r\n      this.placeholder = \"Select \" + this.display;\r\n    }\r\n\r\n\r\n    this.setDefaultValue();\r\n\r\n    if (this.field?.optionsSubject) {\r\n      this.subscription = this.field.optionsSubject.subscribe(newOptions => {\r\n        if (newOptions) {\r\n          this.options = newOptions;\r\n          // this.initFilter();\r\n        }\r\n      });\r\n    }\r\n\r\n  }\r\n\r\n  ngOnChanges() {\r\n\r\n    if (this.readonlyMode != \"\" && this.options.length > 0) {\r\n      this.displayValue = this.options.filter((m) => m[`${this.optionValue}`] == this.value)[0][`${this.optionDisplay}`]\r\n    }\r\n\r\n    //add a null option\r\n    if (this.nullable && this.options && this.options.length > 0 && this.options[0][this.optionValue] != null) {\r\n      this.options.unshift({ [this.optionValue]: null, [this.optionDisplay]: \"None\" })\r\n    }\r\n\r\n  }\r\n\r\n  displayValue;\r\n  isHovered = false;\r\n\r\n  private subscription: Subscription;\r\n\r\n  @Input() width = \"100%\"\r\n  @Input() readonly = false;\r\n  @Input() required = true;\r\n  @Input() defaultFirstValue = false;\r\n  @Input() readonlyMode = \"\";\r\n  @Input() hint = \"\";\r\n  @Input() placeholder = \"\";\r\n  @Input() multiple: boolean = false;\r\n\r\n  @Input() display = \"\";\r\n  @Input() value;\r\n  @Input() options: any;\r\n  @Input() masterOptions: any;\r\n  @Input() masterField: string;\r\n  @Input() optionValue = \"\";\r\n  @Input() optionDisplay = \"\";\r\n  @Input() optionDisplayExtra = \"\";\r\n  @Input() nullable = false;\r\n\r\n\r\n  @Input() infoMessage: string;\r\n  @Input() copyContent = false;\r\n  @Input() loadAction: Action;\r\n  @Input() loadIDField: string;\r\n  @Input() field: Field;\r\n  @Input() data: any;\r\n\r\n  @Output() valueChange = new EventEmitter();\r\n  @Output() hoverChange = new EventEmitter<boolean>();\r\n\r\n  setDefaultValue(){\r\n    if (\r\n      this.defaultFirstValue && this.options && this.options.length > 0 &&\r\n      (this.value == null || this.value == undefined || (typeof (this.value) == 'string' && this.value == '') || (typeof (this.value) == 'number' && this.value == 0))\r\n      ) {\r\n\r\n      this.value = this.options[0][this.optionValue]\r\n      this.changed();\r\n    }\r\n  }\r\n\r\n  changed() {\r\n    this.valueChange.emit(this.value);\r\n  }\r\n\r\n  onMouseEnter(): void {\r\n    this.isHovered = true;\r\n    this.hoverChange.emit(true);\r\n  }\r\n\r\n  onMouseLeave(): void {\r\n    this.isHovered = false;\r\n    this.hoverChange.emit(false);\r\n  }\r\n\r\n  refresh(event: MouseEvent): void {\r\n    console.log(\"refresh clicked\")\r\n    event.stopPropagation();\r\n    if (!this.loadAction) {\r\n      return;\r\n    }\r\n\r\n    const refreshAction : Action = {\r\n      ...this.loadAction,\r\n      skipCache: true\r\n    };\r\n\r\n    this.getData(refreshAction);\r\n  }\r\n\r\n  private transformLoadUrl(action: Action): Action {\r\n\r\n    // console.log(\"Transforming\", action);\r\n\r\n    if (!action?.url || !this.loadIDField || !this.data) return action;\r\n\r\n    // Get the ID value from data using loadIDField\r\n    const idValue = this.data[this.loadIDField];\r\n    if (!idValue) return action;\r\n\r\n    // Transform URL similar to table component\r\n    const urlParts = action.url.split('/');\r\n    return {\r\n      ...action,\r\n      url: `${urlParts[0]}/${urlParts[1]}/${idValue}`\r\n    };\r\n  }\r\n\r\n  getData(loadAction: Action) {\r\n\r\n    if (!loadAction) return;\r\n    if (this.masterField) return; //if master field is set, then it will be loaded by the master field\r\n\r\n    const transformedAction = this.transformLoadUrl(loadAction);\r\n\r\n    // console.log(\"TransformedLoadUrl\", transformedAction);\r\n\r\n    this.dataService.CallApi(transformedAction, \"\").subscribe((apiResponse: ApiResponse) => {\r\n      if (apiResponse.success) {\r\n        this.options = apiResponse.data;\r\n\r\n        if (this.field) {\r\n          this.field.options = apiResponse.data;\r\n\r\n          this.setDefaultValue();\r\n\r\n          if (!this.field.optionsSubject) {\r\n            this.field.optionsSubject = new BehaviorSubject(apiResponse.data);\r\n          } else {\r\n            this.field.optionsSubject.next(apiResponse.data);\r\n          }\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    if (this.subscription) {\r\n      this.subscription.unsubscribe();\r\n    }\r\n  }\r\n\r\n}\r\n","<mat-form-field *ngIf=\"readonlyMode==''\" floatLabel=\"always\" [hintLabel]=\"hint\" [ngStyle]=\"{'width':width ?? '100%'}\" [hideRequiredMarker]=\"!required\" (mouseenter)=\"onMouseEnter()\" (mouseleave)=\"onMouseLeave()\">\r\n\r\n  <mat-label>{{display}}</mat-label>\r\n  <mat-select [(value)]=\"value\" (selectionChange)=\"changed()\" [multiple]=\"multiple\" [disabled]=\"readonly\" [placeholder]=\"placeholder\">\r\n    <mat-option *ngFor=\"let row of options\" [value]=\"row[optionValue]\">\r\n      {{row[optionDisplay]}} <label *ngIf=\"optionDisplayExtra!='' && row[optionDisplayExtra] && row[optionDisplayExtra] != ''\">({{row[optionDisplayExtra]}})</label>\r\n    </mat-option>\r\n  </mat-select>\r\n\r\n  <div matSuffix class=\"suffix-icons\">\r\n    <ng-content select=\"[additionalButtons]\"></ng-content>\r\n    <button mat-icon-button *ngIf=\"loadAction && isHovered && !masterField\" (click)=\"refresh($event)\" matTooltip=\"Refresh\" matTooltipPosition=\"above\">\r\n      <mat-icon color=\"primary\">cached</mat-icon>\r\n    </button>\r\n    <spa-suffix [infoMessage]=\"infoMessage\" [copyContent]=\"copyContent\" [isHovered]=\"isHovered\" [(value)]=\"value\"></spa-suffix>\r\n  </div>\r\n\r\n</mat-form-field>\r\n"]}
@@ -19,6 +19,11 @@ export class SelectInternalComponent extends SelectCommonComponent {
19
19
  this.dialogService = dialogService;
20
20
  this.buttonService = buttonService;
21
21
  }
22
+ ngOnInit() {
23
+ if (this.options == null || this.options == undefined || this.options.length == 0) {
24
+ this.getData(this.loadAction);
25
+ }
26
+ }
22
27
  onHoverChange(isHovered) {
23
28
  this.isHovered = isHovered;
24
29
  }
@@ -67,4 +72,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
67
72
  }], ctorParameters: function () { return [{ type: i1.MessageService }, { type: i2.DataServiceLib }, { type: i3.DialogService }, { type: i4.ButtonService }]; }, propDecorators: { detailsConfig: [{
68
73
  type: Input
69
74
  }] } });
70
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-internal.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/select-internal/select-internal.component.ts","../../../../../../projects/tin-spa/src/lib/components/select-internal/select-internal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport { Action, ApiResponse, Button, DetailsDialogConfig, TableConfig } from '../../classes/Classes';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { DialogService } from '../../services/dialog.service';\r\nimport { SelectCommonComponent } from '../select-common/select-common.component';\r\nimport { DataServiceLib } from '../../services/datalib.service';\r\nimport { DetailsDialogLite } from '../table-lite/detailsDialog-lite.component';\r\nimport { ButtonService } from '../../services/button.service';\r\n\r\n@Component({\r\n  selector: 'spa-select-internal',\r\n  templateUrl: './select-internal.component.html',\r\n  styleUrls: ['./select-internal.component.css']\r\n})\r\nexport class SelectInternalComponent extends SelectCommonComponent {\r\n  constructor(\r\n    protected override messageService: MessageService, protected override dataService: DataServiceLib,\r\n    private dialogService: DialogService, private buttonService: ButtonService,\r\n\r\n  ) {\r\n    super(messageService, dataService);\r\n  }\r\n\r\n  @Input() detailsConfig: DetailsDialogConfig;\r\n\r\n\r\n\r\n  onHoverChange(isHovered: boolean): void {\r\n    this.isHovered = isHovered;\r\n  }\r\n\r\n  canCreate(): boolean {\r\n    if (!this.detailsConfig?.buttons) return false;\r\n    const createButton: Button = this.detailsConfig.buttons.find(b => b.name === 'create');\r\n    const tmpTableConfig: TableConfig = { formConfig: this.detailsConfig.formConfig };\r\n    return createButton && (!createButton.disabled || !createButton.disabled(this.value)) && this.buttonService.testVisible(createButton, null, tmpTableConfig);\r\n  }\r\n\r\n  canView(): boolean {\r\n    if (!this.detailsConfig?.buttons) return false;\r\n    let viewButton: Button = this.detailsConfig.buttons.find(b => b.name === 'view');\r\n    if (!viewButton) {\r\n      // Add default view button if not exists\r\n      viewButton = { name: 'view', dialog: true };\r\n      this.detailsConfig.buttons.push(viewButton);\r\n    }\r\n    const tmpTableConfig: TableConfig = { formConfig: this.detailsConfig.formConfig };\r\n    return this.value && viewButton && this.buttonService.testVisible(viewButton, null, tmpTableConfig);\r\n  }\r\n\r\n  onPeekClick(event: MouseEvent, mode: 'create' | 'view'): void {\r\n    event.stopPropagation();\r\n\r\n    if (this.detailsConfig) {\r\n      const dynamicData = mode === 'create' ? {} : { [this.detailsConfig.heroField]: this.value };\r\n\r\n      let button = this.detailsConfig.buttons.find(b => b.name === mode);\r\n      button.detailsConfig = this.detailsConfig;\r\n\r\n      this.dialogService.openConfiguredDetailsDialog( button, dynamicData, DetailsDialogLite ).subscribe(result => {\r\n        console.log(result);\r\n\r\n        if (result.message === 'success') {\r\n          this.refresh(event);\r\n        }\r\n\r\n      });\r\n\r\n    } else {\r\n      this.messageService.toast(\"Peek configuration error\");\r\n    }\r\n  }\r\n}\r\n","<spa-select-common [width]=\"width\" [readonly]=\"readonly\" [required]=\"required\" [defaultFirstValue]=\"defaultFirstValue\"\r\n                   [readonlyMode]=\"readonlyMode\" [hint]=\"hint\" [placeholder]=\"placeholder\" [multiple]=\"multiple\"\r\n                   [display]=\"display\" [(value)]=\"value\" [options]=\"options\" [masterOptions]=\"masterOptions\" [masterField]=\"masterField\"\r\n                   [optionValue]=\"optionValue\" [optionDisplay]=\"optionDisplay\" [optionDisplayExtra]=\"optionDisplayExtra\"\r\n                   [nullable]=\"nullable\" [infoMessage]=\"infoMessage\" [copyContent]=\"copyContent\" [loadAction]=\"loadAction\" [loadIDField]=\"loadIDField\" [field]=\"field\" [data]=\"data\"\r\n                   (valueChange)=\"valueChange.emit($event)\"\r\n                   (hoverChange)=\"onHoverChange($event)\">\r\n  <ng-container additionalButtons>\r\n    <button mat-icon-button *ngIf=\"detailsConfig && canCreate() && isHovered\" (click)=\"onPeekClick($event, 'create')\" matTooltip=\"Add\" matTooltipPosition=\"above\">\r\n      <mat-icon style=\"color: green;\">add</mat-icon>\r\n    </button>\r\n    <button mat-icon-button *ngIf=\"detailsConfig && canView() && isHovered && value\" (click)=\"onPeekClick($event, 'view')\" matTooltip=\"View\" matTooltipPosition=\"above\">\r\n      <mat-icon color=\"primary\">launch</mat-icon>\r\n    </button>\r\n\r\n  </ng-container>\r\n</spa-select-common>\r\n"]}
75
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-internal.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/select-internal/select-internal.component.ts","../../../../../../projects/tin-spa/src/lib/components/select-internal/select-internal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport { Action, ApiResponse, Button, DetailsDialogConfig, TableConfig } from '../../classes/Classes';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { DialogService } from '../../services/dialog.service';\r\nimport { SelectCommonComponent } from '../select-common/select-common.component';\r\nimport { DataServiceLib } from '../../services/datalib.service';\r\nimport { DetailsDialogLite } from '../table-lite/detailsDialog-lite.component';\r\nimport { ButtonService } from '../../services/button.service';\r\n\r\n@Component({\r\n  selector: 'spa-select-internal',\r\n  templateUrl: './select-internal.component.html',\r\n  styleUrls: ['./select-internal.component.css']\r\n})\r\nexport class SelectInternalComponent extends SelectCommonComponent implements OnInit {\r\n  constructor(\r\n    protected override messageService: MessageService, protected override dataService: DataServiceLib,\r\n    private dialogService: DialogService, private buttonService: ButtonService,\r\n\r\n  ) {\r\n    super(messageService, dataService);\r\n  }\r\n\r\n  override ngOnInit(): void {\r\n\r\n    if (this.options == null || this.options == undefined || this.options.length == 0) {\r\n      this.getData(this.loadAction);\r\n    }\r\n\r\n  }\r\n\r\n  @Input() detailsConfig: DetailsDialogConfig;\r\n\r\n\r\n  onHoverChange(isHovered: boolean): void {\r\n    this.isHovered = isHovered;\r\n  }\r\n\r\n  canCreate(): boolean {\r\n    if (!this.detailsConfig?.buttons) return false;\r\n    const createButton: Button = this.detailsConfig.buttons.find(b => b.name === 'create');\r\n    const tmpTableConfig: TableConfig = { formConfig: this.detailsConfig.formConfig };\r\n    return createButton && (!createButton.disabled || !createButton.disabled(this.value)) && this.buttonService.testVisible(createButton, null, tmpTableConfig);\r\n  }\r\n\r\n  canView(): boolean {\r\n    if (!this.detailsConfig?.buttons) return false;\r\n    let viewButton: Button = this.detailsConfig.buttons.find(b => b.name === 'view');\r\n    if (!viewButton) {\r\n      // Add default view button if not exists\r\n      viewButton = { name: 'view', dialog: true };\r\n      this.detailsConfig.buttons.push(viewButton);\r\n    }\r\n    const tmpTableConfig: TableConfig = { formConfig: this.detailsConfig.formConfig };\r\n    return this.value && viewButton && this.buttonService.testVisible(viewButton, null, tmpTableConfig);\r\n  }\r\n\r\n  onPeekClick(event: MouseEvent, mode: 'create' | 'view'): void {\r\n    event.stopPropagation();\r\n\r\n    if (this.detailsConfig) {\r\n      const dynamicData = mode === 'create' ? {} : { [this.detailsConfig.heroField]: this.value };\r\n\r\n      let button = this.detailsConfig.buttons.find(b => b.name === mode);\r\n      button.detailsConfig = this.detailsConfig;\r\n\r\n      this.dialogService.openConfiguredDetailsDialog( button, dynamicData, DetailsDialogLite ).subscribe(result => {\r\n        console.log(result);\r\n\r\n        if (result.message === 'success') {\r\n          this.refresh(event);\r\n        }\r\n\r\n      });\r\n\r\n    } else {\r\n      this.messageService.toast(\"Peek configuration error\");\r\n    }\r\n  }\r\n}\r\n","<spa-select-common [width]=\"width\" [readonly]=\"readonly\" [required]=\"required\" [defaultFirstValue]=\"defaultFirstValue\"\r\n                   [readonlyMode]=\"readonlyMode\" [hint]=\"hint\" [placeholder]=\"placeholder\" [multiple]=\"multiple\"\r\n                   [display]=\"display\" [(value)]=\"value\" [options]=\"options\" [masterOptions]=\"masterOptions\" [masterField]=\"masterField\"\r\n                   [optionValue]=\"optionValue\" [optionDisplay]=\"optionDisplay\" [optionDisplayExtra]=\"optionDisplayExtra\"\r\n                   [nullable]=\"nullable\" [infoMessage]=\"infoMessage\" [copyContent]=\"copyContent\" [loadAction]=\"loadAction\" [loadIDField]=\"loadIDField\" [field]=\"field\" [data]=\"data\"\r\n                   (valueChange)=\"valueChange.emit($event)\"\r\n                   (hoverChange)=\"onHoverChange($event)\">\r\n  <ng-container additionalButtons>\r\n    <button mat-icon-button *ngIf=\"detailsConfig && canCreate() && isHovered\" (click)=\"onPeekClick($event, 'create')\" matTooltip=\"Add\" matTooltipPosition=\"above\">\r\n      <mat-icon style=\"color: green;\">add</mat-icon>\r\n    </button>\r\n    <button mat-icon-button *ngIf=\"detailsConfig && canView() && isHovered && value\" (click)=\"onPeekClick($event, 'view')\" matTooltip=\"View\" matTooltipPosition=\"above\">\r\n      <mat-icon color=\"primary\">launch</mat-icon>\r\n    </button>\r\n\r\n  </ng-container>\r\n</spa-select-common>\r\n"]}
@@ -3,6 +3,11 @@ import { SelectCommonComponent } from '../select-common/select-common.component'
3
3
  import * as i0 from "@angular/core";
4
4
  import * as i1 from "../select-common/select-common.component";
5
5
  export class SelectLiteComponent extends SelectCommonComponent {
6
+ ngOnInit() {
7
+ if (this.options == null || this.options == undefined || this.options.length == 0) {
8
+ this.getData(this.loadAction);
9
+ }
10
+ }
6
11
  }
7
12
  SelectLiteComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: SelectLiteComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
8
13
  SelectLiteComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: SelectLiteComponent, selector: "spa-select-lite", usesInheritance: true, ngImport: i0, template: "<spa-select-common [width]=\"width\" [readonly]=\"readonly\" [required]=\"required\" [defaultFirstValue]=\"defaultFirstValue\"\n [readonlyMode]=\"readonlyMode\" [hint]=\"hint\" [placeholder]=\"placeholder\" [multiple]=\"multiple\"\n [display]=\"display\" [(value)]=\"value\" [options]=\"options\" [masterOptions]=\"masterOptions\" [masterField]=\"masterField\"\n [optionValue]=\"optionValue\" [optionDisplay]=\"optionDisplay\" [optionDisplayExtra]=\"optionDisplayExtra\"\n [nullable]=\"nullable\" [infoMessage]=\"infoMessage\" [copyContent]=\"copyContent\" [loadAction]=\"loadAction\" [loadIDField]=\"loadIDField\" [field]=\"field\" [data]=\"data\"\n (valueChange)=\"valueChange.emit($event)\">\n</spa-select-common>\n", styles: [""], dependencies: [{ kind: "component", type: i1.SelectCommonComponent, selector: "spa-select-common", inputs: ["width", "readonly", "required", "defaultFirstValue", "readonlyMode", "hint", "placeholder", "multiple", "display", "value", "options", "masterOptions", "masterField", "optionValue", "optionDisplay", "optionDisplayExtra", "nullable", "infoMessage", "copyContent", "loadAction", "loadIDField", "field", "data"], outputs: ["valueChange", "hoverChange"] }] });
@@ -10,4 +15,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
10
15
  type: Component,
11
16
  args: [{ selector: 'spa-select-lite', template: "<spa-select-common [width]=\"width\" [readonly]=\"readonly\" [required]=\"required\" [defaultFirstValue]=\"defaultFirstValue\"\n [readonlyMode]=\"readonlyMode\" [hint]=\"hint\" [placeholder]=\"placeholder\" [multiple]=\"multiple\"\n [display]=\"display\" [(value)]=\"value\" [options]=\"options\" [masterOptions]=\"masterOptions\" [masterField]=\"masterField\"\n [optionValue]=\"optionValue\" [optionDisplay]=\"optionDisplay\" [optionDisplayExtra]=\"optionDisplayExtra\"\n [nullable]=\"nullable\" [infoMessage]=\"infoMessage\" [copyContent]=\"copyContent\" [loadAction]=\"loadAction\" [loadIDField]=\"loadIDField\" [field]=\"field\" [data]=\"data\"\n (valueChange)=\"valueChange.emit($event)\">\n</spa-select-common>\n" }]
12
17
  }] });
13
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LWxpdGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGluLXNwYS9zcmMvbGliL2NvbXBvbmVudHMvc2VsZWN0LWxpdGUvc2VsZWN0LWxpdGUuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGluLXNwYS9zcmMvbGliL2NvbXBvbmVudHMvc2VsZWN0LWxpdGUvc2VsZWN0LWxpdGUuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUNsRCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSwwQ0FBMEMsQ0FBQzs7O0FBT2pGLE1BQU0sT0FBTyxtQkFBb0IsU0FBUSxxQkFBcUI7O2dIQUFqRCxtQkFBbUI7b0dBQW5CLG1CQUFtQiw4RUNSaEMsMHlCQU9BOzJGRENhLG1CQUFtQjtrQkFML0IsU0FBUzsrQkFDRSxpQkFBaUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgU2VsZWN0Q29tbW9uQ29tcG9uZW50IH0gZnJvbSAnLi4vc2VsZWN0LWNvbW1vbi9zZWxlY3QtY29tbW9uLmNvbXBvbmVudCc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3NwYS1zZWxlY3QtbGl0ZScsXG4gIHRlbXBsYXRlVXJsOiAnLi9zZWxlY3QtbGl0ZS5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL3NlbGVjdC1saXRlLmNvbXBvbmVudC5jc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBTZWxlY3RMaXRlQ29tcG9uZW50IGV4dGVuZHMgU2VsZWN0Q29tbW9uQ29tcG9uZW50IHtcblxuXG59XG4iLCI8c3BhLXNlbGVjdC1jb21tb24gW3dpZHRoXT1cIndpZHRoXCIgW3JlYWRvbmx5XT1cInJlYWRvbmx5XCIgW3JlcXVpcmVkXT1cInJlcXVpcmVkXCIgW2RlZmF1bHRGaXJzdFZhbHVlXT1cImRlZmF1bHRGaXJzdFZhbHVlXCJcbiAgICAgICAgICAgICAgICAgICBbcmVhZG9ubHlNb2RlXT1cInJlYWRvbmx5TW9kZVwiIFtoaW50XT1cImhpbnRcIiBbcGxhY2Vob2xkZXJdPVwicGxhY2Vob2xkZXJcIiBbbXVsdGlwbGVdPVwibXVsdGlwbGVcIlxuICAgICAgICAgICAgICAgICAgIFtkaXNwbGF5XT1cImRpc3BsYXlcIiBbKHZhbHVlKV09XCJ2YWx1ZVwiIFtvcHRpb25zXT1cIm9wdGlvbnNcIiBbbWFzdGVyT3B0aW9uc109XCJtYXN0ZXJPcHRpb25zXCIgW21hc3RlckZpZWxkXT1cIm1hc3RlckZpZWxkXCJcbiAgICAgICAgICAgICAgICAgICBbb3B0aW9uVmFsdWVdPVwib3B0aW9uVmFsdWVcIiBbb3B0aW9uRGlzcGxheV09XCJvcHRpb25EaXNwbGF5XCIgW29wdGlvbkRpc3BsYXlFeHRyYV09XCJvcHRpb25EaXNwbGF5RXh0cmFcIlxuICAgICAgICAgICAgICAgICAgIFtudWxsYWJsZV09XCJudWxsYWJsZVwiIFtpbmZvTWVzc2FnZV09XCJpbmZvTWVzc2FnZVwiIFtjb3B5Q29udGVudF09XCJjb3B5Q29udGVudFwiIFtsb2FkQWN0aW9uXT1cImxvYWRBY3Rpb25cIiBbbG9hZElERmllbGRdPVwibG9hZElERmllbGRcIiBbZmllbGRdPVwiZmllbGRcIiBbZGF0YV09XCJkYXRhXCJcbiAgICAgICAgICAgICAgICAgICAodmFsdWVDaGFuZ2UpPVwidmFsdWVDaGFuZ2UuZW1pdCgkZXZlbnQpXCI+XG48L3NwYS1zZWxlY3QtY29tbW9uPlxuIl19
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LWxpdGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGluLXNwYS9zcmMvbGliL2NvbXBvbmVudHMvc2VsZWN0LWxpdGUvc2VsZWN0LWxpdGUuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGluLXNwYS9zcmMvbGliL2NvbXBvbmVudHMvc2VsZWN0LWxpdGUvc2VsZWN0LWxpdGUuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUNsRCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSwwQ0FBMEMsQ0FBQzs7O0FBT2pGLE1BQU0sT0FBTyxtQkFBb0IsU0FBUSxxQkFBcUI7SUFFbkQsUUFBUTtRQUVmLElBQUksSUFBSSxDQUFDLE9BQU8sSUFBSSxJQUFJLElBQUksSUFBSSxDQUFDLE9BQU8sSUFBSSxTQUFTLElBQUksSUFBSSxDQUFDLE9BQU8sQ0FBQyxNQUFNLElBQUksQ0FBQyxFQUFFO1lBQ2pGLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1NBQy9CO0lBRUgsQ0FBQzs7Z0hBUlUsbUJBQW1CO29HQUFuQixtQkFBbUIsOEVDUmhDLDB5QkFPQTsyRkRDYSxtQkFBbUI7a0JBTC9CLFNBQVM7K0JBQ0UsaUJBQWlCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFNlbGVjdENvbW1vbkNvbXBvbmVudCB9IGZyb20gJy4uL3NlbGVjdC1jb21tb24vc2VsZWN0LWNvbW1vbi5jb21wb25lbnQnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdzcGEtc2VsZWN0LWxpdGUnLFxuICB0ZW1wbGF0ZVVybDogJy4vc2VsZWN0LWxpdGUuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9zZWxlY3QtbGl0ZS5jb21wb25lbnQuY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgU2VsZWN0TGl0ZUNvbXBvbmVudCBleHRlbmRzIFNlbGVjdENvbW1vbkNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG5cbiAgb3ZlcnJpZGUgbmdPbkluaXQoKTogdm9pZCB7XG5cbiAgICBpZiAodGhpcy5vcHRpb25zID09IG51bGwgfHwgdGhpcy5vcHRpb25zID09IHVuZGVmaW5lZCB8fCB0aGlzLm9wdGlvbnMubGVuZ3RoID09IDApIHtcbiAgICAgIHRoaXMuZ2V0RGF0YSh0aGlzLmxvYWRBY3Rpb24pO1xuICAgIH1cblxuICB9XG5cbn1cbiIsIjxzcGEtc2VsZWN0LWNvbW1vbiBbd2lkdGhdPVwid2lkdGhcIiBbcmVhZG9ubHldPVwicmVhZG9ubHlcIiBbcmVxdWlyZWRdPVwicmVxdWlyZWRcIiBbZGVmYXVsdEZpcnN0VmFsdWVdPVwiZGVmYXVsdEZpcnN0VmFsdWVcIlxuICAgICAgICAgICAgICAgICAgIFtyZWFkb25seU1vZGVdPVwicmVhZG9ubHlNb2RlXCIgW2hpbnRdPVwiaGludFwiIFtwbGFjZWhvbGRlcl09XCJwbGFjZWhvbGRlclwiIFttdWx0aXBsZV09XCJtdWx0aXBsZVwiXG4gICAgICAgICAgICAgICAgICAgW2Rpc3BsYXldPVwiZGlzcGxheVwiIFsodmFsdWUpXT1cInZhbHVlXCIgW29wdGlvbnNdPVwib3B0aW9uc1wiIFttYXN0ZXJPcHRpb25zXT1cIm1hc3Rlck9wdGlvbnNcIiBbbWFzdGVyRmllbGRdPVwibWFzdGVyRmllbGRcIlxuICAgICAgICAgICAgICAgICAgIFtvcHRpb25WYWx1ZV09XCJvcHRpb25WYWx1ZVwiIFtvcHRpb25EaXNwbGF5XT1cIm9wdGlvbkRpc3BsYXlcIiBbb3B0aW9uRGlzcGxheUV4dHJhXT1cIm9wdGlvbkRpc3BsYXlFeHRyYVwiXG4gICAgICAgICAgICAgICAgICAgW251bGxhYmxlXT1cIm51bGxhYmxlXCIgW2luZm9NZXNzYWdlXT1cImluZm9NZXNzYWdlXCIgW2NvcHlDb250ZW50XT1cImNvcHlDb250ZW50XCIgW2xvYWRBY3Rpb25dPVwibG9hZEFjdGlvblwiIFtsb2FkSURGaWVsZF09XCJsb2FkSURGaWVsZFwiIFtmaWVsZF09XCJmaWVsZFwiIFtkYXRhXT1cImRhdGFcIlxuICAgICAgICAgICAgICAgICAgICh2YWx1ZUNoYW5nZSk9XCJ2YWx1ZUNoYW5nZS5lbWl0KCRldmVudClcIj5cbjwvc3BhLXNlbGVjdC1jb21tb24+XG4iXX0=