tin-spa 2.1.55 → 2.1.56

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.
@@ -60,15 +60,15 @@ export class FormComponent {
60
60
  let master = this.fields.find(x => x.name == child.masterField);
61
61
  this.updateChildOptions(master);
62
62
  });
63
- //set value for child
64
- this.fields.filter(x => x.childField).forEach(master => {
65
- // console.log(master)
66
- // console.log(this.data)
67
- //get child
68
- let child = this.fields.find(x => x.name == master.childField);
69
- this.data[child.name] = master.options.find(x => x[master.optionValue] == this.data[master.optionValue])[master.childValueField];
70
- console.log(this.data);
71
- });
63
+ // //set value for child
64
+ // this.fields.filter(x => x.childField).forEach(master => {
65
+ // // console.log(master)
66
+ // // console.log(this.data)
67
+ // //get child
68
+ // let child = this.fields.find(x => x.name == master.childField)
69
+ // this.data[child.name] = master.options.find(x => x[master.optionValue] == this.data[master.optionValue])[master.childValueField]
70
+ // console.log(this.data)
71
+ // });
72
72
  }
73
73
  ngOnChanges() {
74
74
  console.log("changed");
@@ -115,6 +115,10 @@ export class FormComponent {
115
115
  // console.log(field)
116
116
  this.inputChange.emit({ field: field, value: value });
117
117
  this.updateChildOptions(field);
118
+ if (this.config.mode == 'create' && field.childField) {
119
+ let child = this.fields.find(x => x.name == field.childField);
120
+ this.data[child.name] = field.options.find(x => x[field.optionValue] == value)[field.childValueField];
121
+ }
118
122
  }
119
123
  updateChildOptions(masterField) {
120
124
  console.log(this.data[masterField.name]);
@@ -208,4 +212,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
208
212
  }], inputChange: [{
209
213
  type: Output
210
214
  }] } });
211
- //# 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, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { FormConfig, Field, Button } from '../../classes/Classes';\nimport { Core } from '../../classes/TinCore';\nimport { MessageService } from '../../services/message.service';\nimport { DataServiceLib } from '../../services/data.service';\n\n@Component({\n  selector: 'spa-form',\n  templateUrl: './form.component.html',\n  styleUrls: ['./form.component.css']\n})\nexport class FormComponent implements OnInit {\n\n  constructor(private messageService: MessageService, private dataService: DataServiceLib) { }\n\n  ngOnInit() {\n\n    console.log(\"Form init\")\n    console.log(this.data)\n\n    if (!this.config.fields){\n      this.messageService.toast(\"Please Configure Form Fields\")\n      return;\n    }\n\n    if (!this.data) {\n      this.messageService.toast(\"Please Configure Form Data\")\n      return;\n    }\n\n    this.fields = this.config.fields;\n\n\n    if (this.config.multiColumn){\n      this.multiColumn = this.config.multiColumn\n    }else{\n      this.multiColumn = this.fields.length > 2\n    }\n\n    if (this.config?.button?.display){\n      this.buttonDisplay = this.config.button.display;\n    }\n\n    this.fileField = this.fields.find(x => x.type == 'file')\n\n    if (this.config?.button?.action && this.fileField) {\n      this.config.button.action.isFormData = true;\n\n    }\n\n    // this.fileViewField = this.fields.find(x => x.type == 'file-view')\n\n    // if (this.fileViewField && !this.fileViewField.hidden && this.config.mode != \"create\"){\n    //   this.loadFiles();\n    // }\n\n\n    // this.getVisibleFields();\n\n    this.childFields = this.fields.filter(x => x.masterField)\n\n\n\n    this.childFields.forEach(child => {\n      let master = this.fields.find(x => x.name == child.masterField)\n      this.updateChildOptions(master);\n\n    });\n\n\n    //set value for child\n    this.fields.filter(x => x.childField).forEach(master => {\n\n      // console.log(master)\n      // console.log(this.data)\n      //get child\n      let child = this.fields.find(x => x.name == master.childField)\n      this.data[child.name] = master.options.find(x => x[master.optionValue] == this.data[master.optionValue])[master.childValueField]\n      console.log(this.data)\n    });\n\n  }\n\n  ngOnChanges() {\n    console.log(\"changed\")\n  }\n\n  ngAfterViewInit() {\n    // console.log(\"Form After View init\")\n  }\n\n  getVisibleFields(){\n    let visibleFields = this.fields?.filter(x => this.testVisible(x)\n      // && ( x.hiddenCondition && !x.hiddenCondition(this.data) )\n    )\n\n    return visibleFields\n  }\n\n  testVisible(f : Field): boolean {\n\n    if (f.hidden) return false;\n\n    if (this.config.mode == 'create' && f.hideOnCreate){\n      return false;\n    }\n\n\n    if (this.config.mode != 'create' && f.hideOnExists) {\n      return false;\n    }\n\n    if (f.hiddenCondition) {\n      return !f.hiddenCondition(this.data);\n    }\n\n    return true;\n  }\n\n  testReadOnly(f: Field): boolean {\n\n\n    if (this.config.mode == 'create') {\n      return false;\n    }\n\n    if (f.readonly) return true;\n\n    if (this.config.mode == 'view') {\n      return true;\n    }\n\n\n    if (f.readonlyCondition) {\n      return f.readonlyCondition(this.data);\n    }\n\n    return false;\n  }\n\n\n  fileNames\n  fileField: Field;\n  fileViewField: Field;\n  @Input() files: any[] = [];\n  fields: Field[];\n  buttonDisplay = \"Submit\";\n  isProcessing : boolean = false;\n  multiColumn : boolean = false;\n\n  childFields : Field[];\n\n  @Input() data: any;\n  @Input() config: FormConfig;\n  @Output() buttonClick = new EventEmitter();\n  @Output() inputChange = new EventEmitter();\n\n  inputChanged(field : Field, value){\n\n    console.log(\"Input Changed\")\n    // console.log(field)\n\n    this.inputChange.emit({ field: field, value: value})\n\n    this.updateChildOptions(field)\n\n  }\n\n  updateChildOptions(masterField: Field){\n\n    console.log(this.data[masterField.name])\n\n    let child = this.childFields.find(x => x.masterField == masterField.name)\n    if (child != null) {\n\n      //current is master\n\n      //filter child options based on master value\n      child.options = child.masterOptions.filter(x => x[masterField.optionValue] == this.data[masterField.name])\n\n    }\n  }\n\n  buttonClicked(){\n\n    // console.log(\"Button Clicked\")\n    this.buttonClick.emit(this.data);\n    // console.log(this.data)\n\n\n\n    let button = this.config.button;\n\n    if (!button) {\n      return;\n    }\n\n    //validation\n    let resp = Core.validateObject(this.fields,this.data);\n    if (resp != ''){\n      this.messageService.toast(resp)\n      return;\n    }\n\n\n\n    if (this.files.length < 1 && this.fileField?.required && this.config.mode =='create') {\n      this.messageService.toast(\"Please attach file(s)\");\n      return;\n    }\n\n\n    if (button.confirm){\n\n      this.messageService.confirm(`${button.confirm.message}`).subscribe((result) => {\n        if (result == \"yes\") {\n          this.processCall(button)\n        }\n      });\n\n    }else{\n      this.processCall(button)\n    }\n\n\n\n\n  }\n\n  processCall(button: Button){\n\n    if (!button.action) return\n\n    let dataOut;\n\n    if (button.action.isFormData){\n\n      let formData: FormData = new FormData();\n      for (let i = 0; i < this.files.length; i++) {\n        formData.append(`uploadFile${i}`, this.files[i], this.files[i].name);\n      }\n\n      formData.append(\"data\", JSON.stringify(this.data));\n\n\n      dataOut = formData\n    }else{\n\n      dataOut = this.data\n    }\n\n\n\n\n\n\n    this.isProcessing = true\n    this.dataService.CallApi(button.action, dataOut).subscribe((apiResponse) => {\n      this.isProcessing = false\n\n      if (apiResponse.success) {\n\n        if (button.action.successMessage) {\n          this.messageService.toast(button.action.successMessage);\n        } else {\n          this.messageService.toast(\"Submitted\");\n        }\n\n        if (this.config.reset) {\n          Core.resetObject(this.fields, this.data)\n          this.files = [];\n        }\n\n\n      } else {\n        this.messageService.toast(\"Error: \" + apiResponse.message);\n      }\n    });\n  }\n\n  processForm(){\n\n\n\n\n\n  }\n\n}\n\n\n","\r\n<div [ngClass]=\"multiColumn ? 'tin-grid' : 'tin-col'\">\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.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=\"Drag and Drop files here\" [(files)]=\"files\"></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]=\"config.fileAction\" [path]=\"field.path\" [folderName]=\"data[field.keyFiledName]\" ></spa-viewer>\r\n          </div>\r\n        </ng-container>\r\n\r\n\r\n        <label *ngSwitchCase=\"'blank'\"></label>\r\n\r\n        <spa-number *ngSwitchCase=\"'number'\" [display]=\"field.alias ?? field.name | camelToWords\" [(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\"></spa-number>\r\n\r\n        <spa-money *ngSwitchCase=\"'money'\" [display]=\"field.alias ?? field.name | camelToWords\" [(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\"></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)\" ></spa-check>\r\n\r\n        <spa-date *ngSwitchCase=\"'date'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [min]=\"field?.min\" [max]=\"field?.max\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\"></spa-date>\r\n\r\n        <spa-select *ngSwitchCase=\"'select'\" [display]=\"field.alias ?? field.name | camelToWords\" [nullable]=\"field.nullable\" [options]=\"field.options\" [masterOptions]=\"field.masterOptions\" [optionDisplay]=\"field.optionDisplay ?? 'name'\" [optionValue]=\"field.optionValue ?? 'value'\" [(value)]=\"data[field.name]\" [defaultFirstValue]=\"field.defaultFirstValue\" (valueChange)=\"inputChanged(field, data[field.name])\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\">\r\n        </spa-select>\r\n\r\n        <spa-select *ngSwitchCase=\"'multi-select'\" [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])\" [readonly]=\"testReadOnly(field)\" [multiple]=\"true\" [hint]=\"field.hint\">\r\n        </spa-select>\r\n\r\n        <spa-text *ngSwitchDefault [display]=\"field.alias ?? field.name | camelToWords\" [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\"></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"]}
215
+ //# 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, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { FormConfig, Field, Button } from '../../classes/Classes';\nimport { Core } from '../../classes/TinCore';\nimport { MessageService } from '../../services/message.service';\nimport { DataServiceLib } from '../../services/data.service';\n\n@Component({\n  selector: 'spa-form',\n  templateUrl: './form.component.html',\n  styleUrls: ['./form.component.css']\n})\nexport class FormComponent implements OnInit {\n\n  constructor(private messageService: MessageService, private dataService: DataServiceLib) { }\n\n  ngOnInit() {\n\n    console.log(\"Form init\")\n    console.log(this.data)\n\n    if (!this.config.fields){\n      this.messageService.toast(\"Please Configure Form Fields\")\n      return;\n    }\n\n    if (!this.data) {\n      this.messageService.toast(\"Please Configure Form Data\")\n      return;\n    }\n\n    this.fields = this.config.fields;\n\n\n    if (this.config.multiColumn){\n      this.multiColumn = this.config.multiColumn\n    }else{\n      this.multiColumn = this.fields.length > 2\n    }\n\n    if (this.config?.button?.display){\n      this.buttonDisplay = this.config.button.display;\n    }\n\n    this.fileField = this.fields.find(x => x.type == 'file')\n\n    if (this.config?.button?.action && this.fileField) {\n      this.config.button.action.isFormData = true;\n\n    }\n\n    // this.fileViewField = this.fields.find(x => x.type == 'file-view')\n\n    // if (this.fileViewField && !this.fileViewField.hidden && this.config.mode != \"create\"){\n    //   this.loadFiles();\n    // }\n\n\n    // this.getVisibleFields();\n\n    this.childFields = this.fields.filter(x => x.masterField)\n\n\n\n    this.childFields.forEach(child => {\n      let master = this.fields.find(x => x.name == child.masterField)\n      this.updateChildOptions(master);\n\n    });\n\n\n    // //set value for child\n    // this.fields.filter(x => x.childField).forEach(master => {\n\n    //   // console.log(master)\n    //   // console.log(this.data)\n    //   //get child\n    //   let child = this.fields.find(x => x.name == master.childField)\n    //   this.data[child.name] = master.options.find(x => x[master.optionValue] == this.data[master.optionValue])[master.childValueField]\n    //   console.log(this.data)\n    // });\n\n  }\n\n  ngOnChanges() {\n    console.log(\"changed\")\n  }\n\n  ngAfterViewInit() {\n    // console.log(\"Form After View init\")\n  }\n\n  getVisibleFields(){\n    let visibleFields = this.fields?.filter(x => this.testVisible(x)\n      // && ( x.hiddenCondition && !x.hiddenCondition(this.data) )\n    )\n\n    return visibleFields\n  }\n\n  testVisible(f : Field): boolean {\n\n    if (f.hidden) return false;\n\n    if (this.config.mode == 'create' && f.hideOnCreate){\n      return false;\n    }\n\n\n    if (this.config.mode != 'create' && f.hideOnExists) {\n      return false;\n    }\n\n    if (f.hiddenCondition) {\n      return !f.hiddenCondition(this.data);\n    }\n\n    return true;\n  }\n\n  testReadOnly(f: Field): boolean {\n\n\n    if (this.config.mode == 'create') {\n      return false;\n    }\n\n    if (f.readonly) return true;\n\n    if (this.config.mode == 'view') {\n      return true;\n    }\n\n\n    if (f.readonlyCondition) {\n      return f.readonlyCondition(this.data);\n    }\n\n    return false;\n  }\n\n\n  fileNames\n  fileField: Field;\n  fileViewField: Field;\n  @Input() files: any[] = [];\n  fields: Field[];\n  buttonDisplay = \"Submit\";\n  isProcessing : boolean = false;\n  multiColumn : boolean = false;\n\n  childFields : Field[];\n\n  @Input() data: any;\n  @Input() config: FormConfig;\n  @Output() buttonClick = new EventEmitter();\n  @Output() inputChange = new EventEmitter();\n\n  inputChanged(field : Field, value){\n\n    console.log(\"Input Changed\")\n    // console.log(field)\n\n    this.inputChange.emit({ field: field, value: value})\n\n    this.updateChildOptions(field)\n\n    if (this.config.mode == 'create' && field.childField){\n\n      let child = this.fields.find(x => x.name == field.childField)\n      this.data[child.name] = field.options.find(x => x[field.optionValue] == value)[field.childValueField]\n\n    }\n\n  }\n\n  updateChildOptions(masterField: Field){\n\n    console.log(this.data[masterField.name])\n\n    let child = this.childFields.find(x => x.masterField == masterField.name)\n    if (child != null) {\n\n      //current is master\n\n      //filter child options based on master value\n      child.options = child.masterOptions.filter(x => x[masterField.optionValue] == this.data[masterField.name])\n\n    }\n  }\n\n  buttonClicked(){\n\n    // console.log(\"Button Clicked\")\n    this.buttonClick.emit(this.data);\n    // console.log(this.data)\n\n\n\n    let button = this.config.button;\n\n    if (!button) {\n      return;\n    }\n\n    //validation\n    let resp = Core.validateObject(this.fields,this.data);\n    if (resp != ''){\n      this.messageService.toast(resp)\n      return;\n    }\n\n\n\n    if (this.files.length < 1 && this.fileField?.required && this.config.mode =='create') {\n      this.messageService.toast(\"Please attach file(s)\");\n      return;\n    }\n\n\n    if (button.confirm){\n\n      this.messageService.confirm(`${button.confirm.message}`).subscribe((result) => {\n        if (result == \"yes\") {\n          this.processCall(button)\n        }\n      });\n\n    }else{\n      this.processCall(button)\n    }\n\n\n\n\n  }\n\n  processCall(button: Button){\n\n    if (!button.action) return\n\n    let dataOut;\n\n    if (button.action.isFormData){\n\n      let formData: FormData = new FormData();\n      for (let i = 0; i < this.files.length; i++) {\n        formData.append(`uploadFile${i}`, this.files[i], this.files[i].name);\n      }\n\n      formData.append(\"data\", JSON.stringify(this.data));\n\n\n      dataOut = formData\n    }else{\n\n      dataOut = this.data\n    }\n\n\n\n\n\n\n    this.isProcessing = true\n    this.dataService.CallApi(button.action, dataOut).subscribe((apiResponse) => {\n      this.isProcessing = false\n\n      if (apiResponse.success) {\n\n        if (button.action.successMessage) {\n          this.messageService.toast(button.action.successMessage);\n        } else {\n          this.messageService.toast(\"Submitted\");\n        }\n\n        if (this.config.reset) {\n          Core.resetObject(this.fields, this.data)\n          this.files = [];\n        }\n\n\n      } else {\n        this.messageService.toast(\"Error: \" + apiResponse.message);\n      }\n    });\n  }\n\n  processForm(){\n\n\n\n\n\n  }\n\n}\n\n\n","\r\n<div [ngClass]=\"multiColumn ? 'tin-grid' : 'tin-col'\">\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.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=\"Drag and Drop files here\" [(files)]=\"files\"></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]=\"config.fileAction\" [path]=\"field.path\" [folderName]=\"data[field.keyFiledName]\" ></spa-viewer>\r\n          </div>\r\n        </ng-container>\r\n\r\n\r\n        <label *ngSwitchCase=\"'blank'\"></label>\r\n\r\n        <spa-number *ngSwitchCase=\"'number'\" [display]=\"field.alias ?? field.name | camelToWords\" [(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\"></spa-number>\r\n\r\n        <spa-money *ngSwitchCase=\"'money'\" [display]=\"field.alias ?? field.name | camelToWords\" [(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\"></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)\" ></spa-check>\r\n\r\n        <spa-date *ngSwitchCase=\"'date'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [min]=\"field?.min\" [max]=\"field?.max\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\"></spa-date>\r\n\r\n        <spa-select *ngSwitchCase=\"'select'\" [display]=\"field.alias ?? field.name | camelToWords\" [nullable]=\"field.nullable\" [options]=\"field.options\" [masterOptions]=\"field.masterOptions\" [optionDisplay]=\"field.optionDisplay ?? 'name'\" [optionValue]=\"field.optionValue ?? 'value'\" [(value)]=\"data[field.name]\" [defaultFirstValue]=\"field.defaultFirstValue\" (valueChange)=\"inputChanged(field, data[field.name])\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\">\r\n        </spa-select>\r\n\r\n        <spa-select *ngSwitchCase=\"'multi-select'\" [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])\" [readonly]=\"testReadOnly(field)\" [multiple]=\"true\" [hint]=\"field.hint\">\r\n        </spa-select>\r\n\r\n        <spa-text *ngSwitchDefault [display]=\"field.alias ?? field.name | camelToWords\" [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\"></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"]}
@@ -3106,15 +3106,15 @@ class FormComponent {
3106
3106
  let master = this.fields.find(x => x.name == child.masterField);
3107
3107
  this.updateChildOptions(master);
3108
3108
  });
3109
- //set value for child
3110
- this.fields.filter(x => x.childField).forEach(master => {
3111
- // console.log(master)
3112
- // console.log(this.data)
3113
- //get child
3114
- let child = this.fields.find(x => x.name == master.childField);
3115
- this.data[child.name] = master.options.find(x => x[master.optionValue] == this.data[master.optionValue])[master.childValueField];
3116
- console.log(this.data);
3117
- });
3109
+ // //set value for child
3110
+ // this.fields.filter(x => x.childField).forEach(master => {
3111
+ // // console.log(master)
3112
+ // // console.log(this.data)
3113
+ // //get child
3114
+ // let child = this.fields.find(x => x.name == master.childField)
3115
+ // this.data[child.name] = master.options.find(x => x[master.optionValue] == this.data[master.optionValue])[master.childValueField]
3116
+ // console.log(this.data)
3117
+ // });
3118
3118
  }
3119
3119
  ngOnChanges() {
3120
3120
  console.log("changed");
@@ -3162,6 +3162,10 @@ class FormComponent {
3162
3162
  // console.log(field)
3163
3163
  this.inputChange.emit({ field: field, value: value });
3164
3164
  this.updateChildOptions(field);
3165
+ if (this.config.mode == 'create' && field.childField) {
3166
+ let child = this.fields.find(x => x.name == field.childField);
3167
+ this.data[child.name] = field.options.find(x => x[field.optionValue] == value)[field.childValueField];
3168
+ }
3165
3169
  }
3166
3170
  updateChildOptions(masterField) {
3167
3171
  console.log(this.data[masterField.name]);