tin-spa 2.13.13 → 2.13.15
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/classes/Classes.mjs +1 -1
- package/esm2020/lib/classes/TinCore.mjs +1 -2
- package/esm2020/lib/components/date/date.component.mjs +3 -6
- package/esm2020/lib/components/form/form.component.mjs +4 -1
- package/esm2020/lib/components/table/detailsDialog.component.mjs +4 -2
- package/esm2020/lib/components/table-internal/detailsDialog-internal.component.mjs +4 -2
- package/esm2020/lib/components/table-lite/detailsDialog-lite.component.mjs +4 -2
- package/esm2020/lib/components/text/text.component.mjs +1 -5
- package/esm2020/lib/pages/users/users.component.mjs +29 -3
- package/esm2020/lib/services/datalib.service.mjs +1 -2
- package/fesm2015/tin-spa.mjs +46 -15
- package/fesm2015/tin-spa.mjs.map +1 -1
- package/fesm2020/tin-spa.mjs +42 -16
- package/fesm2020/tin-spa.mjs.map +1 -1
- package/lib/classes/Classes.d.ts +1 -0
- package/package.json +1 -1
|
@@ -171,6 +171,9 @@ export class FormComponent {
|
|
|
171
171
|
}
|
|
172
172
|
selectChanged(field) {
|
|
173
173
|
this.inputChanged(field, this.data[field.name]);
|
|
174
|
+
if (field.onSelectChange) {
|
|
175
|
+
field.onSelectChange(this.data[field.name], this.data);
|
|
176
|
+
}
|
|
174
177
|
}
|
|
175
178
|
inputChanged(field, value) {
|
|
176
179
|
this.inputChange.emit({ field: field, value: value });
|
|
@@ -290,4 +293,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
290
293
|
}], inputChange: [{
|
|
291
294
|
type: Output
|
|
292
295
|
}] } });
|
|
293
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/form/form.component.ts","../../../../../../projects/tin-spa/src/lib/components/form/form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ContentChild, EventEmitter, Input, OnInit, Output, TemplateRef } from '@angular/core';\r\nimport { FormConfig, Field, Button, ApiResponse } from '../../classes/Classes';\r\nimport { Core } from '../../classes/TinCore';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { DataServiceLib } from '../../services/datalib.service';\r\nimport { BehaviorSubject } from 'rxjs';\r\nimport { AuthService } from '../../services/auth.service';\r\n\r\n\r\n@Component({\r\n  selector: 'spa-form',\r\n  templateUrl: './form.component.html',\r\n  styleUrls: ['./form.component.css']\r\n})\r\nexport class FormComponent implements OnInit {\r\n\r\n  constructor(private messageService: MessageService, private dataService: DataServiceLib, private authService: AuthService) { }\r\n\r\n  ngOnInit() {\r\n\r\n    this.hasAccess = Core.hasFormAccess(this.config, this.authService.currentRoleSource.value);\r\n\r\n    if (!this.hasAccess) {\r\n      // this.messageService.toast('Access denied'); // Optional - notify user\r\n      return;\r\n    }\r\n\r\n    if (!this.config.fields){\r\n      this.messageService.toast(\"Please Configure Form Fields\")\r\n      return;\r\n    }\r\n\r\n    if (!this.data) {\r\n      this.messageService.toast(\"Please Configure Form Data\")\r\n      return;\r\n    }\r\n\r\n    this.fields = this.config.fields;\r\n\r\n    // Initialize BehaviorSubjects for fields with loadActions\r\n    this.fields?.forEach(field => {\r\n      if (field.loadAction && !field.optionsSubject && !field.masterField) {\r\n        field.optionsSubject = new BehaviorSubject<any[]>([]);\r\n\r\n        // Subscribe to options changes\r\n        field.optionsSubject.subscribe(newOptions => {\r\n          field.options = newOptions;\r\n\r\n          // Update child fields that depend on this field\r\n          if (this.childFields?.some(x => x.masterField === field.name)) {\r\n            this.updateChildOptions(field.name);\r\n          }\r\n        });\r\n      }\r\n    });\r\n\r\n\r\n    if (this.config.multiColumn){\r\n      this.multiColumn = this.config.multiColumn\r\n    }else{\r\n      this.multiColumn = this.fields.length > 2\r\n    }\r\n\r\n    if (this.config?.button?.display){\r\n      this.buttonDisplay = this.config.button.display;\r\n    }\r\n\r\n    this.fileField = this.fields.find(x => x.type == 'file')\r\n\r\n    if (this.config?.button?.action && this.fileField || this.config?.button?.action.url.includes(\"/form\")) {\r\n      this.config.button.action.isFormData = true;\r\n\r\n    }\r\n\r\n    this.childFields = this.fields.filter(x => x.masterField)\r\n\r\n\r\n    this.childFields.forEach(child => {\r\n      let master = this.fields.find(x => x.name == child.masterField)\r\n      if (child.loadAction) {\r\n        this.loadChildMasterOptions(child);\r\n      }else{\r\n        this.updateChildOptions(master.name);\r\n      }\r\n\r\n    });\r\n\r\n    this.fields.forEach(field => {\r\n      if (field.loadAction) {\r\n        this.loadChildMasterOptions(field);\r\n      }\r\n    });\r\n\r\n    this.initializeCompositeFields();\r\n\r\n\r\n    this.applyValueCalculations();\r\n  }\r\n\r\n  @ContentChild('dynamicSelect') dynamicSelectTemplate: TemplateRef<any>;\r\n\r\n  hasAccess = false;\r\n  fileNames\r\n  fileField: Field;\r\n  fileViewField: Field;\r\n  @Input() files: any[] = [];\r\n  fields: Field[];\r\n  buttonDisplay = \"Submit\";\r\n  isProcessing: boolean = false;\r\n  multiColumn: boolean = false;\r\n\r\n  childFields: Field[];\r\n\r\n  @Input() data: any;\r\n  @Input() config: FormConfig;\r\n  @Output() buttonClick = new EventEmitter();\r\n  @Output() inputChange = new EventEmitter();\r\n\r\n  initializeCompositeFields() {\r\n    this.fields.forEach(field => {\r\n      if (field.type === 'composite' && field.subfields) {\r\n        field.subfields.forEach(subfield => {\r\n          if (this.data[subfield.name] === undefined) {\r\n            this.data[subfield.name] = Core.getInitialValue(subfield);\r\n          }\r\n        });\r\n      }\r\n    });\r\n  }\r\n\r\n  private applyValueCalculations() {\r\n    if (!this.data || !this.fields) return;\r\n    \r\n    // Get visible fields that have valueCalculation functions\r\n    const calculatedFields = this.getVisibleFields()\r\n      .filter(field => typeof field.valueCalculation === 'function');\r\n    \r\n    if (calculatedFields.length === 0) return;\r\n    \r\n    // Apply calculations to each field\r\n    calculatedFields.forEach(field => {\r\n      try {\r\n        const calculatedValue = field.valueCalculation(this.data);\r\n        if (calculatedValue !== undefined) {\r\n          this.data[field.name] = calculatedValue;\r\n        }\r\n      } catch (error) {\r\n        console.error(`Error calculating value for field ${field.name}:`, error);\r\n      }\r\n    });\r\n  }\r\n\r\n  getVisibleSubfields(field : Field){\r\n    return Core.getVisibleSubfields(this.config, this.data, field, this.authService.currentRoleSource.value);\r\n\r\n\r\n  }\r\n\r\n\r\n  getVisibleFields() {\r\n    let visibleFields = this.fields?.filter(x => Core.testVisible(this.config, this.data, x, this.authService.currentRoleSource.value)) ?? [];\r\n\r\n    // Filter out fields under collapsed sections\r\n    return visibleFields.filter(field => {\r\n      if (field.type === 'section') return true;\r\n      if (field.section) {\r\n        const sectionField = this.fields.find(f => f.type === 'section' && f.name === field.section);\r\n        return !sectionField?.collapsed;\r\n      }\r\n      return true;\r\n    });\r\n  }\r\n\r\n  testReadOnly(field: Field): boolean {\r\n    return Core.testReadOnly(this.config, this.data, field);\r\n  }\r\n\r\n  testRequired(field: Field): boolean {\r\n    return Core.testRequired(this.config, this.data, field);\r\n  }\r\n\r\n  toggleSection(field: Field) {\r\n    if (field.type === 'section') {\r\n      field.collapsed = !field.collapsed;\r\n    }\r\n  }\r\n\r\n  hasSectionFields(sectionName: string): boolean {\r\n    return this.fields?.some(field =>\r\n      field.section === sectionName &&\r\n      Core.testVisible(this.config, this.data, field, this.authService.currentRoleSource.value)\r\n    ) ?? false;\r\n  }\r\n\r\n  shouldSectionCollapse(field: Field): boolean {\r\n    if (field.collapsedCondition) {\r\n      return field.collapsedCondition(this.data);\r\n    }\r\n    return field.collapsed ?? false;\r\n  }\r\n\r\n\r\n  onInfoClick(event: MouseEvent, infoMessage: string): void {\r\n    event.stopPropagation();\r\n    this.messageService.info(infoMessage);\r\n  }\r\n\r\n\r\n  selectChanged(field: Field){\r\n    this.inputChanged(field, this.data[field.name] )\r\n  }\r\n\r\n\r\n\r\n  inputChanged(field : Field, value){\r\n\r\n    this.inputChange.emit({ field: field, value: value})\r\n\r\n    this.updateChildOptions(field.name)\r\n\r\n\r\n    if (this.config.mode == 'create' && field.children){\r\n      field.children.forEach(childConfig => {\r\n        let child = this.fields.find(x => x.name == childConfig.childField)\r\n        this.data[child.name] = field.options.find(x => x[field.optionValue ?? 'value'] == value)[childConfig.childValueField]\r\n      });\r\n    }\r\n\r\n    this.applyValueCalculations();\r\n\r\n  }\r\n\r\n  updateChildOptions(masterFieldName: string){\r\n\r\n    let child = this.childFields.find(x => x.masterField == masterFieldName)\r\n    if (child != null) {\r\n\r\n      //current is master\r\n\r\n\r\n      if (child.masterOptions){\r\n        child.options = child.masterOptions.filter(x => x[child.masterOptionValue ?? 'masterValue'] == this.data[masterFieldName])\r\n      }else{\r\n        console.log(\"Master Options not found\")\r\n      }\r\n\r\n    }\r\n  }\r\n\r\n  private loadChildMasterOptions(child: Field) {\r\n    if (!child.loadAction) return;\r\n\r\n    this.dataService.CallApi(child.loadAction).subscribe((apiResponse: ApiResponse) => {\r\n      if (apiResponse.success) {\r\n\r\n        child.masterOptions = apiResponse.data;\r\n        this.updateChildOptions(child.masterField);\r\n      }\r\n    });\r\n  }\r\n\r\n\r\n  buttonClicked(){\r\n\r\n    this.buttonClick.emit(this.data);\r\n\r\n    let button = this.config.button;\r\n\r\n    if (!button) {\r\n      return;\r\n    }\r\n\r\n    //validation\r\n    let resp = Core.validateObject(this.getVisibleFields(),this.data);\r\n    if (resp != ''){\r\n      this.messageService.toast(resp)\r\n      return;\r\n    }\r\n\r\n\r\n\r\n    if (this.files.length < 1 && this.fileField?.required && this.config.mode =='create') {\r\n      this.messageService.toast(\"Please attach file(s)\");\r\n      return;\r\n    }\r\n\r\n\r\n    if (button.confirm){\r\n\r\n      this.messageService.confirm(`${button.confirm.message}`).subscribe((result) => {\r\n        if (result == \"yes\") {\r\n          this.processCall(button)\r\n        }\r\n      });\r\n\r\n    }else{\r\n      this.processCall(button)\r\n    }\r\n\r\n\r\n\r\n\r\n  }\r\n\r\n  processCall(button: Button){\r\n\r\n    if (!button.action) return\r\n\r\n    let dataOut;\r\n\r\n    if (button.action.isFormData){\r\n\r\n      let formData: FormData = new FormData();\r\n      for (let i = 0; i < this.files.length; i++) {\r\n        formData.append(`uploadFile${i}`, this.files[i], this.files[i].name);\r\n      }\r\n\r\n      formData.append(\"data\", JSON.stringify(this.data));\r\n\r\n\r\n      dataOut = formData\r\n    }else{\r\n\r\n      dataOut = this.data\r\n    }\r\n\r\n\r\n\r\n\r\n    this.isProcessing = true\r\n    this.dataService.CallApi(button.action, dataOut).subscribe((apiResponse) => {\r\n      this.isProcessing = false\r\n\r\n      if (apiResponse.success) {\r\n\r\n        if (button.action.successMessage) {\r\n          this.messageService.toast(button.action.successMessage);\r\n        } else {\r\n          this.messageService.toast(\"Submitted\");\r\n        }\r\n\r\n        if (this.config.reset) {\r\n          Core.resetObject(this.fields, this.data)\r\n          this.files = [];\r\n          this.applyValueCalculations();\r\n        }\r\n\r\n\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse.message);\r\n      }\r\n    });\r\n  }\r\n\r\n  processForm(){\r\n\r\n\r\n\r\n\r\n\r\n  }\r\n\r\n}\r\n\r\n\r\n","\r\n\r\n\r\n<div class=\"tin-form-container\" >\r\n  <div [ngClass]=\"[multiColumn ? 'tin-grid' : 'tin-col', config.notesConfig ? 'width-75' : 'width-100']\" class=\"form-main-content\">\r\n\r\n    <div *ngIf=\"!hasAccess\" class=\"tin-center\">\r\n      <p><em>Access Restricted</em></p>\r\n    </div>\r\n  \r\n    <div [ngClass]=\"field.span || field.type =='section' || field.type =='file' || field.type =='file-view'  ? 'span-col' : ''\" *ngFor=\"let field of getVisibleFields()\">\r\n  \r\n      <ng-container>\r\n  \r\n        <ng-container [ngSwitch]=\"field.type\" class=\"highlight\">\r\n  \r\n          <div *ngSwitchCase=\"'section'\" class=\"title d-flex align-items-center\" (click)=\"toggleSection(field)\" style=\"cursor: pointer;\">\r\n            <label style=\"font-size: larger;margin-right: 10px;\">{{field.alias ?? field.name | camelToWords}}</label>\r\n            <mat-icon *ngIf=\"field.infoMessage\" (click)=\"onInfoClick($event, field.infoMessage)\" style=\"color: steelblue; font-size: 14px;\">info</mat-icon>\r\n            <!-- <button  mat-icon-button class=\"info-icon-button\"  matTooltip=\"Info\" matTooltipPosition=\"above\">\r\n  \r\n            </button> -->\r\n            <mat-icon *ngIf=\"hasSectionFields(field.name)\">{{shouldSectionCollapse(field) ? 'expand_more' : 'expand_less'}}</mat-icon>\r\n          </div>\r\n  \r\n          <ng-container *ngSwitchCase=\"'file'\">\r\n            <div class=\"mt-1 mb-2\" *ngIf=\"config.mode !='view'\">\r\n              <spa-attach [message]=\"field.alias ?? 'Drag and Drop files here'\" [(files)]=\"files\" [fileOptions]=\"field.fileOptions\"></spa-attach>\r\n            </div>\r\n          </ng-container>\r\n  \r\n          <ng-container *ngSwitchCase=\"'file-view'\">\r\n            <div class=\"mt-1 mb-2\" *ngIf=\"config.mode && config.mode !='create'\">\r\n              <spa-viewer [fileAction]=\"field.loadAction\" [path]=\"field.path\" [folderName]=\"data[field.keyField]\" ></spa-viewer>\r\n            </div>\r\n          </ng-container>\r\n  \r\n          <spa-html *ngSwitchCase=\"'html'\" [display]=\"field.alias | camelToWords\" [value]=\"data[field.name]\" [maxHeight]=\"field.maxHeight\"></spa-html>\r\n  \r\n          <label *ngSwitchCase=\"'blank'\"></label>\r\n  \r\n          <label *ngSwitchCase=\"'string'\" [ngStyle]=\"{'font-size':field.size ?? '14px'}\" >{{data[field.name] ?? field.alias ?? field.name}} {{field.suffix ?? ''}}</label>\r\n  \r\n          <spa-label *ngSwitchCase=\"'label'\" [display]=\"field.alias ?? field.name | camelToWords\" [value]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [format]=\"field.format ?? 'text'\" [suffix]=\"field.suffix\" [size]=\"field.size\"></spa-label>\r\n  \r\n          <spa-number *ngSwitchCase=\"'number'\" [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [required]=\"testRequired(field)\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\"></spa-number>\r\n  \r\n          <spa-money *ngSwitchCase=\"'money'\" [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [required]=\"testRequired(field)\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\"></spa-money>\r\n  \r\n          <spa-check *ngSwitchCase=\"'checkbox'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [readonly]=\"testReadOnly(field)\" [infoMessage]=\"field.infoMessage\" ></spa-check>\r\n  \r\n          <spa-date *ngSwitchCase=\"'date'\" [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [min]=\"field?.min\" [max]=\"field?.max\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" ></spa-date>\r\n  \r\n          <spa-datetime *ngSwitchCase=\"'datetime'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [readonly]=\"testReadOnly(field)\" [min]=\"field.min\" [max]=\"field.max\" [infoMessage]=\"field.infoMessage\" ></spa-datetime>\r\n  \r\n          <spa-email *ngSwitchCase=\"'email'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field,data[field.name])\" [required]=\"testRequired(field)\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\"  [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\"></spa-email>\r\n  \r\n          <spa-text *ngSwitchCase=\"'password'\" [format]=\"'password'\" [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [options]=\"field.options\" [optionValue]=\"field.optionValue ?? 'value'\" [rows]=\"field.rows\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field,data[field.name])\" [required]=\"testRequired(field)\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\"></spa-text>\r\n  \r\n  \r\n          <ng-container *ngSwitchCase=\"'select'\">\r\n            <ng-container *ngTemplateOutlet=\"dynamicSelectTemplate; context: {\r\n                    $implicit: field,\r\n                    field: field,\r\n                    data: data,\r\n                    testReadOnly: testReadOnly.bind(this),\r\n                    testRequired: testRequired.bind(this),\r\n                    selectChanged: selectChanged.bind(this)\r\n                  }\">\r\n            </ng-container>\r\n          </ng-container>\r\n  \r\n  \r\n          <spa-multi-select *ngSwitchCase=\"'multi-select'\" [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [options]=\"field.options\" [optionDisplay]=\"field.optionDisplay ?? 'name'\" [optionValue]=\"field.optionValue ?? 'value'\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [required]=\"testRequired(field)\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\" [loadAction]=\"field.loadAction\">\r\n          </spa-multi-select>\r\n  \r\n          <spa-multi-text *ngSwitchCase=\"'multi-text'\" [strict]=\"field.strict\" [display]=\"field.alias ?? field.name | camelToWords\" [options]=\"field.options\" [optionDisplay]=\"field.optionDisplay ?? 'name'\" [optionValue]=\"field.optionValue ?? 'value'\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field,data[field.name])\" [required]=\"testRequired(field)\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\" [loadAction]=\"field.loadAction\"></spa-multi-text>\r\n  \r\n  \r\n  \r\n          <ng-container *ngSwitchCase=\"'composite'\">\r\n            <div class=\"composite-field-container\">\r\n              <div class=\"composite-field-group\">\r\n                <ng-container *ngFor=\"let subfield of getVisibleSubfields(field)\">\r\n                  <ng-container [ngSwitch]=\"subfield.type\">\r\n  \r\n                    <label *ngSwitchCase=\"'string'\" [ngStyle]=\"{'font-size':field.size ?? '14px'}\" >{{data[field.name] ?? field.alias ?? field.name}} {{field.suffix ?? ''}}</label>\r\n                    \r\n                    <spa-number *ngSwitchCase=\"'number'\" [display]=\"subfield.alias ?? subfield.name | camelToWords\" [width]=\"subfield.width\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [required]=\"testRequired(subfield)\" [min]=\"subfield.min\" [max]=\"subfield.max\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [hint]=\"subfield.hint\" [infoMessage]=\"subfield.infoMessage\"  [suffix]=\"subfield.suffix\" [copyContent]=\"subfield.copyContent\" [clearContent]=\"subfield.clearContent\"></spa-number>\r\n  \r\n                    <spa-money *ngSwitchCase=\"'money'\" [display]=\"subfield.alias ?? subfield.name | camelToWords\" [width]=\"subfield.width\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [required]=\"testRequired(subfield)\" [min]=\"subfield.min\" [max]=\"subfield.max\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [hint]=\"subfield.hint\" [infoMessage]=\"subfield.infoMessage\" [suffix]=\"subfield.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\"></spa-money>\r\n  \r\n                    <spa-check *ngSwitchCase=\"'checkbox'\" [display]=\"subfield.alias ?? subfield.name | camelToWords\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [infoMessage]=\"subfield.infoMessage\" ></spa-check>\r\n  \r\n                    <spa-date *ngSwitchCase=\"'date'\" [display]=\"subfield.alias ?? subfield.name | camelToWords\" [width]=\"subfield.width\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [min]=\"subfield.min\" [max]=\"subfield.max\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [hint]=\"subfield.hint\" [infoMessage]=\"subfield.infoMessage\" ></spa-date>\r\n  \r\n                    <spa-datetime *ngSwitchCase=\"'datetime'\" [display]=\"subfield.alias ?? subfield.name | camelToWords\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [min]=\"subfield.min\" [max]=\"subfield.max\" [infoMessage]=\"subfield.infoMessage\" ></spa-datetime>\r\n  \r\n                    <ng-container *ngSwitchCase=\"'select'\">\r\n                      <ng-container *ngTemplateOutlet=\"dynamicSelectTemplate; context: {\r\n                                      $implicit: field,\r\n                                      field: field,\r\n                                      data: data,\r\n                                      testReadOnly: testReadOnly.bind(this),\r\n                                      selectChanged: selectChanged.bind(this)\r\n                                    }\">\r\n                      </ng-container>\r\n                    </ng-container>\r\n  \r\n                    <spa-text *ngSwitchDefault [display]=\"subfield.alias ?? subfield.name | camelToWords\" [width]=\"subfield.width\"  [options]=\"subfield.options\" [optionDisplay]=\"subfield.optionDisplay ?? 'name'\" [optionValue]=\"subfield.optionValue ?? 'value'\" [rows]=\"subfield.rows\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [required]=\"testRequired(subfield)\" [min]=\"subfield.min\" [max]=\"subfield.max\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [hint]=\"subfield.hint\" [infoMessage]=\"subfield.infoMessage\"  [suffix]=\"subfield.suffix\" [copyContent]=\"subfield.copyContent\" [clearContent]=\"subfield.clearContent\" [loadAction]=\"subfield.loadAction\" [regex]=\"subfield.regex\"></spa-text>\r\n  \r\n  \r\n                  </ng-container>\r\n                </ng-container>\r\n              </div>\r\n            </div>\r\n          </ng-container>\r\n  \r\n  \r\n          <spa-text *ngSwitchDefault [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [options]=\"field.options\" [optionDisplay]=\"field.optionDisplay ?? 'name'\" [optionValue]=\"field.optionValue ?? 'value'\" [rows]=\"field.rows\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field,data[field.name])\" [required]=\"testRequired(field)\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\"  [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\" [loadAction]=\"field.loadAction\" [regex]=\"field.regex\"></spa-text>\r\n  \r\n        </ng-container>\r\n  \r\n      </ng-container>\r\n  \r\n    </div>\r\n  \r\n  \r\n    <div class=\"span-col-center\" *ngIf=\"config.button\">\r\n      <button mat-raised-button color=\"primary\"  (click)=\"buttonClicked()\"  cdkFocusInitial>{{buttonDisplay}}</button>\r\n    </div>\r\n  \r\n  \r\n  </div>\r\n  <div class=\"notes-section\" *ngIf=\"config.notesConfig\">\r\n    <spa-notes\r\n      [title]=\"config.notesConfig.title || 'Notes'\"\r\n      [notes]=\"config.notesConfig.notes || []\"\r\n      [loadAction]=\"config.notesConfig.loadAction\"\r\n      [loadIDField]=\"config.notesConfig.loadIDField\"\r\n      [data]=\"data\"\r\n      [nameField]=\"config.notesConfig.nameField || 'createdByName'\"\r\n      [dateField]=\"config.notesConfig.dateField || 'createdDate'\"\r\n      [commentField]=\"config.notesConfig.commentField || 'details'\">\r\n    </spa-notes>\r\n  </div>\r\n</div>\r\n\r\n"]}
|
|
296
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/form/form.component.ts","../../../../../../projects/tin-spa/src/lib/components/form/form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ContentChild, EventEmitter, Input, OnInit, Output, TemplateRef } from '@angular/core';\r\nimport { FormConfig, Field, Button, ApiResponse } from '../../classes/Classes';\r\nimport { Core } from '../../classes/TinCore';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { DataServiceLib } from '../../services/datalib.service';\r\nimport { BehaviorSubject } from 'rxjs';\r\nimport { AuthService } from '../../services/auth.service';\r\n\r\n\r\n@Component({\r\n  selector: 'spa-form',\r\n  templateUrl: './form.component.html',\r\n  styleUrls: ['./form.component.css']\r\n})\r\nexport class FormComponent implements OnInit {\r\n\r\n  constructor(private messageService: MessageService, private dataService: DataServiceLib, private authService: AuthService) { }\r\n\r\n  ngOnInit() {\r\n\r\n    this.hasAccess = Core.hasFormAccess(this.config, this.authService.currentRoleSource.value);\r\n\r\n    if (!this.hasAccess) {\r\n      // this.messageService.toast('Access denied'); // Optional - notify user\r\n      return;\r\n    }\r\n\r\n    if (!this.config.fields){\r\n      this.messageService.toast(\"Please Configure Form Fields\")\r\n      return;\r\n    }\r\n\r\n    if (!this.data) {\r\n      this.messageService.toast(\"Please Configure Form Data\")\r\n      return;\r\n    }\r\n\r\n    this.fields = this.config.fields;\r\n\r\n    // Initialize BehaviorSubjects for fields with loadActions\r\n    this.fields?.forEach(field => {\r\n      if (field.loadAction && !field.optionsSubject && !field.masterField) {\r\n        field.optionsSubject = new BehaviorSubject<any[]>([]);\r\n\r\n        // Subscribe to options changes\r\n        field.optionsSubject.subscribe(newOptions => {\r\n          field.options = newOptions;\r\n\r\n          // Update child fields that depend on this field\r\n          if (this.childFields?.some(x => x.masterField === field.name)) {\r\n            this.updateChildOptions(field.name);\r\n          }\r\n        });\r\n      }\r\n    });\r\n\r\n\r\n    if (this.config.multiColumn){\r\n      this.multiColumn = this.config.multiColumn\r\n    }else{\r\n      this.multiColumn = this.fields.length > 2\r\n    }\r\n\r\n    if (this.config?.button?.display){\r\n      this.buttonDisplay = this.config.button.display;\r\n    }\r\n\r\n    this.fileField = this.fields.find(x => x.type == 'file')\r\n\r\n    if (this.config?.button?.action && this.fileField || this.config?.button?.action.url.includes(\"/form\")) {\r\n      this.config.button.action.isFormData = true;\r\n\r\n    }\r\n\r\n    this.childFields = this.fields.filter(x => x.masterField)\r\n\r\n\r\n    this.childFields.forEach(child => {\r\n      let master = this.fields.find(x => x.name == child.masterField)\r\n      if (child.loadAction) {\r\n        this.loadChildMasterOptions(child);\r\n      }else{\r\n        this.updateChildOptions(master.name);\r\n      }\r\n\r\n    });\r\n\r\n    this.fields.forEach(field => {\r\n      if (field.loadAction) {\r\n        this.loadChildMasterOptions(field);\r\n      }\r\n    });\r\n\r\n    this.initializeCompositeFields();\r\n\r\n\r\n    this.applyValueCalculations();\r\n  }\r\n\r\n  @ContentChild('dynamicSelect') dynamicSelectTemplate: TemplateRef<any>;\r\n\r\n  hasAccess = false;\r\n  fileNames\r\n  fileField: Field;\r\n  fileViewField: Field;\r\n  @Input() files: any[] = [];\r\n  fields: Field[];\r\n  buttonDisplay = \"Submit\";\r\n  isProcessing: boolean = false;\r\n  multiColumn: boolean = false;\r\n\r\n  childFields: Field[];\r\n\r\n  @Input() data: any;\r\n  @Input() config: FormConfig;\r\n  @Output() buttonClick = new EventEmitter();\r\n  @Output() inputChange = new EventEmitter();\r\n\r\n  initializeCompositeFields() {\r\n    this.fields.forEach(field => {\r\n      if (field.type === 'composite' && field.subfields) {\r\n        field.subfields.forEach(subfield => {\r\n          if (this.data[subfield.name] === undefined) {\r\n            this.data[subfield.name] = Core.getInitialValue(subfield);\r\n          }\r\n        });\r\n      }\r\n    });\r\n  }\r\n\r\n  private applyValueCalculations() {\r\n    if (!this.data || !this.fields) return;\r\n    \r\n    // Get visible fields that have valueCalculation functions\r\n    const calculatedFields = this.getVisibleFields()\r\n      .filter(field => typeof field.valueCalculation === 'function');\r\n    \r\n    if (calculatedFields.length === 0) return;\r\n    \r\n    // Apply calculations to each field\r\n    calculatedFields.forEach(field => {\r\n      try {\r\n        const calculatedValue = field.valueCalculation(this.data);\r\n        if (calculatedValue !== undefined) {\r\n          this.data[field.name] = calculatedValue;\r\n        }\r\n      } catch (error) {\r\n        console.error(`Error calculating value for field ${field.name}:`, error);\r\n      }\r\n    });\r\n  }\r\n\r\n  getVisibleSubfields(field : Field){\r\n    return Core.getVisibleSubfields(this.config, this.data, field, this.authService.currentRoleSource.value);\r\n\r\n\r\n  }\r\n\r\n\r\n  getVisibleFields() {\r\n    let visibleFields = this.fields?.filter(x => Core.testVisible(this.config, this.data, x, this.authService.currentRoleSource.value)) ?? [];\r\n\r\n    // Filter out fields under collapsed sections\r\n    return visibleFields.filter(field => {\r\n      if (field.type === 'section') return true;\r\n      if (field.section) {\r\n        const sectionField = this.fields.find(f => f.type === 'section' && f.name === field.section);\r\n        return !sectionField?.collapsed;\r\n      }\r\n      return true;\r\n    });\r\n  }\r\n\r\n  testReadOnly(field: Field): boolean {\r\n    return Core.testReadOnly(this.config, this.data, field);\r\n  }\r\n\r\n  testRequired(field: Field): boolean {\r\n    return Core.testRequired(this.config, this.data, field);\r\n  }\r\n\r\n  toggleSection(field: Field) {\r\n    if (field.type === 'section') {\r\n      field.collapsed = !field.collapsed;\r\n    }\r\n  }\r\n\r\n  hasSectionFields(sectionName: string): boolean {\r\n    return this.fields?.some(field =>\r\n      field.section === sectionName &&\r\n      Core.testVisible(this.config, this.data, field, this.authService.currentRoleSource.value)\r\n    ) ?? false;\r\n  }\r\n\r\n  shouldSectionCollapse(field: Field): boolean {\r\n    if (field.collapsedCondition) {\r\n      return field.collapsedCondition(this.data);\r\n    }\r\n    return field.collapsed ?? false;\r\n  }\r\n\r\n\r\n  onInfoClick(event: MouseEvent, infoMessage: string): void {\r\n    event.stopPropagation();\r\n    this.messageService.info(infoMessage);\r\n  }\r\n\r\n\r\n  selectChanged(field: Field){\r\n    this.inputChanged(field, this.data[field.name] )\r\n    \r\n    if (field.onSelectChange) {\r\n      field.onSelectChange(this.data[field.name], this.data);\r\n    }\r\n  }\r\n\r\n\r\n\r\n  inputChanged(field : Field, value){\r\n\r\n    this.inputChange.emit({ field: field, value: value})\r\n\r\n    this.updateChildOptions(field.name)\r\n\r\n\r\n    if (this.config.mode == 'create' && field.children){\r\n      field.children.forEach(childConfig => {\r\n        let child = this.fields.find(x => x.name == childConfig.childField)\r\n        this.data[child.name] = field.options.find(x => x[field.optionValue ?? 'value'] == value)[childConfig.childValueField]\r\n      });\r\n    }\r\n\r\n    this.applyValueCalculations();\r\n\r\n  }\r\n\r\n  updateChildOptions(masterFieldName: string){\r\n\r\n    let child = this.childFields.find(x => x.masterField == masterFieldName)\r\n    if (child != null) {\r\n\r\n      //current is master\r\n\r\n\r\n      if (child.masterOptions){\r\n        child.options = child.masterOptions.filter(x => x[child.masterOptionValue ?? 'masterValue'] == this.data[masterFieldName])\r\n      }else{\r\n        console.log(\"Master Options not found\")\r\n      }\r\n\r\n    }\r\n  }\r\n\r\n  private loadChildMasterOptions(child: Field) {\r\n    if (!child.loadAction) return;\r\n\r\n    this.dataService.CallApi(child.loadAction).subscribe((apiResponse: ApiResponse) => {\r\n      if (apiResponse.success) {\r\n\r\n        child.masterOptions = apiResponse.data;\r\n        this.updateChildOptions(child.masterField);\r\n      }\r\n    });\r\n  }\r\n\r\n\r\n  buttonClicked(){\r\n\r\n    this.buttonClick.emit(this.data);\r\n\r\n    let button = this.config.button;\r\n\r\n    if (!button) {\r\n      return;\r\n    }\r\n\r\n    //validation\r\n    let resp = Core.validateObject(this.getVisibleFields(),this.data);\r\n    if (resp != ''){\r\n      this.messageService.toast(resp)\r\n      return;\r\n    }\r\n\r\n\r\n\r\n    if (this.files.length < 1 && this.fileField?.required && this.config.mode =='create') {\r\n      this.messageService.toast(\"Please attach file(s)\");\r\n      return;\r\n    }\r\n\r\n\r\n    if (button.confirm){\r\n\r\n      this.messageService.confirm(`${button.confirm.message}`).subscribe((result) => {\r\n        if (result == \"yes\") {\r\n          this.processCall(button)\r\n        }\r\n      });\r\n\r\n    }else{\r\n      this.processCall(button)\r\n    }\r\n\r\n\r\n\r\n\r\n  }\r\n\r\n  processCall(button: Button){\r\n\r\n    if (!button.action) return\r\n\r\n    let dataOut;\r\n\r\n    if (button.action.isFormData){\r\n\r\n      let formData: FormData = new FormData();\r\n      for (let i = 0; i < this.files.length; i++) {\r\n        formData.append(`uploadFile${i}`, this.files[i], this.files[i].name);\r\n      }\r\n\r\n      formData.append(\"data\", JSON.stringify(this.data));\r\n\r\n\r\n      dataOut = formData\r\n    }else{\r\n\r\n      dataOut = this.data\r\n    }\r\n\r\n\r\n\r\n\r\n    this.isProcessing = true\r\n    this.dataService.CallApi(button.action, dataOut).subscribe((apiResponse) => {\r\n      this.isProcessing = false\r\n\r\n      if (apiResponse.success) {\r\n\r\n        if (button.action.successMessage) {\r\n          this.messageService.toast(button.action.successMessage);\r\n        } else {\r\n          this.messageService.toast(\"Submitted\");\r\n        }\r\n\r\n        if (this.config.reset) {\r\n          Core.resetObject(this.fields, this.data)\r\n          this.files = [];\r\n          this.applyValueCalculations();\r\n        }\r\n\r\n\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse.message);\r\n      }\r\n    });\r\n  }\r\n\r\n  processForm(){\r\n\r\n\r\n\r\n\r\n\r\n  }\r\n\r\n}\r\n\r\n\r\n","\r\n\r\n\r\n<div class=\"tin-form-container\" >\r\n  <div [ngClass]=\"[multiColumn ? 'tin-grid' : 'tin-col', config.notesConfig ? 'width-75' : 'width-100']\" class=\"form-main-content\">\r\n\r\n    <div *ngIf=\"!hasAccess\" class=\"tin-center\">\r\n      <p><em>Access Restricted</em></p>\r\n    </div>\r\n  \r\n    <div [ngClass]=\"field.span || field.type =='section' || field.type =='file' || field.type =='file-view'  ? 'span-col' : ''\" *ngFor=\"let field of getVisibleFields()\">\r\n  \r\n      <ng-container>\r\n  \r\n        <ng-container [ngSwitch]=\"field.type\" class=\"highlight\">\r\n  \r\n          <div *ngSwitchCase=\"'section'\" class=\"title d-flex align-items-center\" (click)=\"toggleSection(field)\" style=\"cursor: pointer;\">\r\n            <label style=\"font-size: larger;margin-right: 10px;\">{{field.alias ?? field.name | camelToWords}}</label>\r\n            <mat-icon *ngIf=\"field.infoMessage\" (click)=\"onInfoClick($event, field.infoMessage)\" style=\"color: steelblue; font-size: 14px;\">info</mat-icon>\r\n            <!-- <button  mat-icon-button class=\"info-icon-button\"  matTooltip=\"Info\" matTooltipPosition=\"above\">\r\n  \r\n            </button> -->\r\n            <mat-icon *ngIf=\"hasSectionFields(field.name)\">{{shouldSectionCollapse(field) ? 'expand_more' : 'expand_less'}}</mat-icon>\r\n          </div>\r\n  \r\n          <ng-container *ngSwitchCase=\"'file'\">\r\n            <div class=\"mt-1 mb-2\" *ngIf=\"config.mode !='view'\">\r\n              <spa-attach [message]=\"field.alias ?? 'Drag and Drop files here'\" [(files)]=\"files\" [fileOptions]=\"field.fileOptions\"></spa-attach>\r\n            </div>\r\n          </ng-container>\r\n  \r\n          <ng-container *ngSwitchCase=\"'file-view'\">\r\n            <div class=\"mt-1 mb-2\" *ngIf=\"config.mode && config.mode !='create'\">\r\n              <spa-viewer [fileAction]=\"field.loadAction\" [path]=\"field.path\" [folderName]=\"data[field.keyField]\" ></spa-viewer>\r\n            </div>\r\n          </ng-container>\r\n  \r\n          <spa-html *ngSwitchCase=\"'html'\" [display]=\"field.alias | camelToWords\" [value]=\"data[field.name]\" [maxHeight]=\"field.maxHeight\"></spa-html>\r\n  \r\n          <label *ngSwitchCase=\"'blank'\"></label>\r\n  \r\n          <label *ngSwitchCase=\"'string'\" [ngStyle]=\"{'font-size':field.size ?? '14px'}\" >{{data[field.name] ?? field.alias ?? field.name}} {{field.suffix ?? ''}}</label>\r\n  \r\n          <spa-label *ngSwitchCase=\"'label'\" [display]=\"field.alias ?? field.name | camelToWords\" [value]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [format]=\"field.format ?? 'text'\" [suffix]=\"field.suffix\" [size]=\"field.size\"></spa-label>\r\n  \r\n          <spa-number *ngSwitchCase=\"'number'\" [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [required]=\"testRequired(field)\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\"></spa-number>\r\n  \r\n          <spa-money *ngSwitchCase=\"'money'\" [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [required]=\"testRequired(field)\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\"></spa-money>\r\n  \r\n          <spa-check *ngSwitchCase=\"'checkbox'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [readonly]=\"testReadOnly(field)\" [infoMessage]=\"field.infoMessage\" ></spa-check>\r\n  \r\n          <spa-date *ngSwitchCase=\"'date'\" [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [min]=\"field?.min\" [max]=\"field?.max\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" ></spa-date>\r\n  \r\n          <spa-datetime *ngSwitchCase=\"'datetime'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [readonly]=\"testReadOnly(field)\" [min]=\"field.min\" [max]=\"field.max\" [infoMessage]=\"field.infoMessage\" ></spa-datetime>\r\n  \r\n          <spa-email *ngSwitchCase=\"'email'\" [display]=\"field.alias ?? field.name | camelToWords\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field,data[field.name])\" [required]=\"testRequired(field)\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\"  [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\"></spa-email>\r\n  \r\n          <spa-text *ngSwitchCase=\"'password'\" [format]=\"'password'\" [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [options]=\"field.options\" [optionValue]=\"field.optionValue ?? 'value'\" [rows]=\"field.rows\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field,data[field.name])\" [required]=\"testRequired(field)\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\"></spa-text>\r\n  \r\n  \r\n          <ng-container *ngSwitchCase=\"'select'\">\r\n            <ng-container *ngTemplateOutlet=\"dynamicSelectTemplate; context: {\r\n                    $implicit: field,\r\n                    field: field,\r\n                    data: data,\r\n                    testReadOnly: testReadOnly.bind(this),\r\n                    testRequired: testRequired.bind(this),\r\n                    selectChanged: selectChanged.bind(this)\r\n                  }\">\r\n            </ng-container>\r\n          </ng-container>\r\n  \r\n  \r\n          <spa-multi-select *ngSwitchCase=\"'multi-select'\" [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [options]=\"field.options\" [optionDisplay]=\"field.optionDisplay ?? 'name'\" [optionValue]=\"field.optionValue ?? 'value'\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field, data[field.name])\" [required]=\"testRequired(field)\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\" [loadAction]=\"field.loadAction\">\r\n          </spa-multi-select>\r\n  \r\n          <spa-multi-text *ngSwitchCase=\"'multi-text'\" [strict]=\"field.strict\" [display]=\"field.alias ?? field.name | camelToWords\" [options]=\"field.options\" [optionDisplay]=\"field.optionDisplay ?? 'name'\" [optionValue]=\"field.optionValue ?? 'value'\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field,data[field.name])\" [required]=\"testRequired(field)\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\" [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\" [loadAction]=\"field.loadAction\"></spa-multi-text>\r\n  \r\n  \r\n  \r\n          <ng-container *ngSwitchCase=\"'composite'\">\r\n            <div class=\"composite-field-container\">\r\n              <div class=\"composite-field-group\">\r\n                <ng-container *ngFor=\"let subfield of getVisibleSubfields(field)\">\r\n                  <ng-container [ngSwitch]=\"subfield.type\">\r\n  \r\n                    <label *ngSwitchCase=\"'string'\" [ngStyle]=\"{'font-size':field.size ?? '14px'}\" >{{data[field.name] ?? field.alias ?? field.name}} {{field.suffix ?? ''}}</label>\r\n                    \r\n                    <spa-number *ngSwitchCase=\"'number'\" [display]=\"subfield.alias ?? subfield.name | camelToWords\" [width]=\"subfield.width\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [required]=\"testRequired(subfield)\" [min]=\"subfield.min\" [max]=\"subfield.max\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [hint]=\"subfield.hint\" [infoMessage]=\"subfield.infoMessage\"  [suffix]=\"subfield.suffix\" [copyContent]=\"subfield.copyContent\" [clearContent]=\"subfield.clearContent\"></spa-number>\r\n  \r\n                    <spa-money *ngSwitchCase=\"'money'\" [display]=\"subfield.alias ?? subfield.name | camelToWords\" [width]=\"subfield.width\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [required]=\"testRequired(subfield)\" [min]=\"subfield.min\" [max]=\"subfield.max\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [hint]=\"subfield.hint\" [infoMessage]=\"subfield.infoMessage\" [suffix]=\"subfield.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\"></spa-money>\r\n  \r\n                    <spa-check *ngSwitchCase=\"'checkbox'\" [display]=\"subfield.alias ?? subfield.name | camelToWords\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [infoMessage]=\"subfield.infoMessage\" ></spa-check>\r\n  \r\n                    <spa-date *ngSwitchCase=\"'date'\" [display]=\"subfield.alias ?? subfield.name | camelToWords\" [width]=\"subfield.width\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [min]=\"subfield.min\" [max]=\"subfield.max\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [hint]=\"subfield.hint\" [infoMessage]=\"subfield.infoMessage\" ></spa-date>\r\n  \r\n                    <spa-datetime *ngSwitchCase=\"'datetime'\" [display]=\"subfield.alias ?? subfield.name | camelToWords\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [min]=\"subfield.min\" [max]=\"subfield.max\" [infoMessage]=\"subfield.infoMessage\" ></spa-datetime>\r\n  \r\n                    <ng-container *ngSwitchCase=\"'select'\">\r\n                      <ng-container *ngTemplateOutlet=\"dynamicSelectTemplate; context: {\r\n                                      $implicit: field,\r\n                                      field: field,\r\n                                      data: data,\r\n                                      testReadOnly: testReadOnly.bind(this),\r\n                                      selectChanged: selectChanged.bind(this)\r\n                                    }\">\r\n                      </ng-container>\r\n                    </ng-container>\r\n  \r\n                    <spa-text *ngSwitchDefault [display]=\"subfield.alias ?? subfield.name | camelToWords\" [width]=\"subfield.width\"  [options]=\"subfield.options\" [optionDisplay]=\"subfield.optionDisplay ?? 'name'\" [optionValue]=\"subfield.optionValue ?? 'value'\" [rows]=\"subfield.rows\" [(value)]=\"data[subfield.name]\" (valueChange)=\"inputChanged(subfield, $event)\" [required]=\"testRequired(subfield)\" [min]=\"subfield.min\" [max]=\"subfield.max\" [readonly]=\"testReadOnly(field) || testReadOnly(subfield)\" [hint]=\"subfield.hint\" [infoMessage]=\"subfield.infoMessage\"  [suffix]=\"subfield.suffix\" [copyContent]=\"subfield.copyContent\" [clearContent]=\"subfield.clearContent\" [loadAction]=\"subfield.loadAction\" [regex]=\"subfield.regex\"></spa-text>\r\n  \r\n  \r\n                  </ng-container>\r\n                </ng-container>\r\n              </div>\r\n            </div>\r\n          </ng-container>\r\n  \r\n  \r\n          <spa-text *ngSwitchDefault [display]=\"field.alias ?? field.name | camelToWords\" [width]=\"field.width\" [options]=\"field.options\" [optionDisplay]=\"field.optionDisplay ?? 'name'\" [optionValue]=\"field.optionValue ?? 'value'\" [rows]=\"field.rows\" [(value)]=\"data[field.name]\" (valueChange)=\"inputChanged(field,data[field.name])\" [required]=\"testRequired(field)\" [min]=\"field.min\" [max]=\"field.max\" [readonly]=\"testReadOnly(field)\" [hint]=\"field.hint\" [infoMessage]=\"field.infoMessage\"  [suffix]=\"field.suffix\" [copyContent]=\"field.copyContent\" [clearContent]=\"field.clearContent\" [loadAction]=\"field.loadAction\" [regex]=\"field.regex\"></spa-text>\r\n  \r\n        </ng-container>\r\n  \r\n      </ng-container>\r\n  \r\n    </div>\r\n  \r\n  \r\n    <div class=\"span-col-center\" *ngIf=\"config.button\">\r\n      <button mat-raised-button color=\"primary\"  (click)=\"buttonClicked()\"  cdkFocusInitial>{{buttonDisplay}}</button>\r\n    </div>\r\n  \r\n  \r\n  </div>\r\n  <div class=\"notes-section\" *ngIf=\"config.notesConfig\">\r\n    <spa-notes\r\n      [title]=\"config.notesConfig.title || 'Notes'\"\r\n      [notes]=\"config.notesConfig.notes || []\"\r\n      [loadAction]=\"config.notesConfig.loadAction\"\r\n      [loadIDField]=\"config.notesConfig.loadIDField\"\r\n      [data]=\"data\"\r\n      [nameField]=\"config.notesConfig.nameField || 'createdByName'\"\r\n      [dateField]=\"config.notesConfig.dateField || 'createdDate'\"\r\n      [commentField]=\"config.notesConfig.commentField || 'details'\">\r\n    </spa-notes>\r\n  </div>\r\n</div>\r\n\r\n"]}
|
|
@@ -265,7 +265,9 @@ export class DetailsDialog {
|
|
|
265
265
|
}
|
|
266
266
|
processButtonAction(button) {
|
|
267
267
|
if (!button.action) {
|
|
268
|
-
|
|
268
|
+
if (!button.keepOpen) {
|
|
269
|
+
this.dialogRef.close({ message: 'emit', data: this.details });
|
|
270
|
+
}
|
|
269
271
|
return;
|
|
270
272
|
}
|
|
271
273
|
if (button.skipValidation || this.validateForm()) {
|
|
@@ -401,4 +403,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
401
403
|
type: Output
|
|
402
404
|
}] } });
|
|
403
405
|
;
|
|
404
|
-
//# 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;QA0DvH,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;QAQ9C,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;QAtFnB,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,YAAY,EAAE,OAAO,EAAE,GAAG,sBAAsB,CAAC,iBAAiB,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QAClJ,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,YAAY,GAAG,YAAY,CAAC;QACjC,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,OAAO,CAAC,CAAC;QACnH,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;IAkCD,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,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;IAClE,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,MAAM,CAAC,cAAc,IAAI,IAAI,CAAC,YAAY,EAAE,EAAE;YAChD,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,IAAI,EAAC;gBACnB,IAAI,CAAC,OAAO,GAAG,WAAW,CAAC,IAAI,CAAC;aACjC;YAED,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,gBAAgB;QACd,OAAO,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE,QAAQ,IAAI,QAAQ,CAAC;IAC/D,CAAC;IAED,YAAY;QACV,OAAO,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE,IAAI,IAAI,QAAQ,CAAC;IAC3D,CAAC;IAED,kBAAkB;QAChB,OAAO,IAAI,CAAC,gBAAgB,EAAE,KAAK,KAAK,CAAC;IAC3C,CAAC;IAED,qBAAqB;QACnB,OAAO,IAAI,CAAC,gBAAgB,EAAE,KAAK,QAAQ,CAAC;IAC9C,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;;0GArcU,aAAa,yKAGkC,eAAe;8FAH9D,aAAa,kGCrB1B,q4NAiJA;2FD5Ha,aAAa;kBALzB,SAAS;+BACE,mBAAmB;;0BAOsB,MAAM;2BAAC,eAAe;+JAuF/D,WAAW;sBAApB,MAAM;;AA6WR,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, StatusConfig, CloseOptions } 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, statusConfig, 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.statusConfig = statusConfig;\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.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  statusConfig : StatusConfig;\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, this.details);\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 (button.skipValidation || 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.data){\r\n        this.details = apiResponse.data;\r\n      }\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  getClosePosition(): 'top' | 'bottom' {\r\n    return this.detailsConfig.closeOptions?.position || 'bottom';\r\n  }\r\n\r\n  getCloseText(): string {\r\n    return this.detailsConfig.closeOptions?.text || 'Cancel';\r\n  }\r\n\r\n  shouldShowTopClose(): boolean {\r\n    return this.getClosePosition() === 'top';\r\n  }\r\n\r\n  shouldShowBottomClose(): boolean {\r\n    return this.getClosePosition() === 'bottom';\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","<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        \r\n        <!-- Added: Top close button when position is 'top' -->\r\n        <button *ngIf=\"shouldShowTopClose()\" [disabled]=\"isProcessing\" mat-icon-button matTooltipPosition=\"above\" matTooltip=\"Close\" (click)=\"close()\"><mat-icon>close</mat-icon></button>\r\n\r\n      </div>\r\n\r\n    </div>\r\n\r\n    <div>\r\n      <spa-steps *ngIf=\"stepConfig && details && stepConfig.sticky\" [config]=\"stepConfig\" [data]=\"details\"></spa-steps>\r\n      <spa-statuses *ngIf=\"statusConfig && details && statusConfig?.sticky\" [config]=\"statusConfig\" [data]=\"details\"></spa-statuses>\r\n      <spa-alert *ngIf=\"formConfig.alertConfig && formConfig.alertConfig?.sticky\" [config]=\"formConfig.alertConfig\" [data]=\"details\"></spa-alert>\r\n    </div>\r\n\r\n\r\n    <mat-dialog-content class=\"mat-typography dialog-scroll-content\">\r\n\r\n      <spa-steps *ngIf=\"stepConfig && details && !stepConfig.sticky\" [config]=\"stepConfig\" [data]=\"details\"></spa-steps>\r\n      <spa-statuses *ngIf=\"statusConfig && details && !statusConfig?.sticky\" [config]=\"statusConfig\" [data]=\"details\"></spa-statuses>\r\n      <spa-alert *ngIf=\"formConfig.alertConfig && !formConfig.alertConfig?.sticky\" [config]=\"formConfig.alertConfig\" [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-testRequired=\"testRequired\" 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              [required]=\"testRequired(field)\"\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=\"formConfig.mode !== 'create' && testVisible(details,btn.name)\" mat-stroked-button [disabled]=\"isProcessing || testDisabled(details,btn.name)\" [ngStyle]=\"{'color': getButtonColor(btn, details)}\" (click)=\"custom(btn)\" cdkFocusInitial>\r\n          <mat-icon *ngIf=\"btn.icon\" [ngStyle]=\"{'color': getButtonColor(btn, details)}\">{{btn.icon.name}}</mat-icon>\r\n          {{btn.display ?? btn.name | titlecase}}\r\n        </button>\r\n      </ng-container>\r\n\r\n      <!-- Changed: Bottom close button now uses conditional display and custom text -->\r\n      <button *ngIf=\"shouldShowBottomClose()\" mat-stroked-button color=\"primary\" (click)=\"close()\">{{getCloseText()}}</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"]}
|
|
406
|
+
//# 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, StatusConfig, CloseOptions } 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, statusConfig, 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.statusConfig = statusConfig;\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.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  statusConfig : StatusConfig;\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, this.details);\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      if (!button.keepOpen) {\r\n        this.dialogRef.close({ message: 'emit', data: this.details });\r\n      }\r\n      return;\r\n    }\r\n\r\n    if (button.skipValidation || 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.data){\r\n        this.details = apiResponse.data;\r\n      }\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  getClosePosition(): 'top' | 'bottom' {\r\n    return this.detailsConfig.closeOptions?.position || 'bottom';\r\n  }\r\n\r\n  getCloseText(): string {\r\n    return this.detailsConfig.closeOptions?.text || 'Cancel';\r\n  }\r\n\r\n  shouldShowTopClose(): boolean {\r\n    return this.getClosePosition() === 'top';\r\n  }\r\n\r\n  shouldShowBottomClose(): boolean {\r\n    return this.getClosePosition() === 'bottom';\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","<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        \r\n        <!-- Added: Top close button when position is 'top' -->\r\n        <button *ngIf=\"shouldShowTopClose()\" [disabled]=\"isProcessing\" mat-icon-button matTooltipPosition=\"above\" matTooltip=\"Close\" (click)=\"close()\"><mat-icon>close</mat-icon></button>\r\n\r\n      </div>\r\n\r\n    </div>\r\n\r\n    <div>\r\n      <spa-steps *ngIf=\"stepConfig && details && stepConfig.sticky\" [config]=\"stepConfig\" [data]=\"details\"></spa-steps>\r\n      <spa-statuses *ngIf=\"statusConfig && details && statusConfig?.sticky\" [config]=\"statusConfig\" [data]=\"details\"></spa-statuses>\r\n      <spa-alert *ngIf=\"formConfig.alertConfig && formConfig.alertConfig?.sticky\" [config]=\"formConfig.alertConfig\" [data]=\"details\"></spa-alert>\r\n    </div>\r\n\r\n\r\n    <mat-dialog-content class=\"mat-typography dialog-scroll-content\">\r\n\r\n      <spa-steps *ngIf=\"stepConfig && details && !stepConfig.sticky\" [config]=\"stepConfig\" [data]=\"details\"></spa-steps>\r\n      <spa-statuses *ngIf=\"statusConfig && details && !statusConfig?.sticky\" [config]=\"statusConfig\" [data]=\"details\"></spa-statuses>\r\n      <spa-alert *ngIf=\"formConfig.alertConfig && !formConfig.alertConfig?.sticky\" [config]=\"formConfig.alertConfig\" [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-testRequired=\"testRequired\" 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              [required]=\"testRequired(field)\"\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=\"formConfig.mode !== 'create' && testVisible(details,btn.name)\" mat-stroked-button [disabled]=\"isProcessing || testDisabled(details,btn.name)\" [ngStyle]=\"{'color': getButtonColor(btn, details)}\" (click)=\"custom(btn)\" cdkFocusInitial>\r\n          <mat-icon *ngIf=\"btn.icon\" [ngStyle]=\"{'color': getButtonColor(btn, details)}\">{{btn.icon.name}}</mat-icon>\r\n          {{btn.display ?? btn.name | titlecase}}\r\n        </button>\r\n      </ng-container>\r\n\r\n      <!-- Changed: Bottom close button now uses conditional display and custom text -->\r\n      <button *ngIf=\"shouldShowBottomClose()\" mat-stroked-button color=\"primary\" (click)=\"close()\">{{getCloseText()}}</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"]}
|