tin-spa 2.13.2 → 2.13.3
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 +16 -3
- package/esm2020/lib/components/table-internal/detailsDialog-internal.component.mjs +15 -2
- package/esm2020/lib/components/table-lite/detailsDialog-lite.component.mjs +15 -2
- package/fesm2015/tin-spa.mjs +43 -4
- package/fesm2015/tin-spa.mjs.map +1 -1
- package/fesm2020/tin-spa.mjs +43 -4
- package/fesm2020/tin-spa.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -336,10 +336,23 @@ export class DetailsDialog {
|
|
|
336
336
|
this.messageService.toast("Updated");
|
|
337
337
|
}
|
|
338
338
|
if (button.onSuccess) {
|
|
339
|
-
button.onSuccess(apiResponse, this.details);
|
|
339
|
+
button.onSuccess(apiResponse.data, this.details);
|
|
340
340
|
}
|
|
341
341
|
if (button.keepOpen) {
|
|
342
|
-
|
|
342
|
+
if (button.name === 'create' && apiResponse.data) {
|
|
343
|
+
this.details = apiResponse.data;
|
|
344
|
+
if (this.detailsConfig.heroField && apiResponse.data[this.detailsConfig.heroField]) {
|
|
345
|
+
this.detailsConfig.heroValue = apiResponse.data[this.detailsConfig.heroField];
|
|
346
|
+
this.formConfig.heroField = this.detailsConfig.heroField;
|
|
347
|
+
this.formConfig.heroValue = this.detailsConfig.heroValue;
|
|
348
|
+
}
|
|
349
|
+
this.formConfig.mode = 'edit';
|
|
350
|
+
this.setTitleAction();
|
|
351
|
+
this.isLoadComplete = true;
|
|
352
|
+
}
|
|
353
|
+
else {
|
|
354
|
+
this.refreshData();
|
|
355
|
+
}
|
|
343
356
|
}
|
|
344
357
|
else {
|
|
345
358
|
this.dialogRef.close({ message: 'success', data: { ...apiResponse, data: button.name == 'create' ? apiResponse.data : this.details } });
|
|
@@ -371,4 +384,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
371
384
|
type: Output
|
|
372
385
|
}] } });
|
|
373
386
|
;
|
|
374
|
-
//# 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, OnDestroy } from '@angular/core';\r\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\r\nimport { FormConfig, Field, TableConfig, Button, DetailsDialogConfig, Action, ApiResponse, StepConfig } from '../../classes/Classes';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { DataServiceLib } from '../../services/datalib.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, Subscription, config, interval } from 'rxjs';\r\nimport { ButtonService } from '../../services/button.service';\r\nimport { DialogService } from '../../services/dialog.service';\r\nimport { AuthService } from '../../services/auth.service';\r\nimport { TableConfigService } from '../../services/table-config.service';\r\nimport { MatTabChangeEvent } from '@angular/material/tabs';\r\n\r\n@Component({\r\n  selector: 'spa-detailsDialog',\r\n  templateUrl: './detailsDialog.component.html',\r\n  styleUrls: ['./table.component.css']\r\n})\r\nexport class DetailsDialog implements OnInit, OnDestroy {\r\n\r\n  constructor(private breakpointObserver: BreakpointObserver,private loaderService: LoaderService,public dataService: DataServiceLib,private messageService: MessageService,\r\n    private dialogRef: MatDialogRef<DetailsDialog>, @Inject(MAT_DIALOG_DATA) public detailsConfig: DetailsDialogConfig, private buttonService: ButtonService,\r\n    private dialogService: DialogService, private authService: AuthService, public tableConfigService: TableConfigService)\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, stepConfig, buttons } = DetailsDialogProcessor.initializeConfigs(this.detailsConfig);\r\n    this.tableConfig = tableConfig;\r\n    this.tableConfigs = tableConfigs;\r\n    this.formConfig = formConfig;\r\n    this.stepConfig = stepConfig;\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      DetailsDialogProcessor.setHeroValue(this.detailsConfig, this.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    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    this.initAutoRefresh();\r\n\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    // Cleanup subscription on component destroy\r\n    this.stopAutoRefresh();\r\n  }\r\n\r\n  private refreshSubscription: Subscription;\r\n  autoRefreshEnabled: boolean = false;\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 : TableConfig[]\r\n  details: any\r\n  formConfig: FormConfig;\r\n  stepConfig : StepConfig;\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  selectedTabIndex = 0;\r\n  onTabChange(event: MatTabChangeEvent) {\r\n    this.selectedTabIndex = event.index;\r\n  }\r\n\r\n  private initAutoRefresh() {\r\n    const config = this.detailsConfig.autoRefreshConfig;\r\n    if (!config) return;\r\n\r\n    // Set initial state based on defaultOn configuration\r\n    this.autoRefreshEnabled = config.defaultOn || false;\r\n\r\n    // Start auto-refresh if enabled by default\r\n    if (this.autoRefreshEnabled) {\r\n      this.startAutoRefresh();\r\n    }\r\n  }\r\n\r\n  private startAutoRefresh() {\r\n\r\n    if (!this.detailsConfig.autoRefreshConfig) return;\r\n    \r\n    const refreshInterval = this.detailsConfig.autoRefreshConfig.interval || 5000; // Default to 5 seconds\r\n    \r\n    // Clear any existing subscription\r\n    this.stopAutoRefresh();\r\n    \r\n    // Create new subscription\r\n    this.refreshSubscription = interval(refreshInterval).subscribe(() => {\r\n      if (this.isLoadComplete && !this.isProcessing) {\r\n        this.refreshData();\r\n      }\r\n    });\r\n  }\r\n\r\n  private stopAutoRefresh() {\r\n    if (this.refreshSubscription) {\r\n      this.refreshSubscription.unsubscribe();\r\n      this.refreshSubscription = null;\r\n    }\r\n  }\r\n\r\n  toggleAutoRefresh() {\r\n    // this.autoRefreshEnabled = !this.autoRefreshEnabled;\r\n    \r\n    if (this.autoRefreshEnabled) {\r\n      this.startAutoRefresh();\r\n    } else {\r\n      this.stopAutoRefresh();\r\n    }\r\n  }\r\n\r\n  loadData(action: Action, causeTablesReload) {\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          // DetailsDialogProcessor.setHeroValue(this.detailsConfig, this.details);\r\n          if(causeTablesReload) this.tableReload.next(true);\r\n\r\n          const config = this.detailsConfig.autoRefreshConfig;\r\n          if (this.autoRefreshEnabled && config?.stopCondition && config.stopCondition(this.details)) {\r\n            this.autoRefreshEnabled = false;\r\n            this.stopAutoRefresh();\r\n          }\r\n        }\r\n        else{\r\n          this.messageService.toast(\"Error: \" + apiResponse.message);\r\n\r\n          if (this.autoRefreshEnabled) {\r\n            this.autoRefreshEnabled = false;\r\n            this.stopAutoRefresh();\r\n          }\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){\r\n    this.formConfig.mode = newMode\r\n    this.setTitleAction()\r\n  }\r\n\r\n  setTitleAction(){\r\n    if (this.formConfig.fixedTitle) {\r\n      this.titleAction = \"\";\r\n      return;\r\n    }\r\n\r\n    this.titleAction = this.buttonService.getTitleAction(this.formConfig.mode, this.buttons);\r\n  }\r\n\r\n  getButton(name: string) {\r\n    return this.buttonService.getButton(this.buttons, name);\r\n  }\r\n\r\n  testDisabled(row, buttonName: string): boolean {\r\n    const button = this.getButton(buttonName);\r\n\r\n    if (!button) return false;\r\n\r\n    // Create a copy of the button with component's detailsConfig\r\n    const buttonWithConfig = {\r\n      ...button,\r\n      detailsConfig: button.detailsConfig ? { ...button.detailsConfig } : this.detailsConfig\r\n    };\r\n\r\n    return this.buttonService.testDisabled(buttonWithConfig, row);\r\n  }\r\n\r\n\r\n  testVisible(row, buttonName: string): boolean {\r\n    const button = this.getButton(buttonName);\r\n    if (!button) return false;\r\n\r\n    // Create a copy of the button with component's detailsConfig\r\n    const buttonWithConfig = {\r\n      ...button,\r\n      detailsConfig: button.detailsConfig ? { ...button.detailsConfig } : this.detailsConfig\r\n    };\r\n\r\n    return this.buttonService.testVisible(buttonWithConfig, row)\r\n  }\r\n\r\n  testVisibleTab(tblConfig: TableConfig): boolean {\r\n\r\n    if (!this.tableConfigService.hasTableAccess(tblConfig)) {\r\n      return false;\r\n    }\r\n\r\n    return this.buttonService.isTabVisible(tblConfig);\r\n  }\r\n\r\n  getButtonColor(button: Button, row) {\r\n    return this.buttonService.getButtonColor(button, row);\r\n  }\r\n\r\n  getVisibleFields() {\r\n    return this.formConfig.fields?.filter(x => Core.testVisible(this.formConfig, this.details, x, this.authService.currentRoleSource.value))\r\n  }\r\n\r\n\r\n  create() {\r\n    this.handleButtonAction('create');\r\n  }\r\n\r\n  edit() {\r\n    this.handleButtonAction('edit');\r\n  }\r\n\r\n  delete() {\r\n    const button = this.buttonService.getButton(this.buttons, 'delete');\r\n    if (!button) return;\r\n\r\n    let confirmMessage = this.buttonService.getConfirmMessage(button, this.details);\r\n    if (!confirmMessage) {\r\n      confirmMessage = `Are you sure you want to delete ?`;\r\n    }\r\n\r\n    this.messageService.confirm(confirmMessage).subscribe((result) => {\r\n      if (result == \"yes\") {\r\n        this.handleButtonAction('delete');\r\n      }\r\n    });\r\n  }\r\n\r\n\r\n  custom(button: Button ) {\r\n    if (button.dialog && button.detailsConfig) {\r\n      this.openNestedDetailsDialog(button);\r\n    } else {\r\n      this.handleButtonAction(button.name);\r\n    }\r\n  }\r\n\r\n  private openNestedDetailsDialog(button: Button): void {\r\n\r\n    this.dialogService.openConfiguredDetailsDialog( button, this.details, DetailsDialog ).subscribe(result => {\r\n\r\n      if (result.action === 'inputChange') {\r\n        this.inputChanged(result.change);\r\n      } else if (result && result.message === 'success') {\r\n        this.refreshData();\r\n      }\r\n\r\n    });\r\n  }\r\n\r\n  private refreshData(): void {\r\n    if (this.formConfig.loadAction) {\r\n      this.loadData(this.formConfig.loadAction, true);\r\n    }\r\n  }\r\n\r\n  handleButtonAction(buttonName: string) {\r\n    \r\n    const button = this.getButton(buttonName);\r\n    if (!button) return;\r\n   \r\n\r\n    if (button.onClick) {\r\n      button.onClick(this.details);\r\n    }\r\n\r\n    this.processButtonAction(button);\r\n  }\r\n\r\n  processButtonAction(button : Button) {\r\n    if (!button.action) {\r\n      this.dialogRef.close({ message: 'emit', data: this.details });\r\n      return;\r\n    }\r\n\r\n    if (this.validateForm()) {\r\n      this.executeAction(button, this.details);\r\n    }\r\n  }\r\n\r\n  private validateForm(): boolean {\r\n    let validationResult = Core.validateObject(this.getVisibleFields(), this.details);\r\n    if (validationResult !== '') {\r\n      this.messageService.toast(validationResult);\r\n      return false;\r\n    }\r\n\r\n    if (this.files.length < 1 && this.fileField?.required && this.formConfig.mode === 'create') {\r\n      this.messageService.toast(\"Please attach file(s)\");\r\n      return false;\r\n    }\r\n\r\n    // Validate composite fields\r\n    for (const field of this.getVisibleFields()) {\r\n      if (field.type === 'composite') {\r\n        validationResult = Core.validateObject(Core.getVisibleSubfields(this.formConfig, this.details, field, this.authService.currentRoleSource.value), this.details, );\r\n        if (validationResult !== '') {\r\n          this.messageService.toast(validationResult);\r\n          return false;\r\n        }\r\n      }\r\n    }\r\n\r\n    return true;\r\n  }\r\n\r\n  private prepareActionData(button: Button, data: any): any {\r\n    if (this.buttonService.isFormButton(button)) {\r\n      const 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      formData.append(\"data\", JSON.stringify(data));\r\n      return formData;\r\n    }\r\n    return data;\r\n  }\r\n\r\n  private executeAction(button: Button, data: any) {\r\n    const actionData = this.prepareActionData(button, data);\r\n\r\n    if (button.confirm) {\r\n      let confirmMessage = this.buttonService.getConfirmMessage(button, this.details);\r\n\r\n      if (!confirmMessage && button.name == 'delete') {\r\n        confirmMessage = `Are you sure you want to delete ?`;\r\n      }\r\n\r\n      this.messageService.confirm(confirmMessage).subscribe((result) => {\r\n        if (result == \"yes\") {\r\n          this.performApiCall(button, actionData);\r\n        }\r\n      });\r\n\r\n    } else {\r\n      this.performApiCall(button, actionData);\r\n    }\r\n\r\n  }\r\n\r\n  private performApiCall(button: Button, data: any) {\r\n    this.dataService.CallApi(button.action, data).subscribe((apiResponse: ApiResponse) => {\r\n\r\n      if (apiResponse.success) {\r\n\r\n        if (apiResponse.message.includes(\"approval\") || apiResponse.message.includes(\"approve\") || apiResponse.message.includes(\"decline\")) {\r\n          this.messageService.toast(apiResponse.message);\r\n        } else if (button.action.successMessage) {\r\n          this.messageService.toast(button.action.successMessage);\r\n        } else if (apiResponse.message != \"success\" && apiResponse.message != \"\") {\r\n          this.messageService.toast(apiResponse.message);\r\n        } else {\r\n          this.messageService.toast(\"Updated\");\r\n        }\r\n\r\n        if (button.onSuccess) {\r\n          button.onSuccess(apiResponse, this.details);\r\n        }\r\n\r\n        if (button.keepOpen) {\r\n          this.refreshData();\r\n        }else{\r\n          this.dialogRef.close({ message: 'success', data: { ...apiResponse, data: button.name == 'create' ? apiResponse.data : this.details  } });\r\n        }\r\n\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse.message);\r\n      }\r\n    });\r\n  }\r\n\r\n  close(){\r\n    if (this.detailsConfig.refreshOnClose){\r\n      this.dialogRef.close({ message: 'success', data: this.details });\r\n    }else{\r\n      this.dialogRef.close({ message: 'emit', data: this.details });\r\n    }\r\n  }\r\n  \r\n\r\n};\r\n","<div class=\"dialog-container\">\r\n\r\n  <div class=\"dialog-content\">\r\n\r\n    <mat-progress-bar mode=\"indeterminate\" *ngIf=\"isProcessing && dataService.appConfig.progressLine\"></mat-progress-bar>\r\n\r\n    <div class=\"d-flex justify-content-between align-items-center mt-2\">\r\n\r\n      <div>\r\n        <label style=\"font-size: 20px; font-weight:500;margin-bottom: 10px;\" >{{titleAction | titlecase}} {{formConfig?.title}}</label>\r\n      </div>\r\n\r\n      <div class=\"d-flex justify-content-between align-items-center\">\r\n\r\n        <spa-check *ngIf=\"detailsConfig.autoRefreshConfig\" display=\"Auto Refresh\" [(value)]=\"autoRefreshEnabled\" (valueChange)=\"toggleAutoRefresh()\"></spa-check>\r\n\r\n        <div *ngIf=\"formConfig.mode=='view' && editButton && testVisible(details,editButton.name)\">\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, detailsConfig.causeTableRefresh)\"><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 dialog-scroll-content\">\r\n\r\n      <spa-steps *ngIf=\"stepConfig && details\" [config]=\"stepConfig\" [data]=\"details\"></spa-steps>\r\n\r\n      <spa-alert [alertMessages]=\"formConfig.alertMessages\" [data]=\"details\"></spa-alert>\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)\">\r\n          <ng-template #dynamicSelect let-field=\"field\" let-data=\"data\" let-testReadOnly=\"testReadOnly\" let-selectChanged=\"selectChanged\">\r\n            <spa-select\r\n              [display]=\"field.alias ?? field.name | camelToWords\"\r\n              [width]=\"field.width\"\r\n              [nullable]=\"field.nullable\"\r\n              [options]=\"field.options\"\r\n              [masterOptions]=\"field.masterOptions\"\r\n              [masterField]=\"field.masterField\"\r\n              [optionDisplay]=\"field.optionDisplay ?? 'name'\"\r\n              [optionValue]=\"field.optionValue ?? 'value'\"\r\n              [(value)]=\"data[field.name]\"\r\n              [defaultFirstValue]=\"field.defaultFirstValue\"\r\n              [readonly]=\"testReadOnly(field)\"\r\n              [hint]=\"field.hint\"\r\n              [detailsConfig]=\"field.detailsConfig\"\r\n              [loadAction]=\"field.loadAction\"\r\n              [loadIDField]=\"field.loadIDField\"\r\n              [field]=\"field\"\r\n              [data]=\"data\"\r\n              [infoMessage]=\"field.infoMessage\"\r\n              [copyContent]=\"field.copyContent\"\r\n              (valueChange)=\"selectChanged(field)\"\r\n            ></spa-select>\r\n          </ng-template>\r\n        </spa-form>\r\n\r\n\r\n        <mat-tab-group *ngIf=\"tableConfigs\" (selectedTabChange)=\"onTabChange($event)\">\r\n\r\n          <ng-container *ngFor=\"let tbl of tableConfigService.getVisibleTableConfigs(tableConfigs) ; let i = index\">\r\n            <mat-tab *ngIf=\"testVisibleTab(tbl)\">\r\n\r\n              <ng-template matTabLabel>\r\n                <span>{{tbl.tabTitle ?? 'Untitled'}}</span>\r\n              </ng-template>\r\n\r\n              <spa-table-internal \r\n                [config]=\"tbl\" \r\n                [reload]=\"tableReload\" \r\n                [inTab]=\"true\"\r\n                [activeTab]=\"selectedTabIndex === i\"\r\n                (actionSuccess)=\"tbl.causeFormRefresh ? loadData(formConfig.loadAction, false) : null\">\r\n              </spa-table-internal>\r\n\r\n            </mat-tab>\r\n          </ng-container>\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\r\n  </div>\r\n\r\n  <mat-dialog-actions >\r\n\r\n    <div>\r\n\r\n      <button mat-raised-button [disabled]=\"isProcessing\" *ngIf=\"formConfig.mode=='create' && createButton\" color=\"primary\"\r\n        (click)=\"create()\" cdkFocusInitial>{{createButton.display ?? 'Submit'}}\r\n      </button>\r\n\r\n      <button mat-raised-button [disabled]=\"isProcessing\" *ngIf=\"formConfig.mode=='edit' && editButton\" color=\"primary\"\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=\"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 | titlecase}}\r\n        </button>\r\n      </ng-container>\r\n\r\n      <button mat-stroked-button color=\"primary\" (click)=\"close()\">Cancel</button>\r\n\r\n    </div>\r\n\r\n    <div class=\"col d-flex justify-content-end\" *ngIf=\"smallScreen\">\r\n      <button mat-icon-button matTooltipPosition=\"above\" matTooltip=\"Delete\" [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</div>\r\n\r\n\r\n\r\n\r\n\r\n\r\n"]}
|
|
387
|
+
//# 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":"AACA,OAAO,EAAE,SAAS,EAAU,MAAM,EAAE,MAAM,EAAE,YAAY,EAAa,MAAM,eAAe,CAAC;AAC3F,OAAO,EAAE,eAAe,EAAgB,MAAM,0BAA0B,CAAC;AAIzE,OAAO,EAAE,IAAI,EAAE,sBAAsB,EAAE,MAAM,uBAAuB,CAAC;AAGrE,OAAO,EAAE,OAAO,EAAwB,QAAQ,EAAE,MAAM,MAAM,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;AAY/D,MAAM,OAAO,aAAa;IAExB,YAAoB,kBAAsC,EAAS,aAA4B,EAAQ,WAA2B,EAAS,cAA8B,EAC/J,SAAsC,EAAkC,aAAkC,EAAU,aAA4B,EAChJ,aAA4B,EAAU,WAAwB,EAAS,kBAAsC;QAFnG,uBAAkB,GAAlB,kBAAkB,CAAoB;QAAS,kBAAa,GAAb,aAAa,CAAe;QAAQ,gBAAW,GAAX,WAAW,CAAgB;QAAS,mBAAc,GAAd,cAAc,CAAgB;QAC/J,cAAS,GAAT,SAAS,CAA6B;QAAkC,kBAAa,GAAb,aAAa,CAAqB;QAAU,kBAAa,GAAb,aAAa,CAAe;QAChJ,kBAAa,GAAb,aAAa,CAAe;QAAU,gBAAW,GAAX,WAAW,CAAa;QAAS,uBAAkB,GAAlB,kBAAkB,CAAoB;QAyDvH,uBAAkB,GAAY,KAAK,CAAC;QAEpC,gBAAW,GAAG,MAAM,CAAC;QACrB,iBAAY,GAAG,KAAK,CAAC;QAUrB,UAAK,GAAU,EAAE,CAAC;QAElB,gBAAW,GAAqB,IAAI,OAAO,EAAE,CAAC;QAO9C,gBAAW,GAAG,KAAK,CAAC;QAEpB,mBAAc,GAAY,KAAK,CAAC;QAChC,iBAAY,GAAY,KAAK,CAAC;QAEpB,gBAAW,GAAG,IAAI,YAAY,EAAE,CAAC;QAE3C,qBAAgB,GAAG,CAAC,CAAC;QApFnB,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,UAAU,EAAE,OAAO,EAAE,GAAG,sBAAsB,CAAC,iBAAiB,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QACpI,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;QACjC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,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,EAAC;YACpB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;YACzB,UAAU,CAAC,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC;YACpC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;SACnC;aAAI;YACH,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;YAC5B,sBAAsB,CAAC,YAAY,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;YACtE,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;QAEtE,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,CAAC;QACtB,IAAI,CAAC,eAAe,EAAE,CAAC;IAEzB,CAAC;IAED,WAAW;QACT,4CAA4C;QAC5C,IAAI,CAAC,eAAe,EAAE,CAAC;IACzB,CAAC;IAiCD,WAAW,CAAC,KAAwB;QAClC,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC,KAAK,CAAC;IACtC,CAAC;IAEO,eAAe;QACrB,MAAM,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC,iBAAiB,CAAC;QACpD,IAAI,CAAC,MAAM;YAAE,OAAO;QAEpB,qDAAqD;QACrD,IAAI,CAAC,kBAAkB,GAAG,MAAM,CAAC,SAAS,IAAI,KAAK,CAAC;QAEpD,2CAA2C;QAC3C,IAAI,IAAI,CAAC,kBAAkB,EAAE;YAC3B,IAAI,CAAC,gBAAgB,EAAE,CAAC;SACzB;IACH,CAAC;IAEO,gBAAgB;QAEtB,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,iBAAiB;YAAE,OAAO;QAElD,MAAM,eAAe,GAAG,IAAI,CAAC,aAAa,CAAC,iBAAiB,CAAC,QAAQ,IAAI,IAAI,CAAC,CAAC,uBAAuB;QAEtG,kCAAkC;QAClC,IAAI,CAAC,eAAe,EAAE,CAAC;QAEvB,0BAA0B;QAC1B,IAAI,CAAC,mBAAmB,GAAG,QAAQ,CAAC,eAAe,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YAClE,IAAI,IAAI,CAAC,cAAc,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;gBAC7C,IAAI,CAAC,WAAW,EAAE,CAAC;aACpB;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,eAAe;QACrB,IAAI,IAAI,CAAC,mBAAmB,EAAE;YAC5B,IAAI,CAAC,mBAAmB,CAAC,WAAW,EAAE,CAAC;YACvC,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;SACjC;IACH,CAAC;IAED,iBAAiB;QACf,sDAAsD;QAEtD,IAAI,IAAI,CAAC,kBAAkB,EAAE;YAC3B,IAAI,CAAC,gBAAgB,EAAE,CAAC;SACzB;aAAM;YACL,IAAI,CAAC,eAAe,EAAE,CAAC;SACxB;IACH,CAAC;IAED,QAAQ,CAAC,MAAc,EAAE,iBAAiB;QAExC,IAAI,MAAM,IAAI,IAAI,CAAC,YAAY,EAAE;YAE/B,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;oBAC3B,yEAAyE;oBACzE,IAAG,iBAAiB;wBAAE,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;oBAElD,MAAM,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC,iBAAiB,CAAC;oBACpD,IAAI,IAAI,CAAC,kBAAkB,IAAI,MAAM,EAAE,aAAa,IAAI,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE;wBAC1F,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;wBAChC,IAAI,CAAC,eAAe,EAAE,CAAC;qBACxB;iBACF;qBACG;oBACF,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,SAAS,GAAG,WAAW,CAAC,OAAO,CAAC,CAAC;oBAE3D,IAAI,IAAI,CAAC,kBAAkB,EAAE;wBAC3B,IAAI,CAAC,kBAAkB,GAAG,KAAK,CAAC;wBAChC,IAAI,CAAC,eAAe,EAAE,CAAC;qBACxB;iBACF;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,OAAO;QACb,IAAI,CAAC,UAAU,CAAC,IAAI,GAAG,OAAO,CAAA;QAC9B,IAAI,CAAC,cAAc,EAAE,CAAA;IACvB,CAAC;IAED,cAAc;QACZ,IAAI,IAAI,CAAC,UAAU,CAAC,UAAU,EAAE;YAC9B,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;YACtB,OAAO;SACR;QAED,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;IAC3F,CAAC;IAED,SAAS,CAAC,IAAY;QACpB,OAAO,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;IAC1D,CAAC;IAED,YAAY,CAAC,GAAG,EAAE,UAAkB;QAClC,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QAE1C,IAAI,CAAC,MAAM;YAAE,OAAO,KAAK,CAAC;QAE1B,6DAA6D;QAC7D,MAAM,gBAAgB,GAAG;YACvB,GAAG,MAAM;YACT,aAAa,EAAE,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,GAAG,MAAM,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa;SACvF,CAAC;QAEF,OAAO,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,gBAAgB,EAAE,GAAG,CAAC,CAAC;IAChE,CAAC;IAGD,WAAW,CAAC,GAAG,EAAE,UAAkB;QACjC,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QAC1C,IAAI,CAAC,MAAM;YAAE,OAAO,KAAK,CAAC;QAE1B,6DAA6D;QAC7D,MAAM,gBAAgB,GAAG;YACvB,GAAG,MAAM;YACT,aAAa,EAAE,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,GAAG,MAAM,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa;SACvF,CAAC;QAEF,OAAO,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,gBAAgB,EAAE,GAAG,CAAC,CAAA;IAC9D,CAAC;IAED,cAAc,CAAC,SAAsB;QAEnC,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC,cAAc,CAAC,SAAS,CAAC,EAAE;YACtD,OAAO,KAAK,CAAC;SACd;QAED,OAAO,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;IACpD,CAAC;IAED,cAAc,CAAC,MAAc,EAAE,GAAG;QAChC,OAAO,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IACxD,CAAC;IAED,gBAAgB;QACd,OAAO,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,EAAE,IAAI,CAAC,WAAW,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC,CAAA;IAC1I,CAAC;IAGD,MAAM;QACJ,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC;IACpC,CAAC;IAED,IAAI;QACF,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC;IAClC,CAAC;IAED,MAAM;QACJ,MAAM,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC;QACpE,IAAI,CAAC,MAAM;YAAE,OAAO;QAEpB,IAAI,cAAc,GAAG,IAAI,CAAC,aAAa,CAAC,iBAAiB,CAAC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;QAChF,IAAI,CAAC,cAAc,EAAE;YACnB,cAAc,GAAG,mCAAmC,CAAC;SACtD;QAED,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YAC/D,IAAI,MAAM,IAAI,KAAK,EAAE;gBACnB,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC;aACnC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAGD,MAAM,CAAC,MAAc;QACnB,IAAI,MAAM,CAAC,MAAM,IAAI,MAAM,CAAC,aAAa,EAAE;YACzC,IAAI,CAAC,uBAAuB,CAAC,MAAM,CAAC,CAAC;SACtC;aAAM;YACL,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;SACtC;IACH,CAAC;IAEO,uBAAuB,CAAC,MAAc;QAE5C,IAAI,CAAC,aAAa,CAAC,2BAA2B,CAAE,MAAM,EAAE,IAAI,CAAC,OAAO,EAAE,aAAa,CAAE,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE;YAEvG,IAAI,MAAM,CAAC,MAAM,KAAK,aAAa,EAAE;gBACnC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;aAClC;iBAAM,IAAI,MAAM,IAAI,MAAM,CAAC,OAAO,KAAK,SAAS,EAAE;gBACjD,IAAI,CAAC,WAAW,EAAE,CAAC;aACpB;QAEH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,WAAW;QACjB,IAAI,IAAI,CAAC,UAAU,CAAC,UAAU,EAAE;YAC9B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC;SACjD;IACH,CAAC;IAED,kBAAkB,CAAC,UAAkB;QAEnC,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QAC1C,IAAI,CAAC,MAAM;YAAE,OAAO;QAGpB,IAAI,MAAM,CAAC,OAAO,EAAE;YAClB,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;SAC9B;QAED,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC;IACnC,CAAC;IAED,mBAAmB,CAAC,MAAe;QACjC,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE;YAClB,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;YAC9D,OAAO;SACR;QAED,IAAI,IAAI,CAAC,YAAY,EAAE,EAAE;YACvB,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;SAC1C;IACH,CAAC;IAEO,YAAY;QAClB,IAAI,gBAAgB,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,gBAAgB,EAAE,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;QAClF,IAAI,gBAAgB,KAAK,EAAE,EAAE;YAC3B,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAC;YAC5C,OAAO,KAAK,CAAC;SACd;QAED,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,SAAS,EAAE,QAAQ,IAAI,IAAI,CAAC,UAAU,CAAC,IAAI,KAAK,QAAQ,EAAE;YAC1F,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,uBAAuB,CAAC,CAAC;YACnD,OAAO,KAAK,CAAC;SACd;QAED,4BAA4B;QAC5B,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,gBAAgB,EAAE,EAAE;YAC3C,IAAI,KAAK,CAAC,IAAI,KAAK,WAAW,EAAE;gBAC9B,gBAAgB,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,OAAO,EAAE,KAAK,EAAE,IAAI,CAAC,WAAW,CAAC,iBAAiB,CAAC,KAAK,CAAC,EAAE,IAAI,CAAC,OAAO,CAAG,CAAC;gBACjK,IAAI,gBAAgB,KAAK,EAAE,EAAE;oBAC3B,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAC;oBAC5C,OAAO,KAAK,CAAC;iBACd;aACF;SACF;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAEO,iBAAiB,CAAC,MAAc,EAAE,IAAS;QACjD,IAAI,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,MAAM,CAAC,EAAE;YAC3C,MAAM,QAAQ,GAAG,IAAI,QAAQ,EAAE,CAAC;YAChC,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;YACD,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC;YAC9C,OAAO,QAAQ,CAAC;SACjB;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAEO,aAAa,CAAC,MAAc,EAAE,IAAS;QAC7C,MAAM,UAAU,GAAG,IAAI,CAAC,iBAAiB,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QAExD,IAAI,MAAM,CAAC,OAAO,EAAE;YAClB,IAAI,cAAc,GAAG,IAAI,CAAC,aAAa,CAAC,iBAAiB,CAAC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;YAEhF,IAAI,CAAC,cAAc,IAAI,MAAM,CAAC,IAAI,IAAI,QAAQ,EAAE;gBAC9C,cAAc,GAAG,mCAAmC,CAAC;aACtD;YAED,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;gBAC/D,IAAI,MAAM,IAAI,KAAK,EAAE;oBACnB,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;iBACzC;YACH,CAAC,CAAC,CAAC;SAEJ;aAAM;YACL,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;SACzC;IAEH,CAAC;IAEO,cAAc,CAAC,MAAc,EAAE,IAAS;QAC9C,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,SAAS,CAAC,CAAC,WAAwB,EAAE,EAAE;YAEnF,IAAI,WAAW,CAAC,OAAO,EAAE;gBAEvB,IAAI,WAAW,CAAC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAC,IAAI,WAAW,CAAC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,WAAW,CAAC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAC,EAAE;oBAClI,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;iBAChD;qBAAM,IAAI,MAAM,CAAC,MAAM,CAAC,cAAc,EAAE;oBACvC,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC;iBACzD;qBAAM,IAAI,WAAW,CAAC,OAAO,IAAI,SAAS,IAAI,WAAW,CAAC,OAAO,IAAI,EAAE,EAAE;oBACxE,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;iBAChD;qBAAM;oBACL,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;iBACtC;gBAED,IAAI,MAAM,CAAC,SAAS,EAAE;oBACpB,MAAM,CAAC,SAAS,CAAC,WAAW,CAAC,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;iBAClD;gBAED,IAAI,MAAM,CAAC,QAAQ,EAAE;oBACnB,IAAI,MAAM,CAAC,IAAI,KAAK,QAAQ,IAAI,WAAW,CAAC,IAAI,EAAE;wBAChD,IAAI,CAAC,OAAO,GAAG,WAAW,CAAC,IAAI,CAAC;wBAEhC,IAAI,IAAI,CAAC,aAAa,CAAC,SAAS,IAAI,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,EAAE;4BAClF,IAAI,CAAC,aAAa,CAAC,SAAS,GAAG,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;4BAC9E,IAAI,CAAC,UAAU,CAAC,SAAS,GAAG,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC;4BACzD,IAAI,CAAC,UAAU,CAAC,SAAS,GAAG,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC;yBAC1D;wBAED,IAAI,CAAC,UAAU,CAAC,IAAI,GAAG,MAAM,CAAC;wBAC9B,IAAI,CAAC,cAAc,EAAE,CAAC;wBACtB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;qBAE5B;yBAAM;wBACL,IAAI,CAAC,WAAW,EAAE,CAAC;qBACpB;iBACF;qBAAI;oBACH,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,EAAE,GAAG,WAAW,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,IAAI,QAAQ,CAAC,CAAC,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,EAAG,EAAE,CAAC,CAAC;iBAC1I;aAEF;iBAAM;gBACL,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,SAAS,GAAG,WAAW,CAAC,OAAO,CAAC,CAAC;aAC5D;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,KAAK;QACH,IAAI,IAAI,CAAC,aAAa,CAAC,cAAc,EAAC;YACpC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;SAClE;aAAI;YACH,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;SAC/D;IACH,CAAC;;0GA/aU,aAAa,yKAGkC,eAAe;8FAH9D,aAAa,kGCrB1B,kpLAkIA;2FD7Ga,aAAa;kBALzB,SAAS;+BACE,mBAAmB;;0BAOsB,MAAM;2BAAC,eAAe;+JAqF/D,WAAW;sBAApB,MAAM;;AA0VR,CAAC","sourcesContent":["\r\nimport { Component, OnInit, Inject, Output, EventEmitter, OnDestroy } from '@angular/core';\r\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\r\nimport { FormConfig, Field, TableConfig, Button, DetailsDialogConfig, Action, ApiResponse, StepConfig } from '../../classes/Classes';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { DataServiceLib } from '../../services/datalib.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, Subscription, config, interval } from 'rxjs';\r\nimport { ButtonService } from '../../services/button.service';\r\nimport { DialogService } from '../../services/dialog.service';\r\nimport { AuthService } from '../../services/auth.service';\r\nimport { TableConfigService } from '../../services/table-config.service';\r\nimport { MatTabChangeEvent } from '@angular/material/tabs';\r\n\r\n@Component({\r\n  selector: 'spa-detailsDialog',\r\n  templateUrl: './detailsDialog.component.html',\r\n  styleUrls: ['./table.component.css']\r\n})\r\nexport class DetailsDialog implements OnInit, OnDestroy {\r\n\r\n  constructor(private breakpointObserver: BreakpointObserver,private loaderService: LoaderService,public dataService: DataServiceLib,private messageService: MessageService,\r\n    private dialogRef: MatDialogRef<DetailsDialog>, @Inject(MAT_DIALOG_DATA) public detailsConfig: DetailsDialogConfig, private buttonService: ButtonService,\r\n    private dialogService: DialogService, private authService: AuthService, public tableConfigService: TableConfigService)\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, stepConfig, buttons } = DetailsDialogProcessor.initializeConfigs(this.detailsConfig);\r\n    this.tableConfig = tableConfig;\r\n    this.tableConfigs = tableConfigs;\r\n    this.formConfig = formConfig;\r\n    this.stepConfig = stepConfig;\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      DetailsDialogProcessor.setHeroValue(this.detailsConfig, this.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    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    this.initAutoRefresh();\r\n\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    // Cleanup subscription on component destroy\r\n    this.stopAutoRefresh();\r\n  }\r\n\r\n  private refreshSubscription: Subscription;\r\n  autoRefreshEnabled: boolean = false;\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 : TableConfig[]\r\n  details: any\r\n  formConfig: FormConfig;\r\n  stepConfig : StepConfig;\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  selectedTabIndex = 0;\r\n  onTabChange(event: MatTabChangeEvent) {\r\n    this.selectedTabIndex = event.index;\r\n  }\r\n\r\n  private initAutoRefresh() {\r\n    const config = this.detailsConfig.autoRefreshConfig;\r\n    if (!config) return;\r\n\r\n    // Set initial state based on defaultOn configuration\r\n    this.autoRefreshEnabled = config.defaultOn || false;\r\n\r\n    // Start auto-refresh if enabled by default\r\n    if (this.autoRefreshEnabled) {\r\n      this.startAutoRefresh();\r\n    }\r\n  }\r\n\r\n  private startAutoRefresh() {\r\n\r\n    if (!this.detailsConfig.autoRefreshConfig) return;\r\n    \r\n    const refreshInterval = this.detailsConfig.autoRefreshConfig.interval || 5000; // Default to 5 seconds\r\n    \r\n    // Clear any existing subscription\r\n    this.stopAutoRefresh();\r\n    \r\n    // Create new subscription\r\n    this.refreshSubscription = interval(refreshInterval).subscribe(() => {\r\n      if (this.isLoadComplete && !this.isProcessing) {\r\n        this.refreshData();\r\n      }\r\n    });\r\n  }\r\n\r\n  private stopAutoRefresh() {\r\n    if (this.refreshSubscription) {\r\n      this.refreshSubscription.unsubscribe();\r\n      this.refreshSubscription = null;\r\n    }\r\n  }\r\n\r\n  toggleAutoRefresh() {\r\n    // this.autoRefreshEnabled = !this.autoRefreshEnabled;\r\n    \r\n    if (this.autoRefreshEnabled) {\r\n      this.startAutoRefresh();\r\n    } else {\r\n      this.stopAutoRefresh();\r\n    }\r\n  }\r\n\r\n  loadData(action: Action, causeTablesReload) {\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          // DetailsDialogProcessor.setHeroValue(this.detailsConfig, this.details);\r\n          if(causeTablesReload) this.tableReload.next(true);\r\n\r\n          const config = this.detailsConfig.autoRefreshConfig;\r\n          if (this.autoRefreshEnabled && config?.stopCondition && config.stopCondition(this.details)) {\r\n            this.autoRefreshEnabled = false;\r\n            this.stopAutoRefresh();\r\n          }\r\n        }\r\n        else{\r\n          this.messageService.toast(\"Error: \" + apiResponse.message);\r\n\r\n          if (this.autoRefreshEnabled) {\r\n            this.autoRefreshEnabled = false;\r\n            this.stopAutoRefresh();\r\n          }\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){\r\n    this.formConfig.mode = newMode\r\n    this.setTitleAction()\r\n  }\r\n\r\n  setTitleAction(){\r\n    if (this.formConfig.fixedTitle) {\r\n      this.titleAction = \"\";\r\n      return;\r\n    }\r\n\r\n    this.titleAction = this.buttonService.getTitleAction(this.formConfig.mode, this.buttons);\r\n  }\r\n\r\n  getButton(name: string) {\r\n    return this.buttonService.getButton(this.buttons, name);\r\n  }\r\n\r\n  testDisabled(row, buttonName: string): boolean {\r\n    const button = this.getButton(buttonName);\r\n\r\n    if (!button) return false;\r\n\r\n    // Create a copy of the button with component's detailsConfig\r\n    const buttonWithConfig = {\r\n      ...button,\r\n      detailsConfig: button.detailsConfig ? { ...button.detailsConfig } : this.detailsConfig\r\n    };\r\n\r\n    return this.buttonService.testDisabled(buttonWithConfig, row);\r\n  }\r\n\r\n\r\n  testVisible(row, buttonName: string): boolean {\r\n    const button = this.getButton(buttonName);\r\n    if (!button) return false;\r\n\r\n    // Create a copy of the button with component's detailsConfig\r\n    const buttonWithConfig = {\r\n      ...button,\r\n      detailsConfig: button.detailsConfig ? { ...button.detailsConfig } : this.detailsConfig\r\n    };\r\n\r\n    return this.buttonService.testVisible(buttonWithConfig, row)\r\n  }\r\n\r\n  testVisibleTab(tblConfig: TableConfig): boolean {\r\n\r\n    if (!this.tableConfigService.hasTableAccess(tblConfig)) {\r\n      return false;\r\n    }\r\n\r\n    return this.buttonService.isTabVisible(tblConfig);\r\n  }\r\n\r\n  getButtonColor(button: Button, row) {\r\n    return this.buttonService.getButtonColor(button, row);\r\n  }\r\n\r\n  getVisibleFields() {\r\n    return this.formConfig.fields?.filter(x => Core.testVisible(this.formConfig, this.details, x, this.authService.currentRoleSource.value))\r\n  }\r\n\r\n\r\n  create() {\r\n    this.handleButtonAction('create');\r\n  }\r\n\r\n  edit() {\r\n    this.handleButtonAction('edit');\r\n  }\r\n\r\n  delete() {\r\n    const button = this.buttonService.getButton(this.buttons, 'delete');\r\n    if (!button) return;\r\n\r\n    let confirmMessage = this.buttonService.getConfirmMessage(button, this.details);\r\n    if (!confirmMessage) {\r\n      confirmMessage = `Are you sure you want to delete ?`;\r\n    }\r\n\r\n    this.messageService.confirm(confirmMessage).subscribe((result) => {\r\n      if (result == \"yes\") {\r\n        this.handleButtonAction('delete');\r\n      }\r\n    });\r\n  }\r\n\r\n\r\n  custom(button: Button ) {\r\n    if (button.dialog && button.detailsConfig) {\r\n      this.openNestedDetailsDialog(button);\r\n    } else {\r\n      this.handleButtonAction(button.name);\r\n    }\r\n  }\r\n\r\n  private openNestedDetailsDialog(button: Button): void {\r\n\r\n    this.dialogService.openConfiguredDetailsDialog( button, this.details, DetailsDialog ).subscribe(result => {\r\n\r\n      if (result.action === 'inputChange') {\r\n        this.inputChanged(result.change);\r\n      } else if (result && result.message === 'success') {\r\n        this.refreshData();\r\n      }\r\n\r\n    });\r\n  }\r\n\r\n  private refreshData(): void {\r\n    if (this.formConfig.loadAction) {\r\n      this.loadData(this.formConfig.loadAction, true);\r\n    }\r\n  }\r\n\r\n  handleButtonAction(buttonName: string) {\r\n    \r\n    const button = this.getButton(buttonName);\r\n    if (!button) return;\r\n   \r\n\r\n    if (button.onClick) {\r\n      button.onClick(this.details);\r\n    }\r\n\r\n    this.processButtonAction(button);\r\n  }\r\n\r\n  processButtonAction(button : Button) {\r\n    if (!button.action) {\r\n      this.dialogRef.close({ message: 'emit', data: this.details });\r\n      return;\r\n    }\r\n\r\n    if (this.validateForm()) {\r\n      this.executeAction(button, this.details);\r\n    }\r\n  }\r\n\r\n  private validateForm(): boolean {\r\n    let validationResult = Core.validateObject(this.getVisibleFields(), this.details);\r\n    if (validationResult !== '') {\r\n      this.messageService.toast(validationResult);\r\n      return false;\r\n    }\r\n\r\n    if (this.files.length < 1 && this.fileField?.required && this.formConfig.mode === 'create') {\r\n      this.messageService.toast(\"Please attach file(s)\");\r\n      return false;\r\n    }\r\n\r\n    // Validate composite fields\r\n    for (const field of this.getVisibleFields()) {\r\n      if (field.type === 'composite') {\r\n        validationResult = Core.validateObject(Core.getVisibleSubfields(this.formConfig, this.details, field, this.authService.currentRoleSource.value), this.details, );\r\n        if (validationResult !== '') {\r\n          this.messageService.toast(validationResult);\r\n          return false;\r\n        }\r\n      }\r\n    }\r\n\r\n    return true;\r\n  }\r\n\r\n  private prepareActionData(button: Button, data: any): any {\r\n    if (this.buttonService.isFormButton(button)) {\r\n      const 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      formData.append(\"data\", JSON.stringify(data));\r\n      return formData;\r\n    }\r\n    return data;\r\n  }\r\n\r\n  private executeAction(button: Button, data: any) {\r\n    const actionData = this.prepareActionData(button, data);\r\n\r\n    if (button.confirm) {\r\n      let confirmMessage = this.buttonService.getConfirmMessage(button, this.details);\r\n\r\n      if (!confirmMessage && button.name == 'delete') {\r\n        confirmMessage = `Are you sure you want to delete ?`;\r\n      }\r\n\r\n      this.messageService.confirm(confirmMessage).subscribe((result) => {\r\n        if (result == \"yes\") {\r\n          this.performApiCall(button, actionData);\r\n        }\r\n      });\r\n\r\n    } else {\r\n      this.performApiCall(button, actionData);\r\n    }\r\n\r\n  }\r\n\r\n  private performApiCall(button: Button, data: any) {\r\n    this.dataService.CallApi(button.action, data).subscribe((apiResponse: ApiResponse) => {\r\n\r\n      if (apiResponse.success) {\r\n\r\n        if (apiResponse.message.includes(\"approval\") || apiResponse.message.includes(\"approve\") || apiResponse.message.includes(\"decline\")) {\r\n          this.messageService.toast(apiResponse.message);\r\n        } else if (button.action.successMessage) {\r\n          this.messageService.toast(button.action.successMessage);\r\n        } else if (apiResponse.message != \"success\" && apiResponse.message != \"\") {\r\n          this.messageService.toast(apiResponse.message);\r\n        } else {\r\n          this.messageService.toast(\"Updated\");\r\n        }\r\n\r\n        if (button.onSuccess) {\r\n          button.onSuccess(apiResponse.data, this.details);\r\n        }\r\n\r\n        if (button.keepOpen) {\r\n          if (button.name === 'create' && apiResponse.data) {\r\n            this.details = apiResponse.data;\r\n            \r\n            if (this.detailsConfig.heroField && apiResponse.data[this.detailsConfig.heroField]) {\r\n              this.detailsConfig.heroValue = apiResponse.data[this.detailsConfig.heroField];\r\n              this.formConfig.heroField = this.detailsConfig.heroField;\r\n              this.formConfig.heroValue = this.detailsConfig.heroValue;\r\n            }\r\n            \r\n            this.formConfig.mode = 'edit';\r\n            this.setTitleAction();\r\n            this.isLoadComplete = true;\r\n            \r\n          } else {\r\n            this.refreshData();\r\n          }\r\n        }else{\r\n          this.dialogRef.close({ message: 'success', data: { ...apiResponse, data: button.name == 'create' ? apiResponse.data : this.details  } });\r\n        }\r\n        \r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse.message);\r\n      }\r\n    });\r\n  }\r\n\r\n  close(){\r\n    if (this.detailsConfig.refreshOnClose){\r\n      this.dialogRef.close({ message: 'success', data: this.details });\r\n    }else{\r\n      this.dialogRef.close({ message: 'emit', data: this.details });\r\n    }\r\n  }\r\n  \r\n\r\n};\r\n","<div class=\"dialog-container\">\r\n\r\n  <div class=\"dialog-content\">\r\n\r\n    <mat-progress-bar mode=\"indeterminate\" *ngIf=\"isProcessing && dataService.appConfig.progressLine\"></mat-progress-bar>\r\n\r\n    <div class=\"d-flex justify-content-between align-items-center mt-2\">\r\n\r\n      <div>\r\n        <label style=\"font-size: 20px; font-weight:500;margin-bottom: 10px;\" >{{titleAction | titlecase}} {{formConfig?.title}}</label>\r\n      </div>\r\n\r\n      <div class=\"d-flex justify-content-between align-items-center\">\r\n\r\n        <spa-check *ngIf=\"detailsConfig.autoRefreshConfig\" display=\"Auto Refresh\" [(value)]=\"autoRefreshEnabled\" (valueChange)=\"toggleAutoRefresh()\"></spa-check>\r\n\r\n        <div *ngIf=\"formConfig.mode=='view' && editButton && testVisible(details,editButton.name)\">\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, detailsConfig.causeTableRefresh)\"><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 dialog-scroll-content\">\r\n\r\n      <spa-steps *ngIf=\"stepConfig && details\" [config]=\"stepConfig\" [data]=\"details\"></spa-steps>\r\n\r\n      <spa-alert [alertMessages]=\"formConfig.alertMessages\" [data]=\"details\"></spa-alert>\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)\">\r\n          <ng-template #dynamicSelect let-field=\"field\" let-data=\"data\" let-testReadOnly=\"testReadOnly\" let-selectChanged=\"selectChanged\">\r\n            <spa-select\r\n              [display]=\"field.alias ?? field.name | camelToWords\"\r\n              [width]=\"field.width\"\r\n              [nullable]=\"field.nullable\"\r\n              [options]=\"field.options\"\r\n              [masterOptions]=\"field.masterOptions\"\r\n              [masterField]=\"field.masterField\"\r\n              [optionDisplay]=\"field.optionDisplay ?? 'name'\"\r\n              [optionValue]=\"field.optionValue ?? 'value'\"\r\n              [(value)]=\"data[field.name]\"\r\n              [defaultFirstValue]=\"field.defaultFirstValue\"\r\n              [readonly]=\"testReadOnly(field)\"\r\n              [hint]=\"field.hint\"\r\n              [detailsConfig]=\"field.detailsConfig\"\r\n              [loadAction]=\"field.loadAction\"\r\n              [loadIDField]=\"field.loadIDField\"\r\n              [field]=\"field\"\r\n              [data]=\"data\"\r\n              [infoMessage]=\"field.infoMessage\"\r\n              [copyContent]=\"field.copyContent\"\r\n              (valueChange)=\"selectChanged(field)\"\r\n            ></spa-select>\r\n          </ng-template>\r\n        </spa-form>\r\n\r\n\r\n        <mat-tab-group *ngIf=\"tableConfigs\" (selectedTabChange)=\"onTabChange($event)\">\r\n\r\n          <ng-container *ngFor=\"let tbl of tableConfigService.getVisibleTableConfigs(tableConfigs) ; let i = index\">\r\n            <mat-tab *ngIf=\"testVisibleTab(tbl)\">\r\n\r\n              <ng-template matTabLabel>\r\n                <span>{{tbl.tabTitle ?? 'Untitled'}}</span>\r\n              </ng-template>\r\n\r\n              <spa-table-internal \r\n                [config]=\"tbl\" \r\n                [reload]=\"tableReload\" \r\n                [inTab]=\"true\"\r\n                [activeTab]=\"selectedTabIndex === i\"\r\n                (actionSuccess)=\"tbl.causeFormRefresh ? loadData(formConfig.loadAction, false) : null\">\r\n              </spa-table-internal>\r\n\r\n            </mat-tab>\r\n          </ng-container>\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\r\n  </div>\r\n\r\n  <mat-dialog-actions >\r\n\r\n    <div>\r\n\r\n      <button mat-raised-button [disabled]=\"isProcessing\" *ngIf=\"formConfig.mode=='create' && createButton\" color=\"primary\"\r\n        (click)=\"create()\" cdkFocusInitial>{{createButton.display ?? 'Submit'}}\r\n      </button>\r\n\r\n      <button mat-raised-button [disabled]=\"isProcessing\" *ngIf=\"formConfig.mode=='edit' && editButton\" color=\"primary\"\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=\"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 | titlecase}}\r\n        </button>\r\n      </ng-container>\r\n\r\n      <button mat-stroked-button color=\"primary\" (click)=\"close()\">Cancel</button>\r\n\r\n    </div>\r\n\r\n    <div class=\"col d-flex justify-content-end\" *ngIf=\"smallScreen\">\r\n      <button mat-icon-button matTooltipPosition=\"above\" matTooltip=\"Delete\" [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</div>\r\n\r\n\r\n\r\n\r\n\r\n\r\n"]}
|
|
@@ -339,7 +339,20 @@ export class DetailsDialogInternal {
|
|
|
339
339
|
button.onSuccess(apiResponse.data, this.details);
|
|
340
340
|
}
|
|
341
341
|
if (button.keepOpen) {
|
|
342
|
-
|
|
342
|
+
if (button.name === 'create' && apiResponse.data) {
|
|
343
|
+
this.details = apiResponse.data;
|
|
344
|
+
if (this.detailsConfig.heroField && apiResponse.data[this.detailsConfig.heroField]) {
|
|
345
|
+
this.detailsConfig.heroValue = apiResponse.data[this.detailsConfig.heroField];
|
|
346
|
+
this.formConfig.heroField = this.detailsConfig.heroField;
|
|
347
|
+
this.formConfig.heroValue = this.detailsConfig.heroValue;
|
|
348
|
+
}
|
|
349
|
+
this.formConfig.mode = 'edit';
|
|
350
|
+
this.setTitleAction();
|
|
351
|
+
this.isLoadComplete = true;
|
|
352
|
+
}
|
|
353
|
+
else {
|
|
354
|
+
this.refreshData();
|
|
355
|
+
}
|
|
343
356
|
}
|
|
344
357
|
else {
|
|
345
358
|
this.dialogRef.close({ message: 'success', data: { ...apiResponse, data: button.name == 'create' ? apiResponse.data : this.details } });
|
|
@@ -371,4 +384,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
371
384
|
type: Output
|
|
372
385
|
}] } });
|
|
373
386
|
;
|
|
374
|
-
//# 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, OnDestroy } from '@angular/core';\r\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\r\nimport { FormConfig, Field, TableConfig, Button, DetailsDialogConfig, Action, ApiResponse, StepConfig } from '../../classes/Classes';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { DataServiceLib } from '../../services/datalib.service';\r\nimport { LoaderService } from '../../services/loader.service';\r\nimport { BreakpointObserver, BreakpointState } from '@angular/cdk/layout';\r\nimport { Core, DetailsDialogProcessor } from '../../classes/TinCore';\r\nimport { DialogService } from '../../services/dialog.service';\r\nimport { ButtonService } from '../../services/button.service';\r\nimport { interval, Subject, Subscription } from 'rxjs';\r\nimport { AuthService } from '../../services/auth.service';\r\nimport { TableConfigService } from '../../services/table-config.service';\r\nimport { MatTabChangeEvent } from '@angular/material/tabs';\r\n\r\n@Component({\r\n  selector: 'spa-detailsDialog-internal', //uniq to internal\r\n  templateUrl: './detailsDialog-internal.component.html',\r\n  styleUrls: ['./table-internal.component.css']\r\n})\r\nexport class DetailsDialogInternal implements OnInit, OnDestroy {\r\n\r\n  constructor(private breakpointObserver: BreakpointObserver,private loaderService: LoaderService,public dataService: DataServiceLib,private messageService: MessageService,\r\n    private dialogRef: MatDialogRef<DetailsDialogInternal>, @Inject(MAT_DIALOG_DATA) public detailsConfig: DetailsDialogConfig, private buttonService: ButtonService,\r\n    private dialogService: DialogService, private authService: AuthService, public tableConfigService: TableConfigService)\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, stepConfig, buttons } = DetailsDialogProcessor.initializeConfigs(this.detailsConfig);\r\n    this.tableConfig = tableConfig;\r\n    this.tableConfigs = tableConfigs;\r\n    this.formConfig = formConfig;\r\n    this.stepConfig = stepConfig;\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      DetailsDialogProcessor.setHeroValue(this.detailsConfig, this.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    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    this.initAutoRefresh();\r\n\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    // Cleanup subscription on component destroy\r\n    this.stopAutoRefresh();\r\n  }\r\n\r\n  private refreshSubscription: Subscription;\r\n  autoRefreshEnabled: boolean = false;\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 : TableConfig[]\r\n  details: any\r\n  formConfig: FormConfig;\r\n  stepConfig: StepConfig;\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  selectedTabIndex = 0;\r\n  onTabChange(event: MatTabChangeEvent) {\r\n    this.selectedTabIndex = event.index;\r\n  }\r\n\r\n  private initAutoRefresh() {\r\n    const config = this.detailsConfig.autoRefreshConfig;\r\n    if (!config) return;\r\n\r\n    // Set initial state based on defaultOn configuration\r\n    this.autoRefreshEnabled = config.defaultOn || false;\r\n\r\n    // Start auto-refresh if enabled by default\r\n    if (this.autoRefreshEnabled) {\r\n      this.startAutoRefresh();\r\n    }\r\n  }\r\n\r\n  private startAutoRefresh() {\r\n\r\n    if (!this.detailsConfig.autoRefreshConfig) return;\r\n    \r\n    const refreshInterval = this.detailsConfig.autoRefreshConfig.interval || 5000; // Default to 5 seconds\r\n    \r\n    // Clear any existing subscription\r\n    this.stopAutoRefresh();\r\n    \r\n    // Create new subscription\r\n    this.refreshSubscription = interval(refreshInterval).subscribe(() => {\r\n      if (this.isLoadComplete && !this.isProcessing) {\r\n        this.refreshData();\r\n      }\r\n    });\r\n  }\r\n\r\n  private stopAutoRefresh() {\r\n    if (this.refreshSubscription) {\r\n      this.refreshSubscription.unsubscribe();\r\n      this.refreshSubscription = null;\r\n    }\r\n  }\r\n\r\n  toggleAutoRefresh() {\r\n    // this.autoRefreshEnabled = !this.autoRefreshEnabled;\r\n    \r\n    if (this.autoRefreshEnabled) {\r\n      this.startAutoRefresh();\r\n    } else {\r\n      this.stopAutoRefresh();\r\n    }\r\n  }\r\n\r\n  loadData(action: Action, causeTablesReload) {\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          // DetailsDialogProcessor.setHeroValue(this.detailsConfig, this.details);\r\n          if(causeTablesReload) this.tableReload.next(true);\r\n\r\n          const config = this.detailsConfig.autoRefreshConfig;\r\n          if (this.autoRefreshEnabled && config?.stopCondition && config.stopCondition(this.details)) {\r\n            this.autoRefreshEnabled = false;\r\n            this.stopAutoRefresh();\r\n          }\r\n        }\r\n        else{\r\n          this.messageService.toast(\"Error: \" + apiResponse.message);\r\n\r\n          if (this.autoRefreshEnabled) {\r\n            this.autoRefreshEnabled = false;\r\n            this.stopAutoRefresh();\r\n          }\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) {\r\n    this.formConfig.mode = newMode\r\n    this.setTitleAction()\r\n  }\r\n\r\n  setTitleAction() {\r\n    if (this.formConfig.fixedTitle) {\r\n      this.titleAction = \"\";\r\n      return;\r\n    }\r\n\r\n    this.titleAction = this.buttonService.getTitleAction(this.formConfig.mode, this.buttons);\r\n  }\r\n\r\n  getButton(name: string) {\r\n    return this.buttonService.getButton(this.buttons, name);\r\n  }\r\n\r\n  testDisabled(row, buttonName: string): boolean {\r\n    const button = this.getButton(buttonName);\r\n\r\n    if (!button) return false;\r\n\r\n    // Create a copy of the button with component's detailsConfig\r\n    const buttonWithConfig = {\r\n      ...button,\r\n      detailsConfig: button.detailsConfig ? { ...button.detailsConfig } : this.detailsConfig\r\n    };\r\n\r\n    return this.buttonService.testDisabled(buttonWithConfig, row);\r\n  }\r\n\r\n\r\n  testVisible(row, buttonName: string): boolean {\r\n    const button = this.getButton(buttonName);\r\n    if (!button) return false;\r\n\r\n    // Create a copy of the button with component's detailsConfig\r\n    const buttonWithConfig = {\r\n      ...button,\r\n      detailsConfig: button.detailsConfig ? { ...button.detailsConfig } : this.detailsConfig\r\n    };\r\n\r\n    return this.buttonService.testVisible(buttonWithConfig, row)\r\n  }\r\n\r\n  testVisibleTab(tblConfig: TableConfig): boolean {\r\n\r\n    if (!this.tableConfigService.hasTableAccess(tblConfig)) {\r\n      return false;\r\n    }\r\n\r\n    return this.buttonService.isTabVisible(tblConfig);\r\n  }\r\n\r\n  getButtonColor(button: Button, row) {\r\n    return this.buttonService.getButtonColor(button, row);\r\n  }\r\n\r\n  getVisibleFields() {\r\n    return this.formConfig.fields?.filter(x => Core.testVisible(this.formConfig, this.details, x, this.authService.currentRoleSource.value))\r\n  }\r\n\r\n\r\n  create() {\r\n    this.handleButtonAction('create');\r\n  }\r\n\r\n  edit() {\r\n    this.handleButtonAction('edit');\r\n  }\r\n\r\n  delete() {\r\n    const button = this.buttonService.getButton(this.buttons, 'delete');\r\n    if (!button) return;\r\n\r\n    let confirmMessage = this.buttonService.getConfirmMessage(button, this.details);\r\n    if (!confirmMessage) {\r\n      confirmMessage = `Are you sure you want to delete ?`;\r\n    }\r\n\r\n    this.messageService.confirm(confirmMessage).subscribe((result) => {\r\n      if (result == \"yes\") {\r\n        this.handleButtonAction('delete');\r\n      }\r\n    });\r\n  }\r\n\r\n\r\n  custom(button: Button) {\r\n    if (button.dialog && button.detailsConfig) {\r\n      this.openNestedDetailsDialog(button);\r\n    } else {\r\n      this.handleButtonAction(button.name);\r\n    }\r\n  }\r\n\r\n  private openNestedDetailsDialog(button: Button): void {\r\n\r\n    this.dialogService.openConfiguredDetailsDialog(button, this.details, DetailsDialogInternal).subscribe(result => {\r\n\r\n      if (result.action === 'inputChange') {\r\n        this.inputChanged(result.change);\r\n      } else if (result && result.message === 'success') {\r\n        this.refreshData();\r\n      }\r\n\r\n    });\r\n  }\r\n\r\n  private refreshData(): void {\r\n    if (this.formConfig.loadAction) {\r\n      this.loadData(this.formConfig.loadAction, true);\r\n    }\r\n  }\r\n\r\n  handleButtonAction(buttonName: string) {\r\n    \r\n    const button = this.getButton(buttonName);\r\n    if (!button) return;\r\n   \r\n\r\n    if (button.onClick) {\r\n      button.onClick(this.details);\r\n    }\r\n\r\n    this.processButtonAction(button);\r\n  }\r\n\r\n  processButtonAction(button : Button) {\r\n    if (!button.action) {\r\n      this.dialogRef.close({ message: 'emit', data: this.details });\r\n      return;\r\n    }\r\n\r\n    if (this.validateForm()) {\r\n      this.executeAction(button, this.details);\r\n    }\r\n  }\r\n\r\n  private validateForm(): boolean {\r\n    let validationResult = Core.validateObject(this.getVisibleFields(), this.details);\r\n    if (validationResult !== '') {\r\n      this.messageService.toast(validationResult);\r\n      return false;\r\n    }\r\n\r\n    if (this.files.length < 1 && this.fileField?.required && this.formConfig.mode === 'create') {\r\n      this.messageService.toast(\"Please attach file(s)\");\r\n      return false;\r\n    }\r\n\r\n    // Validate composite fields\r\n    for (const field of this.getVisibleFields()) {\r\n      if (field.type === 'composite') {\r\n        validationResult = Core.validateObject(Core.getVisibleSubfields(this.formConfig, this.details, field, this.authService.currentRoleSource.value), this.details, );\r\n        if (validationResult !== '') {\r\n          this.messageService.toast(validationResult);\r\n          return false;\r\n        }\r\n      }\r\n    }\r\n\r\n    return true;\r\n  }\r\n\r\n  private prepareActionData(button: Button, data: any): any {\r\n    if (this.buttonService.isFormButton(button)) {\r\n      const 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      formData.append(\"data\", JSON.stringify(data));\r\n      return formData;\r\n    }\r\n    return data;\r\n  }\r\n\r\n  private executeAction(button: Button, data: any) {\r\n    const actionData = this.prepareActionData(button, data);\r\n\r\n    if (button.confirm) {\r\n      let confirmMessage = this.buttonService.getConfirmMessage(button, this.details);\r\n\r\n      if (!confirmMessage && button.name == 'delete') {\r\n        confirmMessage = `Are you sure you want to delete ?`;\r\n      }\r\n\r\n      this.messageService.confirm(confirmMessage).subscribe((result) => {\r\n        if (result == \"yes\") {\r\n          this.performApiCall(button, actionData);\r\n        }\r\n      });\r\n\r\n    } else {\r\n      this.performApiCall(button, actionData);\r\n    }\r\n\r\n  }\r\n\r\n  private performApiCall(button: Button, data: any) {\r\n    this.dataService.CallApi(button.action, data).subscribe((apiResponse: ApiResponse) => {\r\n\r\n      if (apiResponse.success) {\r\n\r\n        if (apiResponse.message.includes(\"approval\") || apiResponse.message.includes(\"approve\") || apiResponse.message.includes(\"decline\")) {\r\n          this.messageService.toast(apiResponse.message);\r\n        } else if (button.action.successMessage) {\r\n          this.messageService.toast(button.action.successMessage);\r\n        } else if (apiResponse.message != \"success\" && apiResponse.message != \"\") {\r\n          this.messageService.toast(apiResponse.message);\r\n        } else {\r\n          this.messageService.toast(\"Updated\");\r\n        }\r\n\r\n        if (button.onSuccess) {\r\n          button.onSuccess(apiResponse.data, this.details);\r\n        }\r\n\r\n        if (button.keepOpen) {\r\n          this.refreshData();\r\n        }else{\r\n          this.dialogRef.close({ message: 'success', data: { ...apiResponse, data: button.name == 'create' ? apiResponse.data : this.details  } });\r\n        }\r\n        \r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse.message);\r\n      }\r\n    });\r\n  }\r\n\r\n  close(){\r\n    if (this.detailsConfig.refreshOnClose){\r\n      this.dialogRef.close({ message: 'success', data: this.details });\r\n    }else{\r\n      this.dialogRef.close({ message: 'emit', data: this.details });\r\n    }\r\n  }\r\n};\r\n\r\n\r\n\r\n","<div class=\"dialog-container\">\r\n\r\n  <div class=\"dialog-content\">\r\n\r\n    <mat-progress-bar mode=\"indeterminate\" *ngIf=\"isProcessing && dataService.appConfig.progressLine\"></mat-progress-bar>\r\n\r\n    <div class=\"d-flex justify-content-between align-items-center mt-2\">\r\n\r\n      <div>\r\n        <label style=\"font-size: 20px; font-weight:500;margin-bottom: 10px;\">{{titleAction | titlecase}} {{formConfig?.title}}</label>\r\n      </div>\r\n\r\n      <div class=\"d-flex justify-content-between align-items-center\">\r\n\r\n        <spa-check *ngIf=\"detailsConfig.autoRefreshConfig\" display=\"Auto Refresh\" [(value)]=\"autoRefreshEnabled\" (valueChange)=\"toggleAutoRefresh()\"></spa-check>\r\n\r\n        <div *ngIf=\"formConfig.mode=='view' && editButton && testVisible(details,editButton.name)\">\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, detailsConfig.causeTableRefresh)\"><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 dialog-scroll-content\">\r\n\r\n      <spa-steps *ngIf=\"stepConfig && details\" [config]=\"stepConfig\" [data]=\"details\"></spa-steps>\r\n\r\n      <spa-alert [alertMessages]=\"formConfig.alertMessages\" [data]=\"details\"></spa-alert>\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)\">\r\n          <ng-template #dynamicSelect let-field=\"field\" let-data=\"data\" let-testReadOnly=\"testReadOnly\" let-selectChanged=\"selectChanged\">\r\n            <spa-select-internal\r\n              [display]=\"field.alias ?? field.name | camelToWords\"\r\n              [width]=\"field.width\"\r\n              [nullable]=\"field.nullable\"\r\n              [options]=\"field.options\"\r\n              [masterOptions]=\"field.masterOptions\"\r\n              [masterField]=\"field.masterField\"\r\n              [optionDisplay]=\"field.optionDisplay ?? 'name'\"\r\n              [optionValue]=\"field.optionValue ?? 'value'\"\r\n              [(value)]=\"data[field.name]\"\r\n              [defaultFirstValue]=\"field.defaultFirstValue\"\r\n              [readonly]=\"testReadOnly(field)\"\r\n              [hint]=\"field.hint\"\r\n              [detailsConfig]=\"field.detailsConfig\"\r\n              [loadAction]=\"field.loadAction\"\r\n              [loadIDField]=\"field.loadIDField\"\r\n              [field]=\"field\"\r\n              [data]=\"data\"\r\n              [infoMessage]=\"field.infoMessage\"\r\n              [copyContent]=\"field.copyContent\"\r\n              (valueChange)=\"selectChanged(field)\"\r\n            ></spa-select-internal>\r\n          </ng-template>\r\n        </spa-form>\r\n\r\n\r\n        <mat-tab-group *ngIf=\"tableConfigs\" (selectedTabChange)=\"onTabChange($event)\">\r\n\r\n          <ng-container *ngFor=\"let tbl of tableConfigService.getVisibleTableConfigs(tableConfigs) ; let i = index\">\r\n            <mat-tab *ngIf=\"testVisibleTab(tbl)\">\r\n\r\n              <ng-template matTabLabel>\r\n                <span>{{tbl.tabTitle ?? 'Untitled'}}</span>\r\n              </ng-template>\r\n\r\n              <spa-table-lite              \r\n                [config]=\"tbl\" \r\n                [reload]=\"tableReload\" \r\n                [inTab]=\"true\"\r\n                [activeTab]=\"selectedTabIndex === i\"\r\n                (actionSuccess)=\"tbl.causeFormRefresh ? loadData(formConfig.loadAction, false) : null\">\r\n              </spa-table-lite>\r\n\r\n            </mat-tab>\r\n          </ng-container>\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\r\n  </div>\r\n\r\n  <mat-dialog-actions>\r\n\r\n    <div>\r\n\r\n      <button mat-raised-button [disabled]=\"isProcessing\" *ngIf=\"formConfig.mode=='create' && createButton\" color=\"primary\" (click)=\"create()\" cdkFocusInitial>{{createButton.display ?? 'Submit'}}\r\n      </button>\r\n\r\n      <button mat-raised-button [disabled]=\"isProcessing\" *ngIf=\"formConfig.mode=='edit' && editButton\" color=\"primary\" (click)=\"edit()\" cdkFocusInitial>{{editButton.display ?? 'Submit'}}\r\n      </button>\r\n\r\n      <ng-container *ngFor=\"let btn of extraButtons\">\r\n        <button *ngIf=\"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 | titlecase}}\r\n        </button>\r\n      </ng-container>\r\n\r\n      <button mat-stroked-button color=\"primary\" (click)=\"close()\">Cancel</button>\r\n\r\n    </div>\r\n\r\n    <div class=\"col d-flex justify-content-end\" *ngIf=\"smallScreen\">\r\n      <button mat-icon-button matTooltipPosition=\"above\" matTooltip=\"Delete\" [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</div>\r\n\r\n\r\n\r\n\r\n\r\n\r\n"]}
|
|
387
|
+
//# 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, OnDestroy } from '@angular/core';\r\nimport { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';\r\nimport { FormConfig, Field, TableConfig, Button, DetailsDialogConfig, Action, ApiResponse, StepConfig } from '../../classes/Classes';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { DataServiceLib } from '../../services/datalib.service';\r\nimport { LoaderService } from '../../services/loader.service';\r\nimport { BreakpointObserver, BreakpointState } from '@angular/cdk/layout';\r\nimport { Core, DetailsDialogProcessor } from '../../classes/TinCore';\r\nimport { DialogService } from '../../services/dialog.service';\r\nimport { ButtonService } from '../../services/button.service';\r\nimport { interval, Subject, Subscription } from 'rxjs';\r\nimport { AuthService } from '../../services/auth.service';\r\nimport { TableConfigService } from '../../services/table-config.service';\r\nimport { MatTabChangeEvent } from '@angular/material/tabs';\r\n\r\n@Component({\r\n  selector: 'spa-detailsDialog-internal', //uniq to internal\r\n  templateUrl: './detailsDialog-internal.component.html',\r\n  styleUrls: ['./table-internal.component.css']\r\n})\r\nexport class DetailsDialogInternal implements OnInit, OnDestroy {\r\n\r\n  constructor(private breakpointObserver: BreakpointObserver,private loaderService: LoaderService,public dataService: DataServiceLib,private messageService: MessageService,\r\n    private dialogRef: MatDialogRef<DetailsDialogInternal>, @Inject(MAT_DIALOG_DATA) public detailsConfig: DetailsDialogConfig, private buttonService: ButtonService,\r\n    private dialogService: DialogService, private authService: AuthService, public tableConfigService: TableConfigService)\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, stepConfig, buttons } = DetailsDialogProcessor.initializeConfigs(this.detailsConfig);\r\n    this.tableConfig = tableConfig;\r\n    this.tableConfigs = tableConfigs;\r\n    this.formConfig = formConfig;\r\n    this.stepConfig = stepConfig;\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      DetailsDialogProcessor.setHeroValue(this.detailsConfig, this.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    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    this.initAutoRefresh();\r\n\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    // Cleanup subscription on component destroy\r\n    this.stopAutoRefresh();\r\n  }\r\n\r\n  private refreshSubscription: Subscription;\r\n  autoRefreshEnabled: boolean = false;\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 : TableConfig[]\r\n  details: any\r\n  formConfig: FormConfig;\r\n  stepConfig: StepConfig;\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  selectedTabIndex = 0;\r\n  onTabChange(event: MatTabChangeEvent) {\r\n    this.selectedTabIndex = event.index;\r\n  }\r\n\r\n  private initAutoRefresh() {\r\n    const config = this.detailsConfig.autoRefreshConfig;\r\n    if (!config) return;\r\n\r\n    // Set initial state based on defaultOn configuration\r\n    this.autoRefreshEnabled = config.defaultOn || false;\r\n\r\n    // Start auto-refresh if enabled by default\r\n    if (this.autoRefreshEnabled) {\r\n      this.startAutoRefresh();\r\n    }\r\n  }\r\n\r\n  private startAutoRefresh() {\r\n\r\n    if (!this.detailsConfig.autoRefreshConfig) return;\r\n    \r\n    const refreshInterval = this.detailsConfig.autoRefreshConfig.interval || 5000; // Default to 5 seconds\r\n    \r\n    // Clear any existing subscription\r\n    this.stopAutoRefresh();\r\n    \r\n    // Create new subscription\r\n    this.refreshSubscription = interval(refreshInterval).subscribe(() => {\r\n      if (this.isLoadComplete && !this.isProcessing) {\r\n        this.refreshData();\r\n      }\r\n    });\r\n  }\r\n\r\n  private stopAutoRefresh() {\r\n    if (this.refreshSubscription) {\r\n      this.refreshSubscription.unsubscribe();\r\n      this.refreshSubscription = null;\r\n    }\r\n  }\r\n\r\n  toggleAutoRefresh() {\r\n    // this.autoRefreshEnabled = !this.autoRefreshEnabled;\r\n    \r\n    if (this.autoRefreshEnabled) {\r\n      this.startAutoRefresh();\r\n    } else {\r\n      this.stopAutoRefresh();\r\n    }\r\n  }\r\n\r\n  loadData(action: Action, causeTablesReload) {\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          // DetailsDialogProcessor.setHeroValue(this.detailsConfig, this.details);\r\n          if(causeTablesReload) this.tableReload.next(true);\r\n\r\n          const config = this.detailsConfig.autoRefreshConfig;\r\n          if (this.autoRefreshEnabled && config?.stopCondition && config.stopCondition(this.details)) {\r\n            this.autoRefreshEnabled = false;\r\n            this.stopAutoRefresh();\r\n          }\r\n        }\r\n        else{\r\n          this.messageService.toast(\"Error: \" + apiResponse.message);\r\n\r\n          if (this.autoRefreshEnabled) {\r\n            this.autoRefreshEnabled = false;\r\n            this.stopAutoRefresh();\r\n          }\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) {\r\n    this.formConfig.mode = newMode\r\n    this.setTitleAction()\r\n  }\r\n\r\n  setTitleAction() {\r\n    if (this.formConfig.fixedTitle) {\r\n      this.titleAction = \"\";\r\n      return;\r\n    }\r\n\r\n    this.titleAction = this.buttonService.getTitleAction(this.formConfig.mode, this.buttons);\r\n  }\r\n\r\n  getButton(name: string) {\r\n    return this.buttonService.getButton(this.buttons, name);\r\n  }\r\n\r\n  testDisabled(row, buttonName: string): boolean {\r\n    const button = this.getButton(buttonName);\r\n\r\n    if (!button) return false;\r\n\r\n    // Create a copy of the button with component's detailsConfig\r\n    const buttonWithConfig = {\r\n      ...button,\r\n      detailsConfig: button.detailsConfig ? { ...button.detailsConfig } : this.detailsConfig\r\n    };\r\n\r\n    return this.buttonService.testDisabled(buttonWithConfig, row);\r\n  }\r\n\r\n\r\n  testVisible(row, buttonName: string): boolean {\r\n    const button = this.getButton(buttonName);\r\n    if (!button) return false;\r\n\r\n    // Create a copy of the button with component's detailsConfig\r\n    const buttonWithConfig = {\r\n      ...button,\r\n      detailsConfig: button.detailsConfig ? { ...button.detailsConfig } : this.detailsConfig\r\n    };\r\n\r\n    return this.buttonService.testVisible(buttonWithConfig, row)\r\n  }\r\n\r\n  testVisibleTab(tblConfig: TableConfig): boolean {\r\n\r\n    if (!this.tableConfigService.hasTableAccess(tblConfig)) {\r\n      return false;\r\n    }\r\n\r\n    return this.buttonService.isTabVisible(tblConfig);\r\n  }\r\n\r\n  getButtonColor(button: Button, row) {\r\n    return this.buttonService.getButtonColor(button, row);\r\n  }\r\n\r\n  getVisibleFields() {\r\n    return this.formConfig.fields?.filter(x => Core.testVisible(this.formConfig, this.details, x, this.authService.currentRoleSource.value))\r\n  }\r\n\r\n\r\n  create() {\r\n    this.handleButtonAction('create');\r\n  }\r\n\r\n  edit() {\r\n    this.handleButtonAction('edit');\r\n  }\r\n\r\n  delete() {\r\n    const button = this.buttonService.getButton(this.buttons, 'delete');\r\n    if (!button) return;\r\n\r\n    let confirmMessage = this.buttonService.getConfirmMessage(button, this.details);\r\n    if (!confirmMessage) {\r\n      confirmMessage = `Are you sure you want to delete ?`;\r\n    }\r\n\r\n    this.messageService.confirm(confirmMessage).subscribe((result) => {\r\n      if (result == \"yes\") {\r\n        this.handleButtonAction('delete');\r\n      }\r\n    });\r\n  }\r\n\r\n\r\n  custom(button: Button) {\r\n    if (button.dialog && button.detailsConfig) {\r\n      this.openNestedDetailsDialog(button);\r\n    } else {\r\n      this.handleButtonAction(button.name);\r\n    }\r\n  }\r\n\r\n  private openNestedDetailsDialog(button: Button): void {\r\n\r\n    this.dialogService.openConfiguredDetailsDialog(button, this.details, DetailsDialogInternal).subscribe(result => {\r\n\r\n      if (result.action === 'inputChange') {\r\n        this.inputChanged(result.change);\r\n      } else if (result && result.message === 'success') {\r\n        this.refreshData();\r\n      }\r\n\r\n    });\r\n  }\r\n\r\n  private refreshData(): void {\r\n    if (this.formConfig.loadAction) {\r\n      this.loadData(this.formConfig.loadAction, true);\r\n    }\r\n  }\r\n\r\n  handleButtonAction(buttonName: string) {\r\n    \r\n    const button = this.getButton(buttonName);\r\n    if (!button) return;\r\n   \r\n\r\n    if (button.onClick) {\r\n      button.onClick(this.details);\r\n    }\r\n\r\n    this.processButtonAction(button);\r\n  }\r\n\r\n  processButtonAction(button : Button) {\r\n    if (!button.action) {\r\n      this.dialogRef.close({ message: 'emit', data: this.details });\r\n      return;\r\n    }\r\n\r\n    if (this.validateForm()) {\r\n      this.executeAction(button, this.details);\r\n    }\r\n  }\r\n\r\n  private validateForm(): boolean {\r\n    let validationResult = Core.validateObject(this.getVisibleFields(), this.details);\r\n    if (validationResult !== '') {\r\n      this.messageService.toast(validationResult);\r\n      return false;\r\n    }\r\n\r\n    if (this.files.length < 1 && this.fileField?.required && this.formConfig.mode === 'create') {\r\n      this.messageService.toast(\"Please attach file(s)\");\r\n      return false;\r\n    }\r\n\r\n    // Validate composite fields\r\n    for (const field of this.getVisibleFields()) {\r\n      if (field.type === 'composite') {\r\n        validationResult = Core.validateObject(Core.getVisibleSubfields(this.formConfig, this.details, field, this.authService.currentRoleSource.value), this.details, );\r\n        if (validationResult !== '') {\r\n          this.messageService.toast(validationResult);\r\n          return false;\r\n        }\r\n      }\r\n    }\r\n\r\n    return true;\r\n  }\r\n\r\n  private prepareActionData(button: Button, data: any): any {\r\n    if (this.buttonService.isFormButton(button)) {\r\n      const 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      formData.append(\"data\", JSON.stringify(data));\r\n      return formData;\r\n    }\r\n    return data;\r\n  }\r\n\r\n  private executeAction(button: Button, data: any) {\r\n    const actionData = this.prepareActionData(button, data);\r\n\r\n    if (button.confirm) {\r\n      let confirmMessage = this.buttonService.getConfirmMessage(button, this.details);\r\n\r\n      if (!confirmMessage && button.name == 'delete') {\r\n        confirmMessage = `Are you sure you want to delete ?`;\r\n      }\r\n\r\n      this.messageService.confirm(confirmMessage).subscribe((result) => {\r\n        if (result == \"yes\") {\r\n          this.performApiCall(button, actionData);\r\n        }\r\n      });\r\n\r\n    } else {\r\n      this.performApiCall(button, actionData);\r\n    }\r\n\r\n  }\r\n\r\n  private performApiCall(button: Button, data: any) {\r\n    this.dataService.CallApi(button.action, data).subscribe((apiResponse: ApiResponse) => {\r\n\r\n      if (apiResponse.success) {\r\n\r\n        if (apiResponse.message.includes(\"approval\") || apiResponse.message.includes(\"approve\") || apiResponse.message.includes(\"decline\")) {\r\n          this.messageService.toast(apiResponse.message);\r\n        } else if (button.action.successMessage) {\r\n          this.messageService.toast(button.action.successMessage);\r\n        } else if (apiResponse.message != \"success\" && apiResponse.message != \"\") {\r\n          this.messageService.toast(apiResponse.message);\r\n        } else {\r\n          this.messageService.toast(\"Updated\");\r\n        }\r\n\r\n        if (button.onSuccess) {\r\n          button.onSuccess(apiResponse.data, this.details);\r\n        }\r\n\r\n        if (button.keepOpen) {\r\n          if (button.name === 'create' && apiResponse.data) {\r\n            this.details = apiResponse.data;\r\n            \r\n            if (this.detailsConfig.heroField && apiResponse.data[this.detailsConfig.heroField]) {\r\n              this.detailsConfig.heroValue = apiResponse.data[this.detailsConfig.heroField];\r\n              this.formConfig.heroField = this.detailsConfig.heroField;\r\n              this.formConfig.heroValue = this.detailsConfig.heroValue;\r\n            }\r\n            \r\n            this.formConfig.mode = 'edit';\r\n            this.setTitleAction();\r\n            this.isLoadComplete = true;\r\n            \r\n          } else {\r\n            this.refreshData();\r\n          }\r\n        }else{\r\n          this.dialogRef.close({ message: 'success', data: { ...apiResponse, data: button.name == 'create' ? apiResponse.data : this.details  } });\r\n        }\r\n        \r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse.message);\r\n      }\r\n    });\r\n  }\r\n\r\n  close(){\r\n    if (this.detailsConfig.refreshOnClose){\r\n      this.dialogRef.close({ message: 'success', data: this.details });\r\n    }else{\r\n      this.dialogRef.close({ message: 'emit', data: this.details });\r\n    }\r\n  }\r\n};\r\n\r\n\r\n\r\n","<div class=\"dialog-container\">\r\n\r\n  <div class=\"dialog-content\">\r\n\r\n    <mat-progress-bar mode=\"indeterminate\" *ngIf=\"isProcessing && dataService.appConfig.progressLine\"></mat-progress-bar>\r\n\r\n    <div class=\"d-flex justify-content-between align-items-center mt-2\">\r\n\r\n      <div>\r\n        <label style=\"font-size: 20px; font-weight:500;margin-bottom: 10px;\">{{titleAction | titlecase}} {{formConfig?.title}}</label>\r\n      </div>\r\n\r\n      <div class=\"d-flex justify-content-between align-items-center\">\r\n\r\n        <spa-check *ngIf=\"detailsConfig.autoRefreshConfig\" display=\"Auto Refresh\" [(value)]=\"autoRefreshEnabled\" (valueChange)=\"toggleAutoRefresh()\"></spa-check>\r\n\r\n        <div *ngIf=\"formConfig.mode=='view' && editButton && testVisible(details,editButton.name)\">\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, detailsConfig.causeTableRefresh)\"><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 dialog-scroll-content\">\r\n\r\n      <spa-steps *ngIf=\"stepConfig && details\" [config]=\"stepConfig\" [data]=\"details\"></spa-steps>\r\n\r\n      <spa-alert [alertMessages]=\"formConfig.alertMessages\" [data]=\"details\"></spa-alert>\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)\">\r\n          <ng-template #dynamicSelect let-field=\"field\" let-data=\"data\" let-testReadOnly=\"testReadOnly\" let-selectChanged=\"selectChanged\">\r\n            <spa-select-internal\r\n              [display]=\"field.alias ?? field.name | camelToWords\"\r\n              [width]=\"field.width\"\r\n              [nullable]=\"field.nullable\"\r\n              [options]=\"field.options\"\r\n              [masterOptions]=\"field.masterOptions\"\r\n              [masterField]=\"field.masterField\"\r\n              [optionDisplay]=\"field.optionDisplay ?? 'name'\"\r\n              [optionValue]=\"field.optionValue ?? 'value'\"\r\n              [(value)]=\"data[field.name]\"\r\n              [defaultFirstValue]=\"field.defaultFirstValue\"\r\n              [readonly]=\"testReadOnly(field)\"\r\n              [hint]=\"field.hint\"\r\n              [detailsConfig]=\"field.detailsConfig\"\r\n              [loadAction]=\"field.loadAction\"\r\n              [loadIDField]=\"field.loadIDField\"\r\n              [field]=\"field\"\r\n              [data]=\"data\"\r\n              [infoMessage]=\"field.infoMessage\"\r\n              [copyContent]=\"field.copyContent\"\r\n              (valueChange)=\"selectChanged(field)\"\r\n            ></spa-select-internal>\r\n          </ng-template>\r\n        </spa-form>\r\n\r\n\r\n        <mat-tab-group *ngIf=\"tableConfigs\" (selectedTabChange)=\"onTabChange($event)\">\r\n\r\n          <ng-container *ngFor=\"let tbl of tableConfigService.getVisibleTableConfigs(tableConfigs) ; let i = index\">\r\n            <mat-tab *ngIf=\"testVisibleTab(tbl)\">\r\n\r\n              <ng-template matTabLabel>\r\n                <span>{{tbl.tabTitle ?? 'Untitled'}}</span>\r\n              </ng-template>\r\n\r\n              <spa-table-lite              \r\n                [config]=\"tbl\" \r\n                [reload]=\"tableReload\" \r\n                [inTab]=\"true\"\r\n                [activeTab]=\"selectedTabIndex === i\"\r\n                (actionSuccess)=\"tbl.causeFormRefresh ? loadData(formConfig.loadAction, false) : null\">\r\n              </spa-table-lite>\r\n\r\n            </mat-tab>\r\n          </ng-container>\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\r\n  </div>\r\n\r\n  <mat-dialog-actions>\r\n\r\n    <div>\r\n\r\n      <button mat-raised-button [disabled]=\"isProcessing\" *ngIf=\"formConfig.mode=='create' && createButton\" color=\"primary\" (click)=\"create()\" cdkFocusInitial>{{createButton.display ?? 'Submit'}}\r\n      </button>\r\n\r\n      <button mat-raised-button [disabled]=\"isProcessing\" *ngIf=\"formConfig.mode=='edit' && editButton\" color=\"primary\" (click)=\"edit()\" cdkFocusInitial>{{editButton.display ?? 'Submit'}}\r\n      </button>\r\n\r\n      <ng-container *ngFor=\"let btn of extraButtons\">\r\n        <button *ngIf=\"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 | titlecase}}\r\n        </button>\r\n      </ng-container>\r\n\r\n      <button mat-stroked-button color=\"primary\" (click)=\"close()\">Cancel</button>\r\n\r\n    </div>\r\n\r\n    <div class=\"col d-flex justify-content-end\" *ngIf=\"smallScreen\">\r\n      <button mat-icon-button matTooltipPosition=\"above\" matTooltip=\"Delete\" [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</div>\r\n\r\n\r\n\r\n\r\n\r\n\r\n"]}
|