tin-spa 2.1.39 → 2.1.41

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.
Files changed (32) hide show
  1. package/esm2020/lib/classes/Classes.mjs +1 -1
  2. package/esm2020/lib/components/accounts/accounts.component.mjs +1 -1
  3. package/esm2020/lib/components/customers/customers.component.mjs +1 -1
  4. package/esm2020/lib/components/departments/departments.component.mjs +1 -1
  5. package/esm2020/lib/components/employees/employees.component.mjs +1 -1
  6. package/esm2020/lib/components/filter/filter.component.mjs +7 -4
  7. package/esm2020/lib/components/inventory/inventory.component.mjs +1 -1
  8. package/esm2020/lib/components/invitations-table/invitations-table.component.mjs +1 -1
  9. package/esm2020/lib/components/list-dialog/list-dialog.component.mjs +1 -1
  10. package/esm2020/lib/components/logs/logs.component.mjs +1 -1
  11. package/esm2020/lib/components/membership/membership.component.mjs +1 -1
  12. package/esm2020/lib/components/plans/plans.component.mjs +1 -1
  13. package/esm2020/lib/components/suppliers/suppliers.component.mjs +1 -1
  14. package/esm2020/lib/components/table/detailsDialog.component.mjs +19 -14
  15. package/esm2020/lib/components/table/table.component.mjs +52 -3
  16. package/esm2020/lib/components/table-internal/detailsDialog-internal.component.mjs +18 -11
  17. package/esm2020/lib/components/table-internal/table-internal.component.mjs +37 -3
  18. package/esm2020/lib/components/tasks/tasks.component.mjs +1 -1
  19. package/esm2020/lib/components/tenant-settings/tenant-settings.component.mjs +1 -1
  20. package/esm2020/lib/components/tenants/tenants.component.mjs +1 -1
  21. package/esm2020/lib/components/transactions/transactions.component.mjs +1 -1
  22. package/esm2020/lib/components/users/users.component.mjs +1 -1
  23. package/fesm2015/tin-spa.mjs +142 -42
  24. package/fesm2015/tin-spa.mjs.map +1 -1
  25. package/fesm2020/tin-spa.mjs +140 -42
  26. package/fesm2020/tin-spa.mjs.map +1 -1
  27. package/lib/classes/Classes.d.ts +9 -2
  28. package/lib/components/filter/filter.component.d.ts +2 -1
  29. package/lib/components/table/detailsDialog.component.d.ts +1 -0
  30. package/lib/components/table/table.component.d.ts +2 -1
  31. package/lib/components/table-internal/table-internal.component.d.ts +2 -1
  32. package/package.json +1 -1
@@ -42,21 +42,28 @@ export class DetailsDialogInternal {
42
42
  this.formConfig.mode = this.formConfig.mode ?? "view";
43
43
  if (this.formConfig.mode == "create") {
44
44
  this.details = Core.generateObject(this.formConfig.fields);
45
+ if (this.data.heroValue) {
46
+ this.details[this.data.heroField] = this.data.heroValue;
47
+ }
45
48
  }
46
49
  else {
47
50
  console.log(this.data);
48
- if (this.data.details) {
51
+ if (this.data.details && !this.data.heroField && !this.data.heroValue) {
52
+ console.log("data from details");
49
53
  this.details = this.data.details;
50
54
  }
55
+ else if (this.formConfig.loadAction && this.data.heroField && this.data.details) {
56
+ console.log("data from url + ID Field " + this.data.heroField);
57
+ let action = { url: this.formConfig.loadAction.url + "/" + this.data.details[this.data.heroField] };
58
+ this.loadData(action);
59
+ }
60
+ else if (this.formConfig.loadAction && this.data.heroValue) {
61
+ console.log("data from url + Solid ID");
62
+ let action = { url: this.formConfig.loadAction.url + "/" + this.data.heroValue };
63
+ this.loadData(action);
64
+ }
51
65
  else {
52
- if (this.formConfig.loadAction && this.data.detailIDField && this.data.details) {
53
- let action = { url: this.formConfig.loadAction.url + "/" + this.data.details[this.data.detailIDField] };
54
- this.loadData(action);
55
- }
56
- else if (this.formConfig.loadAction && this.data.detailID) {
57
- let action = { url: this.formConfig.loadAction.url + "/" + this.data.detailID };
58
- this.loadData(action);
59
- }
66
+ console.log("data source failed to pick");
60
67
  }
61
68
  }
62
69
  this.fileField = this.formConfig.fields.find(x => x.type == 'file');
@@ -71,7 +78,7 @@ export class DetailsDialogInternal {
71
78
  }
72
79
  }
73
80
  loadData(action) {
74
- console.log("loading");
81
+ console.log("loading details");
75
82
  if (action) {
76
83
  this.dataService.CallApi(action).subscribe((apiResponse) => {
77
84
  if (apiResponse.success) {
@@ -241,4 +248,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
241
248
  type: Output
242
249
  }] } });
243
250
  ;
244
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"detailsDialog-internal.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/table-internal/detailsDialog-internal.component.ts","../../../../../../projects/tin-spa/src/lib/components/table-internal/detailsDialog-internal.component.html"],"names":[],"mappings":"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","sourcesContent":["\r\nimport { Component, OnInit, Inject, Output, EventEmitter } from '@angular/core';\r\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\r\nimport { FormConfig, Field, TableConfig, Button, DetailsDialogConfig, Action } from '../../classes/Classes';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { DataServiceLib } from '../../services/data.service';\r\nimport { ApiResponse, Core } from '../../classes/TinCore';\r\nimport { LoaderService } from '../../services/loader.service';\r\nimport { BreakpointObserver, BreakpointState } from '@angular/cdk/layout';\r\n@Component({\r\n  selector: 'app-viewModel',\r\n  templateUrl: './detailsDialog-internal.component.html',\r\n  styleUrls: ['./table-internal.component.css']\r\n})\r\nexport class DetailsDialogInternal implements OnInit {\r\n\r\n  constructor(private breakpointObserver: BreakpointObserver,private loaderService: LoaderService,private dataService: DataServiceLib,private messageService: MessageService,\r\n    private dialogRef: MatDialogRef<DetailsDialogInternal>, @Inject(MAT_DIALOG_DATA) public data: DetailsDialogConfig)\r\n  {\r\n    // detect screen size changes\r\n    this.breakpointObserver.observe([\"(max-width: 600px)\"]).subscribe((result: BreakpointState) => {\r\n\r\n      if (result.matches) {\r\n        this.smallScreen = true\r\n      } else {\r\n        this.smallScreen = false\r\n      }\r\n\r\n    });\r\n  }\r\n\r\n  ngOnInit() {\r\n\r\n    this.tableConfig = this.data.tableConfig\r\n    this.formConfig = this.data.config;\r\n    this.buttons = this.data.buttons;\r\n\r\n    this.formConfig.mode = this.formConfig.mode ?? \"view\"\r\n\r\n    if (this.formConfig.mode == \"create\"){\r\n      this.details = Core.generateObject(this.formConfig.fields);\r\n    }else{\r\n\r\n\r\n      console.log(this.data)\r\n\r\n      if (this.data.details){\r\n        this.details = this.data.details\r\n      }else{\r\n\r\n        if (this.formConfig.loadAction && this.data.detailIDField && this.data.details){\r\n          let action: Action = { url: this.formConfig.loadAction.url + \"/\" + this.data.details[this.data.detailIDField]}\r\n          this.loadData(action)\r\n        }\r\n        else if (this.formConfig.loadAction && this.data.detailID) {\r\n          let action: Action = { url: this.formConfig.loadAction.url + \"/\" + this.data.detailID }\r\n          this.loadData(action)\r\n        }\r\n      }\r\n\r\n    }\r\n\r\n    this.fileField = this.formConfig.fields.find(x => x.type == 'file')\r\n\r\n    // this.modeButton = this.data.buttons.find(x => x.name == this.formConfig.mode)?? \"view\"\r\n\r\n    this.isLoadComplete = true;\r\n\r\n    this.loaderService.isLoading.subscribe(x => this.isProcessing = x);\r\n\r\n    if (this.buttons){\r\n      this.extraButtons = this.buttons.filter(x => x.name != \"create\" && x.name != \"edit\" && x.name != \"delete\" && x.name != \"view\" && x.inDialog)\r\n      this.createButton = this.buttons.find(x => x.name == \"create\")\r\n      this.editButton = this.buttons.find(x => x.name == \"edit\")\r\n      this.deleteButton = this.buttons.find(x => x.name == \"delete\")\r\n    }\r\n\r\n\r\n\r\n  }\r\n\r\n\r\n  extraButtons: Button[];\r\n  buttons : Button[];\r\n  createButton : Button;\r\n  editButton: Button;\r\n  deleteButton: Button;\r\n\r\n  // modeButton : Button\r\n  fileField: Field;\r\n  files: any[] = [];\r\n\r\n  tableConfig: TableConfig\r\n  details: any\r\n  formConfig : FormConfig;\r\n  smallScreen = false;\r\n\r\n  isLoadComplete: boolean = false;\r\n  isProcessing: boolean = false;\r\n\r\n  @Output() inputChange = new EventEmitter();\r\n\r\n\r\n  loadData(action: Action) {\r\n    console.log(\"loading\")\r\n\r\n    if (action) {\r\n\r\n      this.dataService.CallApi(action).subscribe((apiResponse: ApiResponse) => {\r\n\r\n        if (apiResponse.success) {\r\n          this.details = apiResponse.data\r\n        }\r\n        else{\r\n          this.messageService.toast(\"Error: \" + apiResponse.message);\r\n        }\r\n\r\n      });\r\n    }\r\n\r\n  }\r\n\r\n  inputChanged(event) {\r\n    this.inputChange.emit({ field: event.field, value: event.value })\r\n  }\r\n\r\n\r\n  setMode(newMode: string){\r\n    this.formConfig.mode = newMode\r\n  }\r\n\r\n  create() {\r\n\r\n    // console.log(this.details)\r\n\r\n    //validation\r\n    let resp = Core.validateObject(this.formConfig.fields, this.details);\r\n    if (resp != '') {\r\n      this.messageService.toast(resp)\r\n      return;\r\n    }\r\n\r\n\r\n    // File Validation---\r\n    if (this.files.length < 1 && this.fileField?.required) {\r\n      this.messageService.toast(\"Please attach file(s)\");\r\n      return;\r\n    }\r\n    // File Validation---\r\n\r\n    let tableCreateButton = this.data.buttons.find(x => x.name == \"create\")\r\n    if (!tableCreateButton || !tableCreateButton.action) {\r\n\r\n      this.dialogRef.close({ message: 'emit', data: this.details});\r\n      return;\r\n    }\r\n\r\n\r\n    //coversion--\r\n    let dataOut;\r\n\r\n    if (tableCreateButton.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.details));\r\n\r\n      // console.log(formData)\r\n\r\n      dataOut = formData\r\n    } else {\r\n\r\n      dataOut = this.details\r\n    }\r\n    //coversion--\r\n\r\n\r\n    this.dataService.CallApi(tableCreateButton.action, dataOut).subscribe((apiResponse) => {\r\n\r\n      if (apiResponse.success) {\r\n\r\n        if (tableCreateButton.action.successMessage) {\r\n          this.messageService.toast(tableCreateButton.action.successMessage);\r\n        } else {\r\n          this.messageService.toast(\"Created\");\r\n        }\r\n\r\n        this.dialogRef.close({ message: 'success', data: this.details });\r\n\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse);\r\n      }\r\n    },(error) => {\r\n    }\r\n    );\r\n\r\n  }\r\n\r\n  edit() {\r\n    console.log(\"Edit\")\r\n    // console.log(this.details)\r\n\r\n    //validation\r\n    let resp = Core.validateObject(this.formConfig.fields, this.details);\r\n    if (resp != '') {\r\n      this.messageService.toast(resp)\r\n      return;\r\n    }\r\n\r\n\r\n\r\n    let tableEditButton = this.data.buttons.find(x => x.name == \"edit\")\r\n    if (!tableEditButton || !tableEditButton.action) {\r\n      this.dialogRef.close({ message: 'emit', data: this.details });\r\n      return;\r\n    }\r\n\r\n\r\n    //coversion--\r\n    let dataOut;\r\n\r\n    if (tableEditButton.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.details));\r\n\r\n      // console.log(formData)\r\n\r\n      dataOut = formData\r\n    } else {\r\n\r\n      dataOut = this.details\r\n    }\r\n    //coversion--\r\n\r\n    this.dataService.CallApi(tableEditButton.action, dataOut).subscribe((apiResponse) => {\r\n      if (apiResponse.success) {\r\n\r\n        if (tableEditButton.action.successMessage) {\r\n          this.messageService.toast(tableEditButton.action.successMessage);\r\n        } else {\r\n          this.messageService.toast(\"Updated\");\r\n        }\r\n\r\n        this.dialogRef.close({ message: 'success', data: this.details });\r\n\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse);\r\n      }\r\n    },\r\n    (error) => {\r\n    });\r\n  }\r\n\r\n  delete() {\r\n\r\n\r\n    this.messageService.confirm(`DELETE ?`).subscribe((result) => {\r\n      if (result == \"yes\") {\r\n\r\n        // console.log(\"Delete\")\r\n\r\n        let b = this.data.buttons.find(x => x.name == \"delete\")\r\n        if (!b) {\r\n          this.dialogRef.close({ message: 'success', data: this.details });\r\n          return;\r\n        }\r\n\r\n        this.dataService.CallApi(b.action, this.details).subscribe((apiResponse) => {\r\n          if (apiResponse.success) {\r\n\r\n            if (b.action.successMessage) {\r\n              this.messageService.toast(b.action.successMessage);\r\n            } else {\r\n              this.messageService.toast(\"Deleted\");\r\n            }\r\n\r\n            this.dialogRef.close({ message: 'success', data: this.details });\r\n\r\n          } else {\r\n            this.messageService.toast(\"Error: \" + apiResponse);\r\n          }\r\n        },\r\n        (error) => {\r\n        });\r\n      }\r\n    });\r\n  }\r\n\r\n\r\n  custom(b: Button) {\r\n\r\n\r\n    this.dataService.CallApi(b.action, this.details).subscribe((apiResponse) => {\r\n      if (apiResponse.success) {\r\n\r\n        if (b.action.successMessage) {\r\n          this.messageService.toast(b.action.successMessage);\r\n        } else {\r\n          this.messageService.toast(\"Deleted\");\r\n        }\r\n\r\n        this.dialogRef.close({ message: 'success', data: this.details });\r\n\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse);\r\n      }\r\n    },\r\n      (error) => {\r\n      });\r\n  }\r\n\r\n\r\n};\r\n\r\n\r\n\r\n","\r\n<div class=\"row d-flex align-items-center mt-0\">\r\n\r\n  <div class=\"col\">\r\n    <h2 mat-dialog-title>{{formConfig.mode | titlecase}} {{formConfig?.title}}</h2>\r\n  </div>\r\n\r\n  <div *ngIf=\"formConfig.mode=='view' && editButton\" class=\"col d-flex justify-content-end\">\r\n    <button mat-icon-button color=\"primary\" (click)=\"setMode('edit')\"><mat-icon>edit</mat-icon></button>\r\n  </div>\r\n\r\n  <!-- <div *ngIf=\"formConfig.mode=='edit'\" class=\"col d-flex justify-content-end\">\r\n    <button mat-icon-button  (click)=\"setMode('view')\"><mat-icon>done</mat-icon></button>\r\n  </div> -->\r\n\r\n</div>\r\n<mat-dialog-content class=\"mat-typography\">\r\n\r\n<div class=\"tin-input\" style=\"font-size:14px\">\r\n\r\n<p *ngIf=\"formConfig && !details\"><em>Loading...</em></p>\r\n\r\n<spa-form *ngIf=\"formConfig && details\" [files]=\"files\" [data]=\"details\" [config]=\"formConfig\" (inputChange)=\"inputChanged($event)\"></spa-form>\r\n\r\n\r\n\r\n</div>\r\n\r\n</mat-dialog-content>\r\n\r\n<mat-dialog-actions>\r\n<div>\r\n<button mat-raised-button [disabled]=\"isProcessing\" color=\"primary\" *ngIf=\"formConfig.mode=='create' && createButton\" (click)=\"create()\" cdkFocusInitial>{{createButton.display ?? 'Submit'}}</button>\r\n<button mat-raised-button [disabled]=\"isProcessing\" color=\"primary\" *ngIf=\"formConfig.mode=='edit' && editButton\" (click)=\"edit()\" cdkFocusInitial>{{editButton.display ?? 'Submit'}}</button>\r\n\r\n<ng-container *ngIf=\"!smallScreen\">\r\n<button *ngFor=\"let btn of extraButtons\" mat-stroked-button [disabled]=\"isProcessing\" [ngStyle]=\"{'color': btn.icon.color}\" (click)=\"custom(btn)\" cdkFocusInitial><mat-icon [ngStyle]=\"{'color': btn.icon.color}\">{{btn.icon.name}}</mat-icon>{{btn.display ?? btn.name}}</button>\r\n</ng-container>\r\n\r\n\r\n<button mat-stroked-button color=\"primary\" mat-dialog-close>Cancel</button>\r\n</div>\r\n\r\n<div class=\"col d-flex justify-content-end\" *ngIf=\"smallScreen\">\r\n<button *ngFor=\"let btn of extraButtons\" mat-icon-button [disabled]=\"isProcessing\" [ngStyle]=\"{'color': btn.icon.color}\" (click)=\"custom(btn)\" cdkFocusInitial><mat-icon >{{btn.icon.name}}</mat-icon></button>\r\n<button mat-icon-button [disabled]=\"isProcessing\" style=\"color: red;\" (click)=\"delete()\" *ngIf=\"formConfig.mode!='create'  && deleteButton\"><mat-icon>delete</mat-icon></button>\r\n</div>\r\n\r\n\r\n</mat-dialog-actions>\r\n\r\n\r\n\r\n"]}
251
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"detailsDialog-internal.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/table-internal/detailsDialog-internal.component.ts","../../../../../../projects/tin-spa/src/lib/components/table-internal/detailsDialog-internal.component.html"],"names":[],"mappings":"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","sourcesContent":["\r\nimport { Component, OnInit, Inject, Output, EventEmitter } from '@angular/core';\r\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\r\nimport { FormConfig, Field, TableConfig, Button, DetailsDialogConfig, Action } from '../../classes/Classes';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { DataServiceLib } from '../../services/data.service';\r\nimport { ApiResponse, Core } from '../../classes/TinCore';\r\nimport { LoaderService } from '../../services/loader.service';\r\nimport { BreakpointObserver, BreakpointState } from '@angular/cdk/layout';\r\n@Component({\r\n  selector: 'app-viewModel',\r\n  templateUrl: './detailsDialog-internal.component.html',\r\n  styleUrls: ['./table-internal.component.css']\r\n})\r\nexport class DetailsDialogInternal implements OnInit {\r\n\r\n  constructor(private breakpointObserver: BreakpointObserver,private loaderService: LoaderService,private dataService: DataServiceLib,private messageService: MessageService,\r\n    private dialogRef: MatDialogRef<DetailsDialogInternal>, @Inject(MAT_DIALOG_DATA) public data: DetailsDialogConfig)\r\n  {\r\n    // detect screen size changes\r\n    this.breakpointObserver.observe([\"(max-width: 600px)\"]).subscribe((result: BreakpointState) => {\r\n\r\n      if (result.matches) {\r\n        this.smallScreen = true\r\n      } else {\r\n        this.smallScreen = false\r\n      }\r\n\r\n    });\r\n  }\r\n\r\n  ngOnInit() {\r\n\r\n    this.tableConfig = this.data.tableConfig\r\n    this.formConfig = this.data.config;\r\n    this.buttons = this.data.buttons;\r\n\r\n    this.formConfig.mode = this.formConfig.mode ?? \"view\"\r\n\r\n    if (this.formConfig.mode == \"create\") {\r\n      this.details = Core.generateObject(this.formConfig.fields);\r\n      if (this.data.heroValue) {\r\n        this.details[this.data.heroField] = this.data.heroValue\r\n      }\r\n    } else {\r\n\r\n\r\n      console.log(this.data)\r\n\r\n      if (this.data.details && !this.data.heroField && !this.data.heroValue) {\r\n        console.log(\"data from details\")\r\n        this.details = this.data.details\r\n      }\r\n      else if (this.formConfig.loadAction && this.data.heroField && this.data.details) {\r\n        console.log(\"data from url + ID Field \" + this.data.heroField)\r\n        let action: Action = { url: this.formConfig.loadAction.url + \"/\" + this.data.details[this.data.heroField] }\r\n        this.loadData(action)\r\n      }\r\n      else if (this.formConfig.loadAction && this.data.heroValue) {\r\n        console.log(\"data from url + Solid ID\")\r\n        let action: Action = { url: this.formConfig.loadAction.url + \"/\" + this.data.heroValue }\r\n        this.loadData(action)\r\n      }\r\n      else {\r\n        console.log(\"data source failed to pick\")\r\n      }\r\n\r\n    }\r\n\r\n    this.fileField = this.formConfig.fields.find(x => x.type == 'file')\r\n\r\n    // this.modeButton = this.data.buttons.find(x => x.name == this.formConfig.mode)?? \"view\"\r\n\r\n    this.isLoadComplete = true;\r\n\r\n    this.loaderService.isLoading.subscribe(x => this.isProcessing = x);\r\n\r\n    if (this.buttons) {\r\n      this.extraButtons = this.buttons.filter(x => x.name != \"create\" && x.name != \"edit\" && x.name != \"delete\" && x.name != \"view\" && x.inDialog)\r\n      this.createButton = this.buttons.find(x => x.name == \"create\")\r\n      this.editButton = this.buttons.find(x => x.name == \"edit\")\r\n      this.deleteButton = this.buttons.find(x => x.name == \"delete\")\r\n    }\r\n\r\n\r\n\r\n  }\r\n\r\n\r\n  extraButtons: Button[];\r\n  buttons: Button[];\r\n  createButton: Button;\r\n  editButton: Button;\r\n  deleteButton: Button;\r\n\r\n  // modeButton : Button\r\n  fileField: Field;\r\n  files: any[] = [];\r\n\r\n  tableConfig: TableConfig\r\n  details: any\r\n  formConfig: FormConfig;\r\n  smallScreen = false;\r\n\r\n  isLoadComplete: boolean = false;\r\n  isProcessing: boolean = false;\r\n\r\n  @Output() inputChange = new EventEmitter();\r\n\r\n\r\n  loadData(action: Action) {\r\n    console.log(\"loading details\")\r\n\r\n    if (action) {\r\n\r\n      this.dataService.CallApi(action).subscribe((apiResponse: ApiResponse) => {\r\n\r\n        if (apiResponse.success) {\r\n          this.details = apiResponse.data\r\n        }\r\n        else {\r\n          this.messageService.toast(\"Error: \" + apiResponse.message);\r\n        }\r\n\r\n      });\r\n    }\r\n\r\n  }\r\n\r\n  inputChanged(event) {\r\n    this.inputChange.emit({ field: event.field, value: event.value })\r\n  }\r\n\r\n\r\n  setMode(newMode: string) {\r\n    this.formConfig.mode = newMode\r\n  }\r\n\r\n  create() {\r\n\r\n    // console.log(this.details)\r\n\r\n    //validation\r\n    let resp = Core.validateObject(this.formConfig.fields, this.details);\r\n    if (resp != '') {\r\n      this.messageService.toast(resp)\r\n      return;\r\n    }\r\n\r\n\r\n    // File Validation---\r\n    if (this.files.length < 1 && this.fileField?.required) {\r\n      this.messageService.toast(\"Please attach file(s)\");\r\n      return;\r\n    }\r\n    // File Validation---\r\n\r\n    let tableCreateButton = this.data.buttons.find(x => x.name == \"create\")\r\n    if (!tableCreateButton || !tableCreateButton.action) {\r\n\r\n      this.dialogRef.close({ message: 'emit', data: this.details });\r\n      return;\r\n    }\r\n\r\n\r\n    //coversion--\r\n    let dataOut;\r\n\r\n    if (tableCreateButton.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.details));\r\n\r\n      // console.log(formData)\r\n\r\n      dataOut = formData\r\n    } else {\r\n\r\n      dataOut = this.details\r\n    }\r\n    //coversion--\r\n\r\n\r\n    this.dataService.CallApi(tableCreateButton.action, dataOut).subscribe((apiResponse) => {\r\n\r\n      if (apiResponse.success) {\r\n\r\n        if (tableCreateButton.action.successMessage) {\r\n          this.messageService.toast(tableCreateButton.action.successMessage);\r\n        } else {\r\n          this.messageService.toast(\"Created\");\r\n        }\r\n\r\n        this.dialogRef.close({ message: 'success', data: this.details });\r\n\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse);\r\n      }\r\n    }, (error) => {\r\n    }\r\n    );\r\n\r\n  }\r\n\r\n  edit() {\r\n    console.log(\"Edit\")\r\n    // console.log(this.details)\r\n\r\n    //validation\r\n    let resp = Core.validateObject(this.formConfig.fields, this.details);\r\n    if (resp != '') {\r\n      this.messageService.toast(resp)\r\n      return;\r\n    }\r\n\r\n\r\n\r\n    let tableEditButton = this.data.buttons.find(x => x.name == \"edit\")\r\n    if (!tableEditButton || !tableEditButton.action) {\r\n      this.dialogRef.close({ message: 'emit', data: this.details });\r\n      return;\r\n    }\r\n\r\n\r\n    //coversion--\r\n    let dataOut;\r\n\r\n    if (tableEditButton.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.details));\r\n\r\n      // console.log(formData)\r\n\r\n      dataOut = formData\r\n    } else {\r\n\r\n      dataOut = this.details\r\n    }\r\n    //coversion--\r\n\r\n    this.dataService.CallApi(tableEditButton.action, dataOut).subscribe((apiResponse) => {\r\n      if (apiResponse.success) {\r\n\r\n        if (tableEditButton.action.successMessage) {\r\n          this.messageService.toast(tableEditButton.action.successMessage);\r\n        } else {\r\n          this.messageService.toast(\"Updated\");\r\n        }\r\n\r\n        this.dialogRef.close({ message: 'success', data: this.details });\r\n\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse);\r\n      }\r\n    },\r\n      (error) => {\r\n      });\r\n  }\r\n\r\n  delete() {\r\n\r\n\r\n    this.messageService.confirm(`DELETE ?`).subscribe((result) => {\r\n      if (result == \"yes\") {\r\n\r\n        // console.log(\"Delete\")\r\n\r\n        let b = this.data.buttons.find(x => x.name == \"delete\")\r\n        if (!b) {\r\n          this.dialogRef.close({ message: 'success', data: this.details });\r\n          return;\r\n        }\r\n\r\n        this.dataService.CallApi(b.action, this.details).subscribe((apiResponse) => {\r\n          if (apiResponse.success) {\r\n\r\n            if (b.action.successMessage) {\r\n              this.messageService.toast(b.action.successMessage);\r\n            } else {\r\n              this.messageService.toast(\"Deleted\");\r\n            }\r\n\r\n            this.dialogRef.close({ message: 'success', data: this.details });\r\n\r\n          } else {\r\n            this.messageService.toast(\"Error: \" + apiResponse);\r\n          }\r\n        },\r\n          (error) => {\r\n          });\r\n      }\r\n    });\r\n  }\r\n\r\n\r\n  custom(b: Button) {\r\n\r\n\r\n    this.dataService.CallApi(b.action, this.details).subscribe((apiResponse) => {\r\n      if (apiResponse.success) {\r\n\r\n        if (b.action.successMessage) {\r\n          this.messageService.toast(b.action.successMessage);\r\n        } else {\r\n          this.messageService.toast(\"Deleted\");\r\n        }\r\n\r\n        this.dialogRef.close({ message: 'success', data: this.details });\r\n\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse);\r\n      }\r\n    },\r\n      (error) => {\r\n      });\r\n  }\r\n\r\n\r\n};\r\n\r\n\r\n\r\n","\r\n<div class=\"row d-flex align-items-center mt-0\">\r\n\r\n  <div class=\"col\">\r\n    <h2 mat-dialog-title>{{formConfig.mode | titlecase}} {{formConfig?.title}}</h2>\r\n  </div>\r\n\r\n  <div *ngIf=\"formConfig.mode=='view' && editButton\" class=\"col d-flex justify-content-end\">\r\n    <button mat-icon-button color=\"primary\" (click)=\"setMode('edit')\"><mat-icon>edit</mat-icon></button>\r\n  </div>\r\n\r\n  <!-- <div *ngIf=\"formConfig.mode=='edit'\" class=\"col d-flex justify-content-end\">\r\n    <button mat-icon-button  (click)=\"setMode('view')\"><mat-icon>done</mat-icon></button>\r\n  </div> -->\r\n\r\n</div>\r\n<mat-dialog-content class=\"mat-typography\">\r\n\r\n<div class=\"tin-input\" style=\"font-size:14px\">\r\n\r\n<p *ngIf=\"formConfig && !details\"><em>Loading...</em></p>\r\n\r\n<spa-form *ngIf=\"formConfig && details\" [files]=\"files\" [data]=\"details\" [config]=\"formConfig\" (inputChange)=\"inputChanged($event)\"></spa-form>\r\n\r\n\r\n\r\n</div>\r\n\r\n</mat-dialog-content>\r\n\r\n<mat-dialog-actions>\r\n<div>\r\n<button mat-raised-button [disabled]=\"isProcessing\" color=\"primary\" *ngIf=\"formConfig.mode=='create' && createButton\" (click)=\"create()\" cdkFocusInitial>{{createButton.display ?? 'Submit'}}</button>\r\n<button mat-raised-button [disabled]=\"isProcessing\" color=\"primary\" *ngIf=\"formConfig.mode=='edit' && editButton\" (click)=\"edit()\" cdkFocusInitial>{{editButton.display ?? 'Submit'}}</button>\r\n\r\n<ng-container *ngIf=\"!smallScreen\">\r\n<button *ngFor=\"let btn of extraButtons\" mat-stroked-button [disabled]=\"isProcessing\" [ngStyle]=\"{'color': btn.icon.color}\" (click)=\"custom(btn)\" cdkFocusInitial><mat-icon [ngStyle]=\"{'color': btn.icon.color}\">{{btn.icon.name}}</mat-icon>{{btn.display ?? btn.name}}</button>\r\n</ng-container>\r\n\r\n\r\n<button mat-stroked-button color=\"primary\" mat-dialog-close>Cancel</button>\r\n</div>\r\n\r\n<div class=\"col d-flex justify-content-end\" *ngIf=\"smallScreen\">\r\n<button *ngFor=\"let btn of extraButtons\" mat-icon-button [disabled]=\"isProcessing\" [ngStyle]=\"{'color': btn.icon.color}\" (click)=\"custom(btn)\" cdkFocusInitial><mat-icon >{{btn.icon.name}}</mat-icon></button>\r\n<button mat-icon-button [disabled]=\"isProcessing\" style=\"color: red;\" (click)=\"delete()\" *ngIf=\"formConfig.mode!='create'  && deleteButton\"><mat-icon>delete</mat-icon></button>\r\n</div>\r\n\r\n\r\n</mat-dialog-actions>\r\n\r\n\r\n\r\n"]}