tin-spa 2.1.59 → 2.2.0
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.
- package/esm2020/lib/components/table/detailsDialog.component.mjs +4 -2
- package/esm2020/lib/components/table-internal/detailsDialog-internal.component.mjs +4 -2
- package/fesm2015/tin-spa.mjs +6 -2
- package/fesm2015/tin-spa.mjs.map +1 -1
- package/fesm2020/tin-spa.mjs +6 -2
- package/fesm2020/tin-spa.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -51,9 +51,9 @@ export class DetailsDialog {
|
|
|
51
51
|
this.buttons = buttons;
|
|
52
52
|
let resp = DetailsDialogProcessor.handleFormMode(this.detailsConfig, this.formConfig);
|
|
53
53
|
if (resp.loadByAction) {
|
|
54
|
-
this.loadData(resp.action, false);
|
|
55
54
|
this.loadByAction = true;
|
|
56
55
|
formConfig.loadAction = resp.action;
|
|
56
|
+
this.loadData(resp.action, false);
|
|
57
57
|
}
|
|
58
58
|
else {
|
|
59
59
|
this.details = resp.details;
|
|
@@ -78,6 +78,8 @@ export class DetailsDialog {
|
|
|
78
78
|
if (apiResponse.success) {
|
|
79
79
|
this.details = apiResponse.data;
|
|
80
80
|
this.isLoadComplete = true;
|
|
81
|
+
if (reload)
|
|
82
|
+
this.tableReload.next(true);
|
|
81
83
|
}
|
|
82
84
|
else {
|
|
83
85
|
this.messageService.toast("Error: " + apiResponse.message);
|
|
@@ -270,4 +272,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
270
272
|
type: Output
|
|
271
273
|
}] } });
|
|
272
274
|
;
|
|
273
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"detailsDialog.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/table/detailsDialog.component.ts","../../../../../../projects/tin-spa/src/lib/components/table/detailsDialog.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, ApiResponse } from '../../classes/Classes';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { DataServiceLib } from '../../services/data.service';\r\nimport { Core, DetailsDialogProcessor } from '../../classes/TinCore';\r\nimport { LoaderService } from '../../services/loader.service';\r\nimport { BreakpointObserver, BreakpointState } from '@angular/cdk/layout';\r\nimport { Subject, config } from 'rxjs';\r\n@Component({\r\n  selector: 'app-viewModel',\r\n  templateUrl: './detailsDialog.component.html',\r\n  styleUrls: ['./table.component.css']\r\n})\r\nexport class DetailsDialog implements OnInit {\r\n\r\n  constructor(private breakpointObserver: BreakpointObserver,private loaderService: LoaderService,private dataService: DataServiceLib,private messageService: MessageService,\r\n    private dialogRef: MatDialogRef<DetailsDialog>, @Inject(MAT_DIALOG_DATA) public detailsConfig: 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    const { tableConfig, tableConfigs, formConfig, buttons } = DetailsDialogProcessor.initializeConfigs(this.detailsConfig);\r\n    this.tableConfig = tableConfig;\r\n    this.tableConfigs = tableConfigs;\r\n    this.formConfig = formConfig;\r\n    this.buttons = buttons;\r\n\r\n    let resp = DetailsDialogProcessor.handleFormMode(this.detailsConfig, this.formConfig,);\r\n\r\n    if (resp.loadByAction){\r\n      this.loadData(resp.action, false);\r\n      this.loadByAction = true;\r\n      formConfig.loadAction = resp.action;\r\n    }else{\r\n      this.details = resp.details;\r\n      this.loadByAction = false;\r\n      this.isLoadComplete = true;\r\n    }\r\n\r\n    this.fileField = DetailsDialogProcessor.setFileField(this.formConfig);\r\n\r\n\r\n    this.loaderService.isLoading.subscribe(x => this.isProcessing = x);\r\n\r\n    const { extraButtons, createButton, editButton, deleteButton } = DetailsDialogProcessor.setupButtons(this.formConfig, this.buttons);\r\n    this.extraButtons = extraButtons;\r\n    this.createButton = createButton;\r\n    this.editButton = editButton;\r\n    this.deleteButton = deleteButton;\r\n\r\n    this.setTitleAction();\r\n\r\n  }\r\n\r\n\r\n  titleAction = \"View\";\r\n  loadByAction = false;\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  tableReload: Subject<boolean> = new Subject();\r\n\r\n  tableConfig: TableConfig\r\n  tableConfigs\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, reload) {\r\n    console.log(\"loading details\")\r\n\r\n    if (action && this.loadByAction) {\r\n\r\n      console.log(\"Loading action\")\r\n      console.log(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          this.isLoadComplete = true;\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    this.setTitleAction()\r\n  }\r\n\r\n  setTitleAction(){\r\n\r\n    if (this.buttons){\r\n      if (this.formConfig.mode == \"view\"){\r\n        this.titleAction = \"View\";\r\n      }\r\n      else if (this.formConfig.mode == \"edit\") {\r\n        this.titleAction = this.editButton.display ? this.editButton.display : \"Edit\"\r\n      }\r\n      else if (this.formConfig.mode == \"create\") {\r\n        this.titleAction = this.createButton.display ? this.createButton.display : \"Create\"\r\n      }\r\n    }\r\n  }\r\n\r\n  getButton(name: string) {\r\n    if (!this.buttons) {\r\n      console.log(\"No buttons found\")\r\n      return null\r\n    }\r\n    return this.buttons.find(x => x.name == name)\r\n  }\r\n\r\n  testDisabled(row, buttonName: string): boolean {\r\n\r\n    let button = this.getButton(buttonName)\r\n\r\n    if (button.disabled) {\r\n      let r = button.disabled(row);\r\n      return r;\r\n    }\r\n\r\n    return false;\r\n  }\r\n\r\n\r\n  testVisible(row, buttonName: string): boolean {\r\n\r\n    if (!this.isLoadComplete) return false;\r\n\r\n    let button = this.getButton(buttonName)\r\n\r\n    if (button.visible) {\r\n\r\n      return button.visible(row);\r\n    }\r\n\r\n    return true;\r\n  }\r\n\r\n  testVisibleTab(tblConfig: TableConfig): boolean {\r\n\r\n\r\n    if (tblConfig.hideTabCondition) {\r\n\r\n      return !tblConfig.hideTabCondition(tblConfig.parentData);\r\n    }\r\n\r\n    return true;\r\n  }\r\n\r\n  getButtonColor(button: Button, row) {\r\n\r\n    if (button.disabled) {\r\n      if (button.disabled(row)) {\r\n        return 'lightgray'\r\n      }\r\n    }\r\n\r\n    if (button.icon.color) {\r\n      return button.icon.color;\r\n    }\r\n\r\n    if (button.name == 'delete') {\r\n      return '#F44336'\r\n    }\r\n\r\n    if (button.name == 'create') {\r\n      return 'green'\r\n    }\r\n\r\n    return ' #4050B5'\r\n  }\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 createButton = this.detailsConfig.buttons.find(x => x.name == \"create\")\r\n    if (!createButton || !createButton.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 (createButton.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.exec(createButton, dataOut, \"Created\")\r\n\r\n  }\r\n\r\n  edit() {\r\n\r\n\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 editButton = this.detailsConfig.buttons.find(x => x.name == \"edit\")\r\n    if (!editButton || !editButton.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 (editButton.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.exec(editButton, dataOut, \"Updated\")\r\n\r\n  }\r\n\r\n  delete() {\r\n\r\n    let deleteButton = this.detailsConfig.buttons.find(x => x.name == \"delete\")\r\n    if (!deleteButton) {\r\n      this.dialogRef.close({ message: 'success', data: this.details });\r\n      return;\r\n    }\r\n\r\n    deleteButton.confirm = { message: \"DELETE ?\" }\r\n\r\n    this.exec(deleteButton, this.details, \"Deleted\")\r\n\r\n\r\n  }\r\n\r\n\r\n  custom(button: Button ) {\r\n\r\n\r\n    this.exec(button, this.details, \"Updated\")\r\n\r\n\r\n  }\r\n\r\n\r\n  exec(button: Button, details, defaultSuccessMessages: string) {\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\r\n        if (result == \"yes\") {\r\n          this.execAPI(button, details, defaultSuccessMessages);\r\n        }\r\n\r\n      });\r\n\r\n    } else {\r\n      this.execAPI(button, details,defaultSuccessMessages);\r\n    }\r\n\r\n  }\r\n\r\n  execAPI(button: Button, details, defaultSuccessMessage){\r\n\r\n    this.dataService.CallApi(button.action, details).subscribe((apiResponse) => {\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(defaultSuccessMessage);\r\n        }\r\n\r\n        this.dialogRef.close({ message: 'success', data: details });\r\n\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse);\r\n      }\r\n    })\r\n  }\r\n\r\n\r\n};\r\n\r\n\r\n\r\n","<mat-progress-bar mode=\"indeterminate\" *ngIf=\"isProcessing\"></mat-progress-bar>\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>{{titleAction | titlecase}} {{formConfig?.title}}</h2>\r\n  </div>\r\n\r\n  <div class=\"col d-flex justify-content-end\">\r\n\r\n    <div *ngIf=\"formConfig.mode=='view' && editButton && testVisible(details,editButton.name)\" class=\"col d-flex justify-content-end\">\r\n      <button mat-icon-button matTooltipPosition=\"above\" matTooltip=\"Edit\" color=\"primary\" (click)=\"setMode('edit')\" [disabled]=\"testDisabled(details,editButton.name)\"><mat-icon>edit</mat-icon></button>\r\n    </div>\r\n\r\n    <button [disabled]=\"isProcessing\" *ngIf=\"loadByAction\" mat-icon-button matTooltipPosition=\"above\" matTooltip=\"Refresh\" color=\"primary\" (click)=\"loadData(formConfig.loadAction, true)\"><mat-icon class=\"refreshIcon\">cached</mat-icon></button>\r\n  </div>\r\n\r\n</div>\r\n\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<div *ngIf=\"tableConfig\" class=\"mt-3\" style=\" font-size: 14px;\">\r\n  <spa-table-internal [config]=\"tableConfig\" [reload]=\"tableReload\"  ></spa-table-internal>\r\n</div>\r\n\r\n<mat-tab-group *ngIf=\"tableConfigs\">\r\n\r\n    <ng-container *ngFor=\"let tbl of tableConfigs\">\r\n\r\n      <mat-tab *ngIf=\"testVisibleTab(tbl)\">\r\n        <ng-template matTabLabel>\r\n          <span>{{tbl.title}}</span>\r\n        </ng-template>\r\n\r\n        <spa-table-internal [config]=\"tbl\" [hideTitle]=\"true\" [reload]=\"tableReload\" ></spa-table-internal>\r\n\r\n      </mat-tab>\r\n    </ng-container>\r\n\r\n\r\n</mat-tab-group>\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\r\n  <div>\r\n\r\n    <button mat-raised-button [disabled]=\"isProcessing\" color=\"primary\" *ngIf=\"formConfig.mode=='create' && createButton\"\r\n      (click)=\"create()\" cdkFocusInitial>{{createButton.display ?? 'Submit'}}\r\n    </button>\r\n\r\n    <button mat-raised-button [disabled]=\"isProcessing\" color=\"primary\" *ngIf=\"formConfig.mode=='edit' && editButton\"\r\n      (click)=\"edit()\" cdkFocusInitial>{{editButton.display ?? 'Submit'}}\r\n    </button>\r\n\r\n    <ng-container *ngFor=\"let btn of extraButtons\" >\r\n      <button *ngIf=\"!smallScreen && testVisible(details,btn.name)\" mat-stroked-button [disabled]=\"isProcessing || testDisabled(details,btn.name)\" [ngStyle]=\"{'color': getButtonColor(btn, details)}\"\r\n        (click)=\"custom(btn)\" cdkFocusInitial><mat-icon [ngStyle]=\"{'color': getButtonColor(btn, details)}\">{{btn.icon.name}}</mat-icon>{{btn.display ?? btn.name}}\r\n      </button>\r\n    </ng-container>\r\n\r\n\r\n    <button mat-stroked-button color=\"primary\" mat-dialog-close>Cancel</button>\r\n\r\n  </div>\r\n\r\n  <div class=\"col d-flex justify-content-end\" *ngIf=\"smallScreen\">\r\n    <ng-container *ngFor=\"let btn of extraButtons\">\r\n      <button  *ngIf=\"testVisible(details,btn.name)\" mat-icon-button [disabled]=\"isProcessing || testDisabled(details,btn.name)\" [ngStyle]=\"{'color': getButtonColor(btn, details)}\"\r\n        (click)=\"custom(btn)\" cdkFocusInitial><mat-icon>{{btn.icon.name}}</mat-icon>\r\n      </button>\r\n    </ng-container>\r\n\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"]}
|
|
275
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"detailsDialog.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/table/detailsDialog.component.ts","../../../../../../projects/tin-spa/src/lib/components/table/detailsDialog.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, ApiResponse } from '../../classes/Classes';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { DataServiceLib } from '../../services/data.service';\r\nimport { Core, DetailsDialogProcessor } from '../../classes/TinCore';\r\nimport { LoaderService } from '../../services/loader.service';\r\nimport { BreakpointObserver, BreakpointState } from '@angular/cdk/layout';\r\nimport { Subject, config } from 'rxjs';\r\n@Component({\r\n  selector: 'app-viewModel',\r\n  templateUrl: './detailsDialog.component.html',\r\n  styleUrls: ['./table.component.css']\r\n})\r\nexport class DetailsDialog implements OnInit {\r\n\r\n  constructor(private breakpointObserver: BreakpointObserver,private loaderService: LoaderService,private dataService: DataServiceLib,private messageService: MessageService,\r\n    private dialogRef: MatDialogRef<DetailsDialog>, @Inject(MAT_DIALOG_DATA) public detailsConfig: 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    const { tableConfig, tableConfigs, formConfig, buttons } = DetailsDialogProcessor.initializeConfigs(this.detailsConfig);\r\n    this.tableConfig = tableConfig;\r\n    this.tableConfigs = tableConfigs;\r\n    this.formConfig = formConfig;\r\n    this.buttons = buttons;\r\n\r\n    let resp = DetailsDialogProcessor.handleFormMode(this.detailsConfig, this.formConfig,);\r\n\r\n    if (resp.loadByAction){\r\n      this.loadByAction = true;\r\n      formConfig.loadAction = resp.action;\r\n      this.loadData(resp.action, false);\r\n    }else{\r\n      this.details = resp.details;\r\n      this.loadByAction = false;\r\n      this.isLoadComplete = true;\r\n    }\r\n\r\n    this.fileField = DetailsDialogProcessor.setFileField(this.formConfig);\r\n\r\n\r\n    this.loaderService.isLoading.subscribe(x => this.isProcessing = x);\r\n\r\n    const { extraButtons, createButton, editButton, deleteButton } = DetailsDialogProcessor.setupButtons(this.formConfig, this.buttons);\r\n    this.extraButtons = extraButtons;\r\n    this.createButton = createButton;\r\n    this.editButton = editButton;\r\n    this.deleteButton = deleteButton;\r\n\r\n    this.setTitleAction();\r\n\r\n  }\r\n\r\n\r\n  titleAction = \"View\";\r\n  loadByAction = false;\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  tableReload: Subject<boolean> = new Subject();\r\n\r\n  tableConfig: TableConfig\r\n  tableConfigs\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, reload) {\r\n    console.log(\"loading details\")\r\n\r\n    if (action && this.loadByAction) {\r\n\r\n      console.log(\"Loading action\")\r\n      console.log(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          this.isLoadComplete = true;\r\n          if(reload) this.tableReload.next(true);\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    this.setTitleAction()\r\n  }\r\n\r\n  setTitleAction(){\r\n\r\n    if (this.buttons){\r\n      if (this.formConfig.mode == \"view\"){\r\n        this.titleAction = \"View\";\r\n      }\r\n      else if (this.formConfig.mode == \"edit\") {\r\n        this.titleAction = this.editButton.display ? this.editButton.display : \"Edit\"\r\n      }\r\n      else if (this.formConfig.mode == \"create\") {\r\n        this.titleAction = this.createButton.display ? this.createButton.display : \"Create\"\r\n      }\r\n    }\r\n  }\r\n\r\n  getButton(name: string) {\r\n    if (!this.buttons) {\r\n      console.log(\"No buttons found\")\r\n      return null\r\n    }\r\n    return this.buttons.find(x => x.name == name)\r\n  }\r\n\r\n  testDisabled(row, buttonName: string): boolean {\r\n\r\n    let button = this.getButton(buttonName)\r\n\r\n    if (button.disabled) {\r\n      let r = button.disabled(row);\r\n      return r;\r\n    }\r\n\r\n    return false;\r\n  }\r\n\r\n\r\n  testVisible(row, buttonName: string): boolean {\r\n\r\n    if (!this.isLoadComplete) return false;\r\n\r\n    let button = this.getButton(buttonName)\r\n\r\n    if (button.visible) {\r\n\r\n      return button.visible(row);\r\n    }\r\n\r\n    return true;\r\n  }\r\n\r\n  testVisibleTab(tblConfig: TableConfig): boolean {\r\n\r\n\r\n    if (tblConfig.hideTabCondition) {\r\n\r\n      return !tblConfig.hideTabCondition(tblConfig.parentData);\r\n    }\r\n\r\n    return true;\r\n  }\r\n\r\n  getButtonColor(button: Button, row) {\r\n\r\n    if (button.disabled) {\r\n      if (button.disabled(row)) {\r\n        return 'lightgray'\r\n      }\r\n    }\r\n\r\n    if (button.icon.color) {\r\n      return button.icon.color;\r\n    }\r\n\r\n    if (button.name == 'delete') {\r\n      return '#F44336'\r\n    }\r\n\r\n    if (button.name == 'create') {\r\n      return 'green'\r\n    }\r\n\r\n    return ' #4050B5'\r\n  }\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 createButton = this.detailsConfig.buttons.find(x => x.name == \"create\")\r\n    if (!createButton || !createButton.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 (createButton.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.exec(createButton, dataOut, \"Created\")\r\n\r\n  }\r\n\r\n  edit() {\r\n\r\n\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 editButton = this.detailsConfig.buttons.find(x => x.name == \"edit\")\r\n    if (!editButton || !editButton.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 (editButton.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.exec(editButton, dataOut, \"Updated\")\r\n\r\n  }\r\n\r\n  delete() {\r\n\r\n    let deleteButton = this.detailsConfig.buttons.find(x => x.name == \"delete\")\r\n    if (!deleteButton) {\r\n      this.dialogRef.close({ message: 'success', data: this.details });\r\n      return;\r\n    }\r\n\r\n    deleteButton.confirm = { message: \"DELETE ?\" }\r\n\r\n    this.exec(deleteButton, this.details, \"Deleted\")\r\n\r\n\r\n  }\r\n\r\n\r\n  custom(button: Button ) {\r\n\r\n\r\n    this.exec(button, this.details, \"Updated\")\r\n\r\n\r\n  }\r\n\r\n\r\n  exec(button: Button, details, defaultSuccessMessages: string) {\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\r\n        if (result == \"yes\") {\r\n          this.execAPI(button, details, defaultSuccessMessages);\r\n        }\r\n\r\n      });\r\n\r\n    } else {\r\n      this.execAPI(button, details,defaultSuccessMessages);\r\n    }\r\n\r\n  }\r\n\r\n  execAPI(button: Button, details, defaultSuccessMessage){\r\n\r\n    this.dataService.CallApi(button.action, details).subscribe((apiResponse) => {\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(defaultSuccessMessage);\r\n        }\r\n\r\n        this.dialogRef.close({ message: 'success', data: details });\r\n\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse);\r\n      }\r\n    })\r\n  }\r\n\r\n\r\n};\r\n\r\n\r\n\r\n","<mat-progress-bar mode=\"indeterminate\" *ngIf=\"isProcessing\"></mat-progress-bar>\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>{{titleAction | titlecase}} {{formConfig?.title}}</h2>\r\n  </div>\r\n\r\n  <div class=\"col d-flex justify-content-end\">\r\n\r\n    <div *ngIf=\"formConfig.mode=='view' && editButton && testVisible(details,editButton.name)\" class=\"col d-flex justify-content-end\">\r\n      <button mat-icon-button matTooltipPosition=\"above\" matTooltip=\"Edit\" color=\"primary\" (click)=\"setMode('edit')\" [disabled]=\"testDisabled(details,editButton.name)\"><mat-icon>edit</mat-icon></button>\r\n    </div>\r\n\r\n    <button [disabled]=\"isProcessing\" *ngIf=\"loadByAction\" mat-icon-button matTooltipPosition=\"above\" matTooltip=\"Refresh\" color=\"primary\" (click)=\"loadData(formConfig.loadAction, true)\"><mat-icon class=\"refreshIcon\">cached</mat-icon></button>\r\n  </div>\r\n\r\n</div>\r\n\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<div *ngIf=\"tableConfig\" class=\"mt-3\" style=\" font-size: 14px;\">\r\n  <spa-table-internal [config]=\"tableConfig\" [reload]=\"tableReload\"  ></spa-table-internal>\r\n</div>\r\n\r\n<mat-tab-group *ngIf=\"tableConfigs\">\r\n\r\n    <ng-container *ngFor=\"let tbl of tableConfigs\">\r\n\r\n      <mat-tab *ngIf=\"testVisibleTab(tbl)\">\r\n        <ng-template matTabLabel>\r\n          <span>{{tbl.title}}</span>\r\n        </ng-template>\r\n\r\n        <spa-table-internal [config]=\"tbl\" [hideTitle]=\"true\" [reload]=\"tableReload\" ></spa-table-internal>\r\n\r\n      </mat-tab>\r\n    </ng-container>\r\n\r\n\r\n</mat-tab-group>\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\r\n  <div>\r\n\r\n    <button mat-raised-button [disabled]=\"isProcessing\" color=\"primary\" *ngIf=\"formConfig.mode=='create' && createButton\"\r\n      (click)=\"create()\" cdkFocusInitial>{{createButton.display ?? 'Submit'}}\r\n    </button>\r\n\r\n    <button mat-raised-button [disabled]=\"isProcessing\" color=\"primary\" *ngIf=\"formConfig.mode=='edit' && editButton\"\r\n      (click)=\"edit()\" cdkFocusInitial>{{editButton.display ?? 'Submit'}}\r\n    </button>\r\n\r\n    <ng-container *ngFor=\"let btn of extraButtons\" >\r\n      <button *ngIf=\"!smallScreen && testVisible(details,btn.name)\" mat-stroked-button [disabled]=\"isProcessing || testDisabled(details,btn.name)\" [ngStyle]=\"{'color': getButtonColor(btn, details)}\"\r\n        (click)=\"custom(btn)\" cdkFocusInitial><mat-icon [ngStyle]=\"{'color': getButtonColor(btn, details)}\">{{btn.icon.name}}</mat-icon>{{btn.display ?? btn.name}}\r\n      </button>\r\n    </ng-container>\r\n\r\n\r\n    <button mat-stroked-button color=\"primary\" mat-dialog-close>Cancel</button>\r\n\r\n  </div>\r\n\r\n  <div class=\"col d-flex justify-content-end\" *ngIf=\"smallScreen\">\r\n    <ng-container *ngFor=\"let btn of extraButtons\">\r\n      <button  *ngIf=\"testVisible(details,btn.name)\" mat-icon-button [disabled]=\"isProcessing || testDisabled(details,btn.name)\" [ngStyle]=\"{'color': getButtonColor(btn, details)}\"\r\n        (click)=\"custom(btn)\" cdkFocusInitial><mat-icon>{{btn.icon.name}}</mat-icon>\r\n      </button>\r\n    </ng-container>\r\n\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"]}
|
|
@@ -47,9 +47,9 @@ export class DetailsDialogInternal {
|
|
|
47
47
|
this.buttons = buttons;
|
|
48
48
|
let resp = DetailsDialogProcessor.handleFormMode(this.detailsConfig, this.formConfig);
|
|
49
49
|
if (resp.loadByAction) {
|
|
50
|
-
this.loadData(resp.action);
|
|
51
50
|
this.loadByAction = true;
|
|
52
51
|
formConfig.loadAction = resp.action;
|
|
52
|
+
this.loadData(resp.action);
|
|
53
53
|
}
|
|
54
54
|
else {
|
|
55
55
|
this.details = resp.details;
|
|
@@ -68,6 +68,8 @@ export class DetailsDialogInternal {
|
|
|
68
68
|
loadData(action) {
|
|
69
69
|
console.log("loading details");
|
|
70
70
|
if (action && this.loadByAction) {
|
|
71
|
+
console.log("Loading action");
|
|
72
|
+
console.log(action);
|
|
71
73
|
this.dataService.CallApi(action).subscribe((apiResponse) => {
|
|
72
74
|
if (apiResponse.success) {
|
|
73
75
|
this.details = apiResponse.data;
|
|
@@ -258,4 +260,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
258
260
|
type: Output
|
|
259
261
|
}] } });
|
|
260
262
|
;
|
|
261
|
-
//# 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, ApiResponse } from '../../classes/Classes';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { DataServiceLib } from '../../services/data.service';\r\nimport { LoaderService } from '../../services/loader.service';\r\nimport { BreakpointObserver, BreakpointState } from '@angular/cdk/layout';\r\nimport { Core, DetailsDialogProcessor } from '../../classes/TinCore';\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 detailsConfig: 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    const { tableConfig, tableConfigs, formConfig, buttons } = DetailsDialogProcessor.initializeConfigs(this.detailsConfig);\r\n    this.tableConfig = tableConfig;\r\n    this.tableConfigs = tableConfigs;\r\n    this.formConfig = formConfig;\r\n    this.buttons = buttons;\r\n\r\n    let resp = DetailsDialogProcessor.handleFormMode(this.detailsConfig, this.formConfig,);\r\n\r\n    if (resp.loadByAction) {\r\n      this.loadData(resp.action);\r\n      this.loadByAction = true;\r\n      formConfig.loadAction = resp.action;\r\n    } else {\r\n      this.details = resp.details;\r\n      this.loadByAction = false;\r\n      this.isLoadComplete = true;\r\n    }\r\n\r\n    this.fileField = DetailsDialogProcessor.setFileField(this.formConfig);\r\n\r\n\r\n    this.loaderService.isLoading.subscribe(x => this.isProcessing = x);\r\n\r\n    const { extraButtons, createButton, editButton, deleteButton } = DetailsDialogProcessor.setupButtons(this.formConfig, this.buttons);\r\n    this.extraButtons = extraButtons;\r\n    this.createButton = createButton;\r\n    this.editButton = editButton;\r\n    this.deleteButton = deleteButton;\r\n\r\n    this.setTitleAction()\r\n\r\n  }\r\n\r\n\r\n  titleAction = \"View\";\r\n  loadByAction = false;\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  tableConfigs\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 && this.loadByAction) {\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          this.isLoadComplete = true;\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    this.setTitleAction()\r\n  }\r\n\r\n  setTitleAction() {\r\n\r\n    if (this.buttons) {\r\n      if (this.formConfig.mode == \"view\") {\r\n        this.titleAction = \"View\";\r\n      }\r\n      else if (this.formConfig.mode == \"edit\") {\r\n        this.titleAction = this.editButton.display ? this.editButton.display : \"Edit\"\r\n      }\r\n      else if (this.formConfig.mode == \"create\") {\r\n        this.titleAction = this.createButton.display ? this.createButton.display : \"Create\"\r\n      }\r\n    }\r\n  }\r\n\r\n  getButton(name: string) {\r\n    if (!this.buttons) {\r\n      console.log(\"No buttons found\")\r\n      return null\r\n    }\r\n    return this.buttons.find(x => x.name == name)\r\n  }\r\n\r\n  testDisabled(row, buttonName: string): boolean {\r\n\r\n    let button = this.getButton(buttonName)\r\n\r\n    if (button.disabled) {\r\n      let r = button.disabled(row);\r\n      return r;\r\n    }\r\n\r\n    return false;\r\n  }\r\n\r\n\r\n  testVisible(row, buttonName: string): boolean {\r\n\r\n    if (!this.isLoadComplete) return false;\r\n\r\n    let button = this.getButton(buttonName)\r\n\r\n    if (button.visible) {\r\n\r\n      return button.visible(row);\r\n    }\r\n\r\n    return true;\r\n  }\r\n\r\n  getButtonColor(button: Button, row) {\r\n\r\n    if (button.disabled) {\r\n      if (button.disabled(row)) {\r\n        return 'lightgray'\r\n      }\r\n    }\r\n\r\n    if (button.icon.color) {\r\n      return button.icon.color;\r\n    }\r\n\r\n    if (button.name == 'delete') {\r\n      return '#F44336'\r\n    }\r\n\r\n    if (button.name == 'create') {\r\n      return 'green'\r\n    }\r\n\r\n    return ' #4050B5'\r\n  }\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 createButton = this.detailsConfig.buttons.find(x => x.name == \"create\")\r\n    if (!createButton || !createButton.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 (createButton.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.exec(createButton, dataOut, \"Created\")\r\n\r\n  }\r\n\r\n  edit() {\r\n\r\n\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 editButton = this.detailsConfig.buttons.find(x => x.name == \"edit\")\r\n    if (!editButton || !editButton.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 (editButton.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.exec(editButton, dataOut, \"Updated\")\r\n\r\n  }\r\n\r\n  delete() {\r\n\r\n    let deleteButton = this.detailsConfig.buttons.find(x => x.name == \"delete\")\r\n    if (!deleteButton) {\r\n      this.dialogRef.close({ message: 'success', data: this.details });\r\n      return;\r\n    }\r\n\r\n    deleteButton.confirm = { message: \"DELETE ?\" }\r\n\r\n    this.exec(deleteButton, this.details, \"Deleted\")\r\n\r\n  }\r\n\r\n\r\n  custom(button: Button) {\r\n\r\n\r\n    this.exec(button, this.details, \"Updated\")\r\n\r\n\r\n  }\r\n\r\n\r\n  exec(button: Button, details, defaultSuccessMessages: string) {\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\r\n        if (result == \"yes\") {\r\n          this.execAPI(button, details, defaultSuccessMessages);\r\n        }\r\n\r\n      });\r\n\r\n    } else {\r\n      this.execAPI(button, details, defaultSuccessMessages);\r\n    }\r\n\r\n  }\r\n\r\n  execAPI(button: Button, details, defaultSuccessMessage) {\r\n\r\n    this.dataService.CallApi(button.action, details).subscribe((apiResponse) => {\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(defaultSuccessMessage);\r\n        }\r\n\r\n        this.dialogRef.close({ message: 'success', data: details });\r\n\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse);\r\n      }\r\n    })\r\n  }\r\n\r\n\r\n};\r\n\r\n\r\n\r\n","<mat-progress-bar mode=\"indeterminate\" *ngIf=\"isProcessing\"></mat-progress-bar>\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>{{titleAction | titlecase}} {{formConfig?.title}}</h2>\r\n  </div>\r\n\r\n  <div class=\"col d-flex justify-content-end\">\r\n\r\n    <div *ngIf=\"formConfig.mode=='view' && editButton && testVisible(details,editButton.name)\" class=\"col d-flex justify-content-end\">\r\n      <button mat-icon-button matTooltipPosition=\"above\" matTooltip=\"Edit\" color=\"primary\" (click)=\"setMode('edit')\" [disabled]=\"testDisabled(details,editButton.name)\"><mat-icon>edit</mat-icon></button>\r\n    </div>\r\n\r\n    <button [disabled]=\"isProcessing\" *ngIf=\"loadByAction\" mat-icon-button matTooltipPosition=\"above\" matTooltip=\"Refresh\" color=\"primary\" (click)=\"loadData(formConfig.loadAction)\"><mat-icon class=\"refreshIcon\">cached</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\r\n  <div>\r\n\r\n    <button mat-raised-button [disabled]=\"isProcessing\" color=\"primary\" *ngIf=\"formConfig.mode=='create' && createButton\" (click)=\"create()\" cdkFocusInitial>{{createButton.display ?? 'Submit'}}\r\n    </button>\r\n\r\n    <button mat-raised-button [disabled]=\"isProcessing\" color=\"primary\" *ngIf=\"formConfig.mode=='edit' && editButton\" (click)=\"edit()\" cdkFocusInitial>{{editButton.display ?? 'Submit'}}\r\n    </button>\r\n\r\n    <ng-container *ngFor=\"let btn of extraButtons\">\r\n      <button *ngIf=\"!smallScreen && testVisible(details,btn.name)\" mat-stroked-button [disabled]=\"isProcessing || testDisabled(details,btn.name)\" [ngStyle]=\"{'color': getButtonColor(btn, details)}\" (click)=\"custom(btn)\" cdkFocusInitial><mat-icon [ngStyle]=\"{'color': getButtonColor(btn, details)}\">{{btn.icon.name}}</mat-icon>{{btn.display ?? btn.name}}\r\n      </button>\r\n    </ng-container>\r\n\r\n\r\n    <button mat-stroked-button color=\"primary\" mat-dialog-close>Cancel</button>\r\n\r\n  </div>\r\n\r\n  <div class=\"col d-flex justify-content-end\" *ngIf=\"smallScreen\">\r\n    <ng-container *ngFor=\"let btn of extraButtons\">\r\n      <button *ngIf=\"testVisible(details,btn.name)\" mat-icon-button [disabled]=\"isProcessing || testDisabled(details,btn.name)\" [ngStyle]=\"{'color': getButtonColor(btn, details)}\" (click)=\"custom(btn)\" cdkFocusInitial><mat-icon>{{btn.icon.name}}</mat-icon>\r\n      </button>\r\n    </ng-container>\r\n\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"]}
|
|
263
|
+
//# 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":"AACA,OAAO,EAAE,SAAS,EAAU,MAAM,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAChF,OAAO,EAAE,eAAe,EAAgB,MAAM,0BAA0B,CAAC;AAMzE,OAAO,EAAE,IAAI,EAAE,sBAAsB,EAAE,MAAM,uBAAuB,CAAC;;;;;;;;;;;;;;AAMrE,MAAM,OAAO,qBAAqB;IAEhC,YAAoB,kBAAsC,EAAS,aAA4B,EAAS,WAA2B,EAAS,cAA8B,EAChK,SAA8C,EAAkC,aAAkC;QADxG,uBAAkB,GAAlB,kBAAkB,CAAoB;QAAS,kBAAa,GAAb,aAAa,CAAe;QAAS,gBAAW,GAAX,WAAW,CAAgB;QAAS,mBAAc,GAAd,cAAc,CAAgB;QAChK,cAAS,GAAT,SAAS,CAAqC;QAAkC,kBAAa,GAAb,aAAa,CAAqB;QAkD5H,gBAAW,GAAG,MAAM,CAAC;QACrB,iBAAY,GAAG,KAAK,CAAC;QAUrB,UAAK,GAAU,EAAE,CAAC;QAMlB,gBAAW,GAAG,KAAK,CAAC;QAEpB,mBAAc,GAAY,KAAK,CAAC;QAChC,iBAAY,GAAY,KAAK,CAAC;QAEpB,gBAAW,GAAG,IAAI,YAAY,EAAE,CAAC;QAtEzC,6BAA6B;QAC7B,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,MAAuB,EAAE,EAAE;YAE5F,IAAI,MAAM,CAAC,OAAO,EAAE;gBAClB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAA;aACxB;iBAAK;gBACJ,IAAI,CAAC,WAAW,GAAG,KAAK,CAAA;aACzB;QAEH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,QAAQ;QAEN,MAAM,EAAE,WAAW,EAAE,YAAY,EAAE,UAAU,EAAE,OAAO,EAAE,GAAG,sBAAsB,CAAC,iBAAiB,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QACxH,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;QACjC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QAEvB,IAAI,IAAI,GAAG,sBAAsB,CAAC,cAAc,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,UAAU,CAAE,CAAC;QAEvF,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;YACzB,UAAU,CAAC,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC;YACpC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SAC5B;aAAM;YACL,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;YAC5B,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;YAC1B,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;SAC5B;QAED,IAAI,CAAC,SAAS,GAAG,sBAAsB,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAGtE,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC,CAAC;QAEnE,MAAM,EAAE,YAAY,EAAE,YAAY,EAAE,UAAU,EAAE,YAAY,EAAE,GAAG,sBAAsB,CAAC,YAAY,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;QACpI,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;QACjC,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;QACjC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;QAEjC,IAAI,CAAC,cAAc,EAAE,CAAA;IAEvB,CAAC;IA4BD,QAAQ,CAAC,MAAc;QACrB,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAA;QAE9B,IAAI,MAAM,IAAI,IAAI,CAAC,YAAY,EAAE;YAE/B,OAAO,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAA;YAC7B,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;YAEnB,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,CAAC,WAAwB,EAAE,EAAE;gBAEtE,IAAI,WAAW,CAAC,OAAO,EAAE;oBACvB,IAAI,CAAC,OAAO,GAAG,WAAW,CAAC,IAAI,CAAA;oBAC/B,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;iBAC5B;qBACI;oBACH,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,SAAS,GAAG,WAAW,CAAC,OAAO,CAAC,CAAC;iBAC5D;YAEH,CAAC,CAAC,CAAC;SACJ;IAEH,CAAC;IAED,YAAY,CAAC,KAAK;QAChB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,KAAK,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,KAAK,EAAE,CAAC,CAAA;IACnE,CAAC;IAGD,OAAO,CAAC,OAAe;QACrB,IAAI,CAAC,UAAU,CAAC,IAAI,GAAG,OAAO,CAAA;QAC9B,IAAI,CAAC,cAAc,EAAE,CAAA;IACvB,CAAC;IAED,cAAc;QAEZ,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,IAAI,IAAI,CAAC,UAAU,CAAC,IAAI,IAAI,MAAM,EAAE;gBAClC,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC;aAC3B;iBACI,IAAI,IAAI,CAAC,UAAU,CAAC,IAAI,IAAI,MAAM,EAAE;gBACvC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAA;aAC9E;iBACI,IAAI,IAAI,CAAC,UAAU,CAAC,IAAI,IAAI,QAAQ,EAAE;gBACzC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAA;aACpF;SACF;IACH,CAAC;IAED,SAAS,CAAC,IAAY;QACpB,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;YACjB,OAAO,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAA;YAC/B,OAAO,IAAI,CAAA;SACZ;QACD,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI,IAAI,CAAC,CAAA;IAC/C,CAAC;IAED,YAAY,CAAC,GAAG,EAAE,UAAkB;QAElC,IAAI,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAA;QAEvC,IAAI,MAAM,CAAC,QAAQ,EAAE;YACnB,IAAI,CAAC,GAAG,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;YAC7B,OAAO,CAAC,CAAC;SACV;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAGD,WAAW,CAAC,GAAG,EAAE,UAAkB;QAEjC,IAAI,CAAC,IAAI,CAAC,cAAc;YAAE,OAAO,KAAK,CAAC;QAEvC,IAAI,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAA;QAEvC,IAAI,MAAM,CAAC,OAAO,EAAE;YAElB,OAAO,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;SAC5B;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAED,cAAc,CAAC,MAAc,EAAE,GAAG;QAEhC,IAAI,MAAM,CAAC,QAAQ,EAAE;YACnB,IAAI,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE;gBACxB,OAAO,WAAW,CAAA;aACnB;SACF;QAED,IAAI,MAAM,CAAC,IAAI,CAAC,KAAK,EAAE;YACrB,OAAO,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC;SAC1B;QAED,IAAI,MAAM,CAAC,IAAI,IAAI,QAAQ,EAAE;YAC3B,OAAO,SAAS,CAAA;SACjB;QAED,IAAI,MAAM,CAAC,IAAI,IAAI,QAAQ,EAAE;YAC3B,OAAO,OAAO,CAAA;SACf;QAED,OAAO,UAAU,CAAA;IACnB,CAAC;IAGD,MAAM;QAEJ,4BAA4B;QAE5B,YAAY;QACZ,IAAI,IAAI,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;QACrE,IAAI,IAAI,IAAI,EAAE,EAAE;YACd,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;YAC/B,OAAO;SACR;QAGD,qBAAqB;QACrB,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,SAAS,EAAE,QAAQ,EAAE;YACrD,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,uBAAuB,CAAC,CAAC;YACnD,OAAO;SACR;QACD,qBAAqB;QAErB,IAAI,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI,QAAQ,CAAC,CAAA;QAC3E,IAAI,CAAC,YAAY,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE;YAEzC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;YAC9D,OAAO;SACR;QAGD,aAAa;QACb,IAAI,OAAO,CAAC;QAEZ,IAAI,YAAY,CAAC,MAAM,CAAC,UAAU,EAAE;YAElC,IAAI,QAAQ,GAAa,IAAI,QAAQ,EAAE,CAAC;YACxC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBAC1C,QAAQ,CAAC,MAAM,CAAC,aAAa,CAAC,EAAE,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;aACtE;YAED,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;YAEtD,wBAAwB;YAExB,OAAO,GAAG,QAAQ,CAAA;SACnB;aAAM;YAEL,OAAO,GAAG,IAAI,CAAC,OAAO,CAAA;SACvB;QACD,aAAa;QAGb,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,OAAO,EAAE,SAAS,CAAC,CAAA;IAE7C,CAAC;IAED,IAAI;QAIF,YAAY;QACZ,IAAI,IAAI,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;QACrE,IAAI,IAAI,IAAI,EAAE,EAAE;YACd,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;YAC/B,OAAO;SACR;QAID,IAAI,UAAU,GAAG,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI,MAAM,CAAC,CAAA;QACvE,IAAI,CAAC,UAAU,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE;YACrC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;YAC9D,OAAO;SACR;QAGD,aAAa;QACb,IAAI,OAAO,CAAC;QAEZ,IAAI,UAAU,CAAC,MAAM,CAAC,UAAU,EAAE;YAEhC,IAAI,QAAQ,GAAa,IAAI,QAAQ,EAAE,CAAC;YACxC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBAC1C,QAAQ,CAAC,MAAM,CAAC,aAAa,CAAC,EAAE,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;aACtE;YAED,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;YAEtD,wBAAwB;YAExB,OAAO,GAAG,QAAQ,CAAA;SACnB;aAAM;YAEL,OAAO,GAAG,IAAI,CAAC,OAAO,CAAA;SACvB;QACD,aAAa;QAGb,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,OAAO,EAAE,SAAS,CAAC,CAAA;IAE3C,CAAC;IAED,MAAM;QAEJ,IAAI,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI,QAAQ,CAAC,CAAA;QAC3E,IAAI,CAAC,YAAY,EAAE;YACjB,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;YACjE,OAAO;SACR;QAED,YAAY,CAAC,OAAO,GAAG,EAAE,OAAO,EAAE,UAAU,EAAE,CAAA;QAE9C,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,OAAO,EAAE,SAAS,CAAC,CAAA;IAElD,CAAC;IAGD,MAAM,CAAC,MAAc;QAGnB,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,OAAO,EAAE,SAAS,CAAC,CAAA;IAG5C,CAAC;IAGD,IAAI,CAAC,MAAc,EAAE,OAAO,EAAE,sBAA8B;QAI1D,IAAI,MAAM,CAAC,OAAO,EAAE;YAElB,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;gBAEvE,IAAI,MAAM,IAAI,KAAK,EAAE;oBACnB,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,OAAO,EAAE,sBAAsB,CAAC,CAAC;iBACvD;YAEH,CAAC,CAAC,CAAC;SAEJ;aAAM;YACL,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,OAAO,EAAE,sBAAsB,CAAC,CAAC;SACvD;IAEH,CAAC;IAED,OAAO,CAAC,MAAc,EAAE,OAAO,EAAE,qBAAqB;QAEpD,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,WAAW,EAAE,EAAE;YACzE,IAAI,WAAW,CAAC,OAAO,EAAE;gBAEvB,IAAI,MAAM,CAAC,MAAM,CAAC,cAAc,EAAE;oBAChC,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC;iBACzD;qBAAM;oBACL,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,qBAAqB,CAAC,CAAC;iBAClD;gBAED,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,CAAC,CAAC;aAE7D;iBAAM;gBACL,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,SAAS,GAAG,WAAW,CAAC,CAAC;aACpD;QACH,CAAC,CAAC,CAAA;IACJ,CAAC;;kHAzVU,qBAAqB,yKAGkC,eAAe;sGAHtE,qBAAqB,8FCdlC,+jGAiEA;2FDnDa,qBAAqB;kBALjC,SAAS;+BACE,eAAe;;0BAOkC,MAAM;2BAAC,eAAe;4CAwEvE,WAAW;sBAApB,MAAM;;AAiRR,CAAC","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, ApiResponse } from '../../classes/Classes';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { DataServiceLib } from '../../services/data.service';\r\nimport { LoaderService } from '../../services/loader.service';\r\nimport { BreakpointObserver, BreakpointState } from '@angular/cdk/layout';\r\nimport { Core, DetailsDialogProcessor } from '../../classes/TinCore';\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 detailsConfig: 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    const { tableConfig, tableConfigs, formConfig, buttons } = DetailsDialogProcessor.initializeConfigs(this.detailsConfig);\r\n    this.tableConfig = tableConfig;\r\n    this.tableConfigs = tableConfigs;\r\n    this.formConfig = formConfig;\r\n    this.buttons = buttons;\r\n\r\n    let resp = DetailsDialogProcessor.handleFormMode(this.detailsConfig, this.formConfig,);\r\n\r\n    if (resp.loadByAction) {\r\n      this.loadByAction = true;\r\n      formConfig.loadAction = resp.action;\r\n      this.loadData(resp.action);\r\n    } else {\r\n      this.details = resp.details;\r\n      this.loadByAction = false;\r\n      this.isLoadComplete = true;\r\n    }\r\n\r\n    this.fileField = DetailsDialogProcessor.setFileField(this.formConfig);\r\n\r\n\r\n    this.loaderService.isLoading.subscribe(x => this.isProcessing = x);\r\n\r\n    const { extraButtons, createButton, editButton, deleteButton } = DetailsDialogProcessor.setupButtons(this.formConfig, this.buttons);\r\n    this.extraButtons = extraButtons;\r\n    this.createButton = createButton;\r\n    this.editButton = editButton;\r\n    this.deleteButton = deleteButton;\r\n\r\n    this.setTitleAction()\r\n\r\n  }\r\n\r\n\r\n  titleAction = \"View\";\r\n  loadByAction = false;\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  tableConfigs\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 && this.loadByAction) {\r\n\r\n      console.log(\"Loading action\")\r\n      console.log(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          this.isLoadComplete = true;\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    this.setTitleAction()\r\n  }\r\n\r\n  setTitleAction() {\r\n\r\n    if (this.buttons) {\r\n      if (this.formConfig.mode == \"view\") {\r\n        this.titleAction = \"View\";\r\n      }\r\n      else if (this.formConfig.mode == \"edit\") {\r\n        this.titleAction = this.editButton.display ? this.editButton.display : \"Edit\"\r\n      }\r\n      else if (this.formConfig.mode == \"create\") {\r\n        this.titleAction = this.createButton.display ? this.createButton.display : \"Create\"\r\n      }\r\n    }\r\n  }\r\n\r\n  getButton(name: string) {\r\n    if (!this.buttons) {\r\n      console.log(\"No buttons found\")\r\n      return null\r\n    }\r\n    return this.buttons.find(x => x.name == name)\r\n  }\r\n\r\n  testDisabled(row, buttonName: string): boolean {\r\n\r\n    let button = this.getButton(buttonName)\r\n\r\n    if (button.disabled) {\r\n      let r = button.disabled(row);\r\n      return r;\r\n    }\r\n\r\n    return false;\r\n  }\r\n\r\n\r\n  testVisible(row, buttonName: string): boolean {\r\n\r\n    if (!this.isLoadComplete) return false;\r\n\r\n    let button = this.getButton(buttonName)\r\n\r\n    if (button.visible) {\r\n\r\n      return button.visible(row);\r\n    }\r\n\r\n    return true;\r\n  }\r\n\r\n  getButtonColor(button: Button, row) {\r\n\r\n    if (button.disabled) {\r\n      if (button.disabled(row)) {\r\n        return 'lightgray'\r\n      }\r\n    }\r\n\r\n    if (button.icon.color) {\r\n      return button.icon.color;\r\n    }\r\n\r\n    if (button.name == 'delete') {\r\n      return '#F44336'\r\n    }\r\n\r\n    if (button.name == 'create') {\r\n      return 'green'\r\n    }\r\n\r\n    return ' #4050B5'\r\n  }\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 createButton = this.detailsConfig.buttons.find(x => x.name == \"create\")\r\n    if (!createButton || !createButton.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 (createButton.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.exec(createButton, dataOut, \"Created\")\r\n\r\n  }\r\n\r\n  edit() {\r\n\r\n\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 editButton = this.detailsConfig.buttons.find(x => x.name == \"edit\")\r\n    if (!editButton || !editButton.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 (editButton.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.exec(editButton, dataOut, \"Updated\")\r\n\r\n  }\r\n\r\n  delete() {\r\n\r\n    let deleteButton = this.detailsConfig.buttons.find(x => x.name == \"delete\")\r\n    if (!deleteButton) {\r\n      this.dialogRef.close({ message: 'success', data: this.details });\r\n      return;\r\n    }\r\n\r\n    deleteButton.confirm = { message: \"DELETE ?\" }\r\n\r\n    this.exec(deleteButton, this.details, \"Deleted\")\r\n\r\n  }\r\n\r\n\r\n  custom(button: Button) {\r\n\r\n\r\n    this.exec(button, this.details, \"Updated\")\r\n\r\n\r\n  }\r\n\r\n\r\n  exec(button: Button, details, defaultSuccessMessages: string) {\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\r\n        if (result == \"yes\") {\r\n          this.execAPI(button, details, defaultSuccessMessages);\r\n        }\r\n\r\n      });\r\n\r\n    } else {\r\n      this.execAPI(button, details, defaultSuccessMessages);\r\n    }\r\n\r\n  }\r\n\r\n  execAPI(button: Button, details, defaultSuccessMessage) {\r\n\r\n    this.dataService.CallApi(button.action, details).subscribe((apiResponse) => {\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(defaultSuccessMessage);\r\n        }\r\n\r\n        this.dialogRef.close({ message: 'success', data: details });\r\n\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse);\r\n      }\r\n    })\r\n  }\r\n\r\n\r\n};\r\n\r\n\r\n\r\n","<mat-progress-bar mode=\"indeterminate\" *ngIf=\"isProcessing\"></mat-progress-bar>\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>{{titleAction | titlecase}} {{formConfig?.title}}</h2>\r\n  </div>\r\n\r\n  <div class=\"col d-flex justify-content-end\">\r\n\r\n    <div *ngIf=\"formConfig.mode=='view' && editButton && testVisible(details,editButton.name)\" class=\"col d-flex justify-content-end\">\r\n      <button mat-icon-button matTooltipPosition=\"above\" matTooltip=\"Edit\" color=\"primary\" (click)=\"setMode('edit')\" [disabled]=\"testDisabled(details,editButton.name)\"><mat-icon>edit</mat-icon></button>\r\n    </div>\r\n\r\n    <button [disabled]=\"isProcessing\" *ngIf=\"loadByAction\" mat-icon-button matTooltipPosition=\"above\" matTooltip=\"Refresh\" color=\"primary\" (click)=\"loadData(formConfig.loadAction)\"><mat-icon class=\"refreshIcon\">cached</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\r\n  <div>\r\n\r\n    <button mat-raised-button [disabled]=\"isProcessing\" color=\"primary\" *ngIf=\"formConfig.mode=='create' && createButton\" (click)=\"create()\" cdkFocusInitial>{{createButton.display ?? 'Submit'}}\r\n    </button>\r\n\r\n    <button mat-raised-button [disabled]=\"isProcessing\" color=\"primary\" *ngIf=\"formConfig.mode=='edit' && editButton\" (click)=\"edit()\" cdkFocusInitial>{{editButton.display ?? 'Submit'}}\r\n    </button>\r\n\r\n    <ng-container *ngFor=\"let btn of extraButtons\">\r\n      <button *ngIf=\"!smallScreen && testVisible(details,btn.name)\" mat-stroked-button [disabled]=\"isProcessing || testDisabled(details,btn.name)\" [ngStyle]=\"{'color': getButtonColor(btn, details)}\" (click)=\"custom(btn)\" cdkFocusInitial><mat-icon [ngStyle]=\"{'color': getButtonColor(btn, details)}\">{{btn.icon.name}}</mat-icon>{{btn.display ?? btn.name}}\r\n      </button>\r\n    </ng-container>\r\n\r\n\r\n    <button mat-stroked-button color=\"primary\" mat-dialog-close>Cancel</button>\r\n\r\n  </div>\r\n\r\n  <div class=\"col d-flex justify-content-end\" *ngIf=\"smallScreen\">\r\n    <ng-container *ngFor=\"let btn of extraButtons\">\r\n      <button *ngIf=\"testVisible(details,btn.name)\" mat-icon-button [disabled]=\"isProcessing || testDisabled(details,btn.name)\" [ngStyle]=\"{'color': getButtonColor(btn, details)}\" (click)=\"custom(btn)\" cdkFocusInitial><mat-icon>{{btn.icon.name}}</mat-icon>\r\n      </button>\r\n    </ng-container>\r\n\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"]}
|
package/fesm2015/tin-spa.mjs
CHANGED
|
@@ -3305,9 +3305,9 @@ class DetailsDialogInternal {
|
|
|
3305
3305
|
this.buttons = buttons;
|
|
3306
3306
|
let resp = DetailsDialogProcessor.handleFormMode(this.detailsConfig, this.formConfig);
|
|
3307
3307
|
if (resp.loadByAction) {
|
|
3308
|
-
this.loadData(resp.action);
|
|
3309
3308
|
this.loadByAction = true;
|
|
3310
3309
|
formConfig.loadAction = resp.action;
|
|
3310
|
+
this.loadData(resp.action);
|
|
3311
3311
|
}
|
|
3312
3312
|
else {
|
|
3313
3313
|
this.details = resp.details;
|
|
@@ -3326,6 +3326,8 @@ class DetailsDialogInternal {
|
|
|
3326
3326
|
loadData(action) {
|
|
3327
3327
|
console.log("loading details");
|
|
3328
3328
|
if (action && this.loadByAction) {
|
|
3329
|
+
console.log("Loading action");
|
|
3330
|
+
console.log(action);
|
|
3329
3331
|
this.dataService.CallApi(action).subscribe((apiResponse) => {
|
|
3330
3332
|
if (apiResponse.success) {
|
|
3331
3333
|
this.details = apiResponse.data;
|
|
@@ -4127,9 +4129,9 @@ class DetailsDialog {
|
|
|
4127
4129
|
this.buttons = buttons;
|
|
4128
4130
|
let resp = DetailsDialogProcessor.handleFormMode(this.detailsConfig, this.formConfig);
|
|
4129
4131
|
if (resp.loadByAction) {
|
|
4130
|
-
this.loadData(resp.action, false);
|
|
4131
4132
|
this.loadByAction = true;
|
|
4132
4133
|
formConfig.loadAction = resp.action;
|
|
4134
|
+
this.loadData(resp.action, false);
|
|
4133
4135
|
}
|
|
4134
4136
|
else {
|
|
4135
4137
|
this.details = resp.details;
|
|
@@ -4154,6 +4156,8 @@ class DetailsDialog {
|
|
|
4154
4156
|
if (apiResponse.success) {
|
|
4155
4157
|
this.details = apiResponse.data;
|
|
4156
4158
|
this.isLoadComplete = true;
|
|
4159
|
+
if (reload)
|
|
4160
|
+
this.tableReload.next(true);
|
|
4157
4161
|
}
|
|
4158
4162
|
else {
|
|
4159
4163
|
this.messageService.toast("Error: " + apiResponse.message);
|