tin-spa 2.4.3 → 2.4.5
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/components/page/page.component.mjs +29 -10
- package/esm2020/lib/components/search/search.component.mjs +3 -3
- package/esm2020/lib/components/table/table.component.mjs +12 -4
- package/esm2020/lib/components/table-internal/table-internal.component.mjs +7 -2
- package/esm2020/lib/components/tiles/tiles.component.mjs +3 -3
- package/fesm2015/tin-spa.mjs +47 -17
- package/fesm2015/tin-spa.mjs.map +1 -1
- package/fesm2020/tin-spa.mjs +47 -15
- package/fesm2020/tin-spa.mjs.map +1 -1
- package/lib/classes/Classes.d.ts +1 -0
- package/lib/components/page/page.component.d.ts +8 -5
- package/package.json +1 -1
|
@@ -74,7 +74,12 @@ export class TableInternalComponent {
|
|
|
74
74
|
this.displayedColumns = this.tableConfigService.setColumns(this.config, this.smallScreen);
|
|
75
75
|
this.displayedButtons = this.buttonService.getDisplayedButtons(this.config?.buttons, this.smallScreen, this.config?.minButtons);
|
|
76
76
|
this.actionsWidth = this.tableConfigService.getActionsWidth(this.displayedButtons);
|
|
77
|
-
|
|
77
|
+
if (this.config?.searchConfig) {
|
|
78
|
+
this.showFilterButton = false;
|
|
79
|
+
}
|
|
80
|
+
if (this.config.showFilterButton === false) {
|
|
81
|
+
this.showFilterButton = false;
|
|
82
|
+
}
|
|
78
83
|
if (this.displayedButtons?.length > 0 && !this.displayedColumns.includes('action')) {
|
|
79
84
|
this.displayedColumns.push('action');
|
|
80
85
|
}
|
|
@@ -415,4 +420,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
415
420
|
}], inputChange: [{
|
|
416
421
|
type: Output
|
|
417
422
|
}] } });
|
|
418
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-internal.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/table-internal/table-internal.component.ts","../../../../../../projects/tin-spa/src/lib/components/table-internal/table-internal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, ViewChild } from '@angular/core';\r\nimport { MatTableDataSource } from '@angular/material/table';\r\nimport { DatePipe, CurrencyPipe } from '@angular/common';\r\nimport { Action, Button, Color, Column, DetailsDialogConfig, FormConfig, Icon, TableConfig, ApiResponse } from '../../classes/Classes';\r\nimport { MatPaginator } from '@angular/material/paginator';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { DetailsDialogInternal } from './detailsDialog-internal.component';\r\nimport { BreakpointObserver, BreakpointState } from '@angular/cdk/layout';\r\nimport { DataServiceLib } from '../../services/datalib.service';\r\nimport {  Core, DetailsDialogProcessor } from '../../classes/TinCore';\r\nimport { Subject } from 'rxjs';\r\nimport { ButtonService } from '../../services/button.service';\r\nimport { DialogService } from '../../services/dialog.service';\r\nimport { TableConfigService } from '../../services/table-config.service';\r\nimport { ConditionService } from '../../services/condition.service';\r\n\r\n@Component({\r\n  selector: 'spa-table-internal',\r\n  templateUrl: './table-internal.component.html',\r\n  styleUrls: ['./table-internal.component.css']\r\n})\r\nexport class TableInternalComponent implements OnInit {\r\n\r\n  constructor(private dataService: DataServiceLib, private messageService: MessageService, private breakpointObserver: BreakpointObserver, public dialog: MatDialog,\r\n    private buttonService: ButtonService, private dialogService: DialogService, private tableConfigService: TableConfigService, private conditionService: ConditionService) {\r\n    // detect screen size changes\r\n    this.breakpointObserver.observe([\"(max-width: 600px)\"]).subscribe((result: BreakpointState) => {\r\n      this.smallScreen = result.matches;\r\n      this.updateTableConfiguration();\r\n    });\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.initializeComponent();\r\n  }\r\n\r\n  ngOnChanges() {\r\n\r\n    if (!this.config.loadAction) {\r\n      this.dataSource = this.data;\r\n      this.tableDataSource = new MatTableDataSource<any>(this.dataSource);\r\n    }\r\n\r\n    setTimeout(() => { this.tableDataSource.paginator = this.tablePaginator; }, 1000)\r\n  }\r\n\r\n\r\n  elevation = \"mat-elevation-z5\";\r\n  actionsWidth = \"50px\";\r\n  showFilterButton = true;\r\n  tileReload: Subject<boolean> = new Subject();\r\n\r\n  smallScreen = false\r\n  // createButton: Button;\r\n\r\n  //Table\r\n  tableDataSource;\r\n  dataSource: any[];\r\n  displayedColumns = []\r\n  displayedButtons = []\r\n  originalTableLoadAction: Action\r\n\r\n  @ViewChild('tablePaginator') tablePaginator: MatPaginator;\r\n\r\n  @Input() hideTitle = false;\r\n  @Input() data: any = [];\r\n  @Input() tileData: any = [];\r\n  @Input() config: TableConfig;\r\n  @Input() reload: Subject<boolean>;\r\n  @Output() dataLoad = new EventEmitter();\r\n  @Output() refreshClick = new EventEmitter();\r\n  @Output() searchClick = new EventEmitter();\r\n  @Output() createClick = new EventEmitter();\r\n  @Output() actionClick = new EventEmitter();\r\n  @Output() inputChange = new EventEmitter();\r\n\r\n  private initializeComponent() {\r\n    this.updateTableConfiguration();\r\n    this.setupDataLoading();\r\n    this.formDefaults();\r\n    this.originalTableLoadAction = Core.getClone(this.config.loadAction);\r\n  }\r\n\r\n  private updateTableConfiguration() {\r\n    this.elevation = this.getElevationClass(this.config?.elevation);\r\n    this.displayedColumns = this.tableConfigService.setColumns(this.config, this.smallScreen);\r\n    this.displayedButtons = this.buttonService.getDisplayedButtons(this.config?.buttons, this.smallScreen, this.config?.minButtons);\r\n    this.actionsWidth = this.tableConfigService.getActionsWidth(this.displayedButtons);\r\n    this.showFilterButton = !this.config?.searchConfig;\r\n\r\n    if (this.displayedButtons?.length > 0 && !this.displayedColumns.includes('action')) {\r\n      this.displayedColumns.push('action');\r\n    }\r\n  }\r\n\r\n  private setupDataLoading() {\r\n    if (this.config.loadAction) {\r\n      this.loadData(this.config.loadAction, \"\");\r\n    }\r\n\r\n    if (this.reload) {\r\n      this.reload.subscribe(v => {\r\n        if (v && this.config?.loadAction) {\r\n          this.loadData(this.config.loadAction, \"\");\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  loadData(action: Action, data: any) {\r\n\r\n    if (action) {\r\n      this.dataService.CallApi(action, data).subscribe((apiResponse: ApiResponse) => {\r\n\r\n        if (this.config.logResponse) {\r\n          console.log(apiResponse)\r\n        }\r\n\r\n        this.dataSource = apiResponse.data\r\n\r\n        this.tableDataSource = new MatTableDataSource<any>(apiResponse.data);\r\n        this.tableDataSource.paginator = this.tablePaginator;\r\n\r\n        if (apiResponse.success) {\r\n          this.tableDataSource = new MatTableDataSource(apiResponse.data);\r\n          this.tableDataSource.paginator = this.tablePaginator;\r\n\r\n          this.dataLoaded(apiResponse.data);\r\n\r\n        } else {\r\n          this.messageService.toast(\"Error: \" + apiResponse.message);\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n\r\n  inputChanged(event) {\r\n    this.inputChange.emit({ field: event.field, value: event.value })\r\n  }\r\n\r\n  formDefaults() {\r\n\r\n    if (!this.config.formConfig) {\r\n      let config = new FormConfig\r\n\r\n      config.fields = []\r\n\r\n      this.config.columns.forEach(column => {\r\n\r\n        let field = { name: column.name, type: column.type }\r\n        config.fields.push(field)\r\n\r\n      });\r\n\r\n      this.config.formConfig = config;\r\n    }\r\n  }\r\n\r\n  setColumns() {\r\n    this.displayedColumns = this.tableConfigService.setColumns(this.config, this.smallScreen);\r\n    this.displayedButtons = this.buttonService.getDisplayedButtons(this.config.buttons, this.smallScreen, this.config.minButtons);\r\n    this.actionsWidth = this.tableConfigService.getActionsWidth(this.displayedButtons);\r\n\r\n    if (this.displayedButtons.length > 0 && !this.displayedColumns.includes('action')) {\r\n      this.displayedColumns.push('action');\r\n    }\r\n  }\r\n\r\n  setButtons() {\r\n    if (!this.config.buttons) return\r\n    if (!this.smallScreen) {\r\n      this.displayedButtons = this.config.buttons;\r\n    } else {\r\n      this.displayedButtons = this.config.buttons;\r\n    }\r\n  }\r\n\r\n  getButton(name: string) {\r\n    return this.buttonService.getButton(this.config.buttons, name);\r\n  }\r\n\r\n  getIcon(buttonName: string) {\r\n    const button = this.getButton(buttonName);\r\n    return this.buttonService.getIcon(button, this.config);\r\n  }\r\n\r\n  getButtonColor(button: Button, row) {\r\n    return this.buttonService.getButtonColor(button, row);\r\n  }\r\n\r\n  getOptions(column) {\r\n    let x = this.config.columns.find(opt => opt.name === column);\r\n    return x\r\n  }\r\n\r\n  getColor(value: any, options: any[]): string {\r\n    return this.conditionService.getColor(value, options);\r\n  }\r\n\r\n  testIconCondition(row: any, icon: Icon): boolean {\r\n    return this.conditionService.testIconCondition(icon, row);\r\n  }\r\n\r\n  testColorCondition(row: any, color: Color): boolean {\r\n    return this.conditionService.testColorCondition(color, row);\r\n  }\r\n\r\n  showBanner(message: string) {\r\n    if (message && message !== '') {\r\n      this.messageService.info(message);\r\n    }\r\n  }\r\n\r\n  testDisabled(row, buttonName: string): boolean {\r\n    const button = this.getButton(buttonName);\r\n    return this.buttonService.testDisabled(button, row);\r\n  }\r\n\r\n  testVisible(row, buttonName: string): boolean {\r\n    const button = this.getButton(buttonName);\r\n    return this.buttonService.testVisible(button, row);\r\n  }\r\n\r\n\r\n\r\n  //Events\r\n  searchClicked(x) {\r\n    this.searchClick.emit(x);\r\n\r\n    if (this.config.searchConfig.searchAction) {\r\n      this.config.searchConfig.searchAction.method == 'post'\r\n      this.loadData(this.config.searchConfig.searchAction, x);\r\n    }\r\n  }\r\n\r\n  tileClicked(tile) {\r\n    this.config.loadAction = Core.getClone(tile.data.action);\r\n    this.refreshClicked();\r\n  }\r\n\r\n  tileUnClicked(tile) {\r\n    this.config.loadAction = Core.getClone(this.originalTableLoadAction);\r\n    this.refreshClicked();\r\n  }\r\n\r\n  refreshClicked() {\r\n    this.refreshClick.emit();\r\n\r\n    if (this.config.loadAction) {\r\n      this.loadData(this.config.loadAction, \"\");\r\n    } else {\r\n      this.dataLoad.emit();\r\n    }\r\n  }\r\n\r\n  dataLoaded(x) {\r\n    this.dataLoad.emit(x)\r\n\r\n    if (this.config.tileConfig?.loadAction) {\r\n      this.tileReload.next(true);\r\n    }\r\n  }\r\n\r\n  actionClicked(name: string, row: any) {\r\n    if (name === 'view') {\r\n      this.viewModel(row);\r\n    } else if (name === 'edit') {\r\n      this.editModel(row);\r\n    } else if (name === 'delete') {\r\n      this.deleteModel(row);\r\n    } else {\r\n      this.customModel(name, row);\r\n    }\r\n  }\r\n\r\n\r\n  //Dialog events\r\n  columnClicked(column: Column, row) {\r\n    if (column.detailsConfig) {\r\n      this.open(column.name, row, column);\r\n    } else {\r\n      this.actionClickedEmit(column.name, row);\r\n    }\r\n  }\r\n\r\n  customModel(name, row) {\r\n    this.open(name, row);\r\n  }\r\n\r\n\r\n  actionClickedEmit(name, row) {\r\n    this.actionClick.emit({ name: name, data: row });\r\n  }\r\n\r\n  viewModel(row) {\r\n    this.open('view', row);\r\n  }\r\n\r\n  newModel() {\r\n    this.open('create', null);\r\n  }\r\n\r\n  editModel(row) {\r\n    this.open('edit', row);\r\n  }\r\n\r\n  private open(buttonName: string, row: any | null, column?: Column): void {\r\n    this.dialogService.openConfiguredDetailsDialog( buttonName, row, this.config, DetailsDialogInternal, column ).subscribe(result => {\r\n      if (result.action === 'doAction') {\r\n        this.doAction(result.name, result.row);\r\n        this.actionClickedEmit(result.name, result.row);\r\n      } else if (result.action === 'inputChange') {\r\n        this.inputChanged(result.change);\r\n      } else if (result.message === 'success') {\r\n        this.actionClickedEmit(buttonName, result.data);\r\n        this.refreshClicked();\r\n      } else if (result.message === 'emit') {\r\n        this.actionClickedEmit(buttonName, result.data);\r\n      }\r\n    });\r\n  }\r\n\r\n  private openDetailsDialog(buttonName: string, row: any | null, column?: Column): void {\r\n    const button = column ? { name: column.name, dialog: true, detailsConfig: column.detailsConfig } : this.getButton(buttonName);\r\n    if (!button) return;\r\n\r\n    if (!button.dialog) {\r\n      this.doAction(button.name, row)\r\n      this.actionClickedEmit(button.name, row);\r\n      return;\r\n    }\r\n\r\n    if (!this.config.formConfig && !button.detailsConfig) {\r\n      this.messageService.toast(\"Please configure form\");\r\n      return;\r\n    }\r\n\r\n    let conf: DetailsDialogConfig = {\r\n      formConfig: this.config.formConfig,\r\n      buttons: this.config.buttons,\r\n      details: row,\r\n    };\r\n\r\n    if (button.detailsConfig) {\r\n      conf = buttonName === 'create'\r\n        ? button.detailsConfig\r\n        : DetailsDialogProcessor.processDetailsConfig(button.detailsConfig, row);\r\n    }\r\n\r\n    if (button.detailsConfig && button.detailsConfig.mode) {\r\n      conf.formConfig.mode = button.detailsConfig.mode;\r\n    } else {\r\n      conf.formConfig.mode = buttonName === 'create' ? 'create' : (buttonName === 'edit' ? 'edit' : 'view');\r\n    }\r\n\r\n    if (buttonName === 'create') {\r\n      conf.heroField = this.config?.heroField;\r\n      conf.heroValue = this.config?.heroValue;\r\n    }\r\n\r\n\r\n\r\n    const dialogResult = this.dialogService.openDetailsDialog(conf, DetailsDialogInternal); // Unique to internal\r\n\r\n    if (buttonName === 'edit') {\r\n      dialogResult.inputChange.subscribe((x) => {\r\n        this.inputChanged(x);\r\n      });\r\n    }\r\n\r\n    dialogResult.afterClosed.subscribe((result) => {\r\n      if (result.message === 'success') {\r\n        this.actionClickedEmit(button.name, result.data);\r\n        this.refreshClicked();\r\n      } else if (result.message === 'emit') {\r\n        this.actionClickedEmit(button.name, result.data);\r\n      }\r\n    });\r\n\r\n  }\r\n\r\n  deleteModel(row) {\r\n\r\n    let button = this.getButton('delete');\r\n    if (!button) return;\r\n\r\n    this.messageService.confirm(`DELETE ?`).subscribe((result) => {\r\n      if (result == \"yes\") {\r\n        this.actionClickedEmit('delete', row)\r\n        this.doAction(button.name, row);\r\n      }\r\n    });\r\n\r\n  }\r\n\r\n\r\n  //Actions\r\n  doAction(buttonName: string, row) {\r\n\r\n    let b = this.getButton(buttonName)\r\n\r\n    if (!b) return;\r\n    if (!b.action) return;\r\n\r\n    if (b.setHeroField && this.config.heroValue){\r\n      row[this.config.heroField] = this.config.heroValue;\r\n    }\r\n\r\n\r\n    if (b.confirm) {\r\n      this.messageService.confirm(`${b.confirm.message}`).subscribe((result) => {\r\n        if (result == \"yes\") {\r\n          this.execAction(b, row)\r\n        }\r\n      });\r\n    } else {\r\n      this.execAction(b, row)\r\n    }\r\n\r\n  }\r\n\r\n  execAction(b: Button, row) {\r\n    this.dataService.CallApi(b.action, row).subscribe((apiResponse) => {\r\n\r\n      if (apiResponse.success) {\r\n        if (b.action.successMessage) {\r\n          this.messageService.toast(b.action.successMessage);\r\n        } else {\r\n          this.messageService.toast(\"Updated\");\r\n        }\r\n\r\n        this.refreshClicked();\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse.message);\r\n      }\r\n    },\r\n      (error) => {\r\n        this.messageService.toast(\"Error: \" + error);\r\n      }\r\n    );\r\n  }\r\n\r\n\r\n  //Misc\r\n  private getElevationClass(elevation: string): string {\r\n\r\n    if (elevation == \"none\") {\r\n      return \"\"\r\n    }\r\n    else if (elevation == \"low\") {\r\n      return \"mat-elevation-z1\"\r\n    }\r\n    else if (elevation == \"medium\") {\r\n      return \"mat-elevation-z5\"\r\n    }\r\n    else if (elevation == \"high\") {\r\n      return \"mat-elevation-z9\"\r\n    }\r\n    else {\r\n      return \"mat-elevation-z5\"\r\n    }\r\n\r\n  }\r\n\r\n\r\n}\r\n","\r\n<!-- Search -->\r\n<spa-search\r\n  *ngIf=\"config.searchConfig\" [config]=\"config.searchConfig\" style=\"margin-bottom: 20px;\" (searchClick)=\"searchClicked($event)\">\r\n</spa-search>\r\n\r\n\r\n<!-- Header -->\r\n<app-table-header\r\n  [config]=\"config\" [data]=\"dataSource\" [hideTitle]=\"false\" [tableDataSource]=\"tableDataSource\" [tileConfig]=\"config.tileConfig\" [tileData]=\"tileData\" [smallScreen]=\"smallScreen\" [hideTitle]=\"hideTitle\"\r\n  [tileReload]=\"tileReload\" [showFilterButton]=\"showFilterButton\" (createClick)=\"newModel()\" (refreshClick)=\"refreshClicked()\">\r\n</app-table-header>\r\n\r\n\r\n<!-- Table -->\r\n<div>\r\n\r\n  <p *ngIf=\"!config\"><em>Configure Table</em></p>\r\n  <p *ngIf=\"!dataSource\"><em>Loading...</em></p>\r\n\r\n  <div *ngIf=\"dataSource && (!smallScreen || (smallScreen && dataSource?.length > 0))\">\r\n\r\n    <table mat-table [dataSource]=\"tableDataSource\" [ngClass]=\"elevation\">\r\n\r\n      <ng-container *ngFor=\"let column of config.columns\" [matColumnDef]=\"column.name\">\r\n        <th mat-header-cell *matHeaderCellDef>{{ column.alias ?? column.name | camelToWords }}</th>\r\n        <td mat-cell *matCellDef=\"let row;\" class=\"right-padding\">\r\n\r\n          <!-- Rows -->\r\n          <app-table-row [column]=\"column\" [row]=\"row\" [config]=\"config\" (actionClick)=\"actionClicked(column.name, row)\" (columnClick)=\"columnClicked(column, row)\" (showBannerEvent)=\"showBanner($event)\">\r\n          </app-table-row>\r\n\r\n        </td>\r\n      </ng-container>\r\n\r\n      <ng-container matColumnDef=\"action\">\r\n        <th mat-header-cell *matHeaderCellDef> Action </th>\r\n        <td mat-cell *matCellDef=\"let row\" [ngStyle]=\"{width:false ? '50px' : actionsWidth}\">\r\n          <div class=\"action-buttons-container\">\r\n\r\n            <!-- Actions -->\r\n            <app-table-action [displayedButtons]=\"displayedButtons\" [config]=\"config\" [row]=\"row\" (actionClick)=\"actionClicked($event.name, $event.row)\">\r\n            </app-table-action>\r\n\r\n          </div>\r\n        </td>\r\n      </ng-container>\r\n\r\n\r\n      <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\r\n      <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\" [ngClass]=\"{'make-gray': config.greyOut && config.greyOut(row)}\"></tr>\r\n    </table>\r\n\r\n  </div>\r\n\r\n  <mat-paginator *ngIf=\"dataSource && (!smallScreen || (smallScreen && dataSource?.length > 0))\" #tablePaginator [pageSizeOptions]=\"config.pageSizes ?? [10, 20, 50]\" showFirstLastButtons></mat-paginator>\r\n\r\n</div>\r\n\r\n<div class=\"tin-center\">\r\n  <p *ngIf=\"dataSource?.length == 0\"><em>{{config.noDataMessage ?? 'No Data'}}</em></p>\r\n</div>\r\n\r\n\r\n"]}
|
|
423
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-internal.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/table-internal/table-internal.component.ts","../../../../../../projects/tin-spa/src/lib/components/table-internal/table-internal.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC1F,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAE7D,OAAO,EAAsD,UAAU,EAAkC,MAAM,uBAAuB,CAAC;AAIvI,OAAO,EAAE,qBAAqB,EAAE,MAAM,oCAAoC,CAAC;AAG3E,OAAO,EAAG,IAAI,EAAE,sBAAsB,EAAE,MAAM,uBAAuB,CAAC;AACtE,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;;;;;;;;;;;;;;;;;;AAW/B,MAAM,OAAO,sBAAsB;IAEjC,YAAoB,WAA2B,EAAU,cAA8B,EAAU,kBAAsC,EAAS,MAAiB,EACvJ,aAA4B,EAAU,aAA4B,EAAU,kBAAsC,EAAU,gBAAkC;QADpJ,gBAAW,GAAX,WAAW,CAAgB;QAAU,mBAAc,GAAd,cAAc,CAAgB;QAAU,uBAAkB,GAAlB,kBAAkB,CAAoB;QAAS,WAAM,GAAN,MAAM,CAAW;QACvJ,kBAAa,GAAb,aAAa,CAAe;QAAU,kBAAa,GAAb,aAAa,CAAe;QAAU,uBAAkB,GAAlB,kBAAkB,CAAoB;QAAU,qBAAgB,GAAhB,gBAAgB,CAAkB;QAuBxK,cAAS,GAAG,kBAAkB,CAAC;QAC/B,iBAAY,GAAG,MAAM,CAAC;QACtB,qBAAgB,GAAG,IAAI,CAAC;QACxB,eAAU,GAAqB,IAAI,OAAO,EAAE,CAAC;QAE7C,gBAAW,GAAG,KAAK,CAAA;QAMnB,qBAAgB,GAAG,EAAE,CAAA;QACrB,qBAAgB,GAAG,EAAE,CAAA;QAKZ,cAAS,GAAG,KAAK,CAAC;QAClB,SAAI,GAAQ,EAAE,CAAC;QACf,aAAQ,GAAQ,EAAE,CAAC;QAGlB,aAAQ,GAAG,IAAI,YAAY,EAAE,CAAC;QAC9B,iBAAY,GAAG,IAAI,YAAY,EAAE,CAAC;QAClC,gBAAW,GAAG,IAAI,YAAY,EAAE,CAAC;QACjC,gBAAW,GAAG,IAAI,YAAY,EAAE,CAAC;QACjC,gBAAW,GAAG,IAAI,YAAY,EAAE,CAAC;QACjC,gBAAW,GAAG,IAAI,YAAY,EAAE,CAAC;QAjDzC,6BAA6B;QAC7B,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,MAAuB,EAAE,EAAE;YAC5F,IAAI,CAAC,WAAW,GAAG,MAAM,CAAC,OAAO,CAAC;YAClC,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAClC,CAAC,CAAC,CAAC;IACL,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAED,WAAW;QAET,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE;YAC3B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC;YAC5B,IAAI,CAAC,eAAe,GAAG,IAAI,kBAAkB,CAAM,IAAI,CAAC,UAAU,CAAC,CAAC;SACrE;QAED,UAAU,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,eAAe,CAAC,SAAS,GAAG,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,CAAA;IACnF,CAAC;IAgCO,mBAAmB;QACzB,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAChC,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACxB,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,IAAI,CAAC,uBAAuB,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;IACvE,CAAC;IAEO,wBAAwB;QAC9B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;QAChE,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;QAC1F,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,aAAa,CAAC,mBAAmB,CAAC,IAAI,CAAC,MAAM,EAAE,OAAO,EAAE,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;QAChI,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,kBAAkB,CAAC,eAAe,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;QAEnF,IAAI,IAAI,CAAC,MAAM,EAAE,YAAY,EAAE;YAC7B,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC;SAC/B;QAED,IAAI,IAAI,CAAC,MAAM,CAAC,gBAAgB,KAAK,KAAK,EAAE;YAC1C,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC;SAC/B;QAED,IAAI,IAAI,CAAC,gBAAgB,EAAE,MAAM,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE;YAClF,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SACtC;IACH,CAAC;IAEO,gBAAgB;QACtB,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE;YAC1B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;SAC3C;QAED,IAAI,IAAI,CAAC,MAAM,EAAE;YACf,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;gBACxB,IAAI,CAAC,IAAI,IAAI,CAAC,MAAM,EAAE,UAAU,EAAE;oBAChC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;iBAC3C;YACH,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IAED,QAAQ,CAAC,MAAc,EAAE,IAAS;QAEhC,IAAI,MAAM,EAAE;YACV,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,SAAS,CAAC,CAAC,WAAwB,EAAE,EAAE;gBAE5E,IAAI,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE;oBAC3B,OAAO,CAAC,GAAG,CAAC,WAAW,CAAC,CAAA;iBACzB;gBAED,IAAI,CAAC,UAAU,GAAG,WAAW,CAAC,IAAI,CAAA;gBAElC,IAAI,CAAC,eAAe,GAAG,IAAI,kBAAkB,CAAM,WAAW,CAAC,IAAI,CAAC,CAAC;gBACrE,IAAI,CAAC,eAAe,CAAC,SAAS,GAAG,IAAI,CAAC,cAAc,CAAC;gBAErD,IAAI,WAAW,CAAC,OAAO,EAAE;oBACvB,IAAI,CAAC,eAAe,GAAG,IAAI,kBAAkB,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;oBAChE,IAAI,CAAC,eAAe,CAAC,SAAS,GAAG,IAAI,CAAC,cAAc,CAAC;oBAErD,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;iBAEnC;qBAAM;oBACL,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,SAAS,GAAG,WAAW,CAAC,OAAO,CAAC,CAAC;iBAC5D;YACH,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IAGD,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;IAED,YAAY;QAEV,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE;YAC3B,IAAI,MAAM,GAAG,IAAI,UAAU,CAAA;YAE3B,MAAM,CAAC,MAAM,GAAG,EAAE,CAAA;YAElB,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;gBAEnC,IAAI,KAAK,GAAG,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,CAAA;gBACpD,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;YAE3B,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,MAAM,CAAC,UAAU,GAAG,MAAM,CAAC;SACjC;IACH,CAAC;IAED,UAAU;QACR,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;QAC1F,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,aAAa,CAAC,mBAAmB,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;QAC9H,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,kBAAkB,CAAC,eAAe,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;QAEnF,IAAI,IAAI,CAAC,gBAAgB,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE;YACjF,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SACtC;IACH,CAAC;IAED,UAAU;QACR,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO;YAAE,OAAM;QAChC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;YACrB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC;SAC7C;aAAM;YACL,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC;SAC7C;IACH,CAAC;IAED,SAAS,CAAC,IAAY;QACpB,OAAO,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;IACjE,CAAC;IAED,OAAO,CAAC,UAAkB;QACxB,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QAC1C,OAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;IACzD,CAAC;IAED,cAAc,CAAC,MAAc,EAAE,GAAG;QAChC,OAAO,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IACxD,CAAC;IAED,UAAU,CAAC,MAAM;QACf,IAAI,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,KAAK,MAAM,CAAC,CAAC;QAC7D,OAAO,CAAC,CAAA;IACV,CAAC;IAED,QAAQ,CAAC,KAAU,EAAE,OAAc;QACjC,OAAO,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;IACxD,CAAC;IAED,iBAAiB,CAAC,GAAQ,EAAE,IAAU;QACpC,OAAO,IAAI,CAAC,gBAAgB,CAAC,iBAAiB,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;IAC5D,CAAC;IAED,kBAAkB,CAAC,GAAQ,EAAE,KAAY;QACvC,OAAO,IAAI,CAAC,gBAAgB,CAAC,kBAAkB,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IAC9D,CAAC;IAED,UAAU,CAAC,OAAe;QACxB,IAAI,OAAO,IAAI,OAAO,KAAK,EAAE,EAAE;YAC7B,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;SACnC;IACH,CAAC;IAED,YAAY,CAAC,GAAG,EAAE,UAAkB;QAClC,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QAC1C,OAAO,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IACtD,CAAC;IAED,WAAW,CAAC,GAAG,EAAE,UAAkB;QACjC,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QAC1C,OAAO,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IACrD,CAAC;IAID,QAAQ;IACR,aAAa,CAAC,CAAC;QACb,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAEzB,IAAI,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,YAAY,EAAE;YACzC,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,YAAY,CAAC,MAAM,IAAI,MAAM,CAAA;YACtD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC;SACzD;IACH,CAAC;IAED,WAAW,CAAC,IAAI;QACd,IAAI,CAAC,MAAM,CAAC,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACzD,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAED,aAAa,CAAC,IAAI;QAChB,IAAI,CAAC,MAAM,CAAC,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC;QACrE,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;QAEzB,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE;YAC1B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;SAC3C;aAAM;YACL,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;SACtB;IACH,CAAC;IAED,UAAU,CAAC,CAAC;QACV,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;QAErB,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU,EAAE,UAAU,EAAE;YACtC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SAC5B;IACH,CAAC;IAED,aAAa,CAAC,IAAY,EAAE,GAAQ;QAClC,IAAI,IAAI,KAAK,MAAM,EAAE;YACnB,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;SACrB;aAAM,IAAI,IAAI,KAAK,MAAM,EAAE;YAC1B,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;SACrB;aAAM,IAAI,IAAI,KAAK,QAAQ,EAAE;YAC5B,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;SACvB;aAAM;YACL,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;SAC7B;IACH,CAAC;IAGD,eAAe;IACf,aAAa,CAAC,MAAc,EAAE,GAAG;QAC/B,IAAI,MAAM,CAAC,aAAa,EAAE;YACxB,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,GAAG,EAAE,MAAM,CAAC,CAAC;SACrC;aAAM;YACL,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;SAC1C;IACH,CAAC;IAED,WAAW,CAAC,IAAI,EAAE,GAAG;QACnB,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;IACvB,CAAC;IAGD,iBAAiB,CAAC,IAAI,EAAE,GAAG;QACzB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,CAAC,CAAC;IACnD,CAAC;IAED,SAAS,CAAC,GAAG;QACX,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IACzB,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC;IAC5B,CAAC;IAED,SAAS,CAAC,GAAG;QACX,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IACzB,CAAC;IAEO,IAAI,CAAC,UAAkB,EAAE,GAAe,EAAE,MAAe;QAC/D,IAAI,CAAC,aAAa,CAAC,2BAA2B,CAAE,UAAU,EAAE,GAAG,EAAE,IAAI,CAAC,MAAM,EAAE,qBAAqB,EAAE,MAAM,CAAE,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE;YAC/H,IAAI,MAAM,CAAC,MAAM,KAAK,UAAU,EAAE;gBAChC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC;gBACvC,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,IAAI,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC;aACjD;iBAAM,IAAI,MAAM,CAAC,MAAM,KAAK,aAAa,EAAE;gBAC1C,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;aAClC;iBAAM,IAAI,MAAM,CAAC,OAAO,KAAK,SAAS,EAAE;gBACvC,IAAI,CAAC,iBAAiB,CAAC,UAAU,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC;gBAChD,IAAI,CAAC,cAAc,EAAE,CAAC;aACvB;iBAAM,IAAI,MAAM,CAAC,OAAO,KAAK,MAAM,EAAE;gBACpC,IAAI,CAAC,iBAAiB,CAAC,UAAU,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC;aACjD;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,iBAAiB,CAAC,UAAkB,EAAE,GAAe,EAAE,MAAe;QAC5E,MAAM,MAAM,GAAG,MAAM,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,aAAa,EAAE,MAAM,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QAC9H,IAAI,CAAC,MAAM;YAAE,OAAO;QAEpB,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE;YAClB,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,EAAE,GAAG,CAAC,CAAA;YAC/B,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;YACzC,OAAO;SACR;QAED,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,IAAI,CAAC,MAAM,CAAC,aAAa,EAAE;YACpD,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,uBAAuB,CAAC,CAAC;YACnD,OAAO;SACR;QAED,IAAI,IAAI,GAAwB;YAC9B,UAAU,EAAE,IAAI,CAAC,MAAM,CAAC,UAAU;YAClC,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,OAAO;YAC5B,OAAO,EAAE,GAAG;SACb,CAAC;QAEF,IAAI,MAAM,CAAC,aAAa,EAAE;YACxB,IAAI,GAAG,UAAU,KAAK,QAAQ;gBAC5B,CAAC,CAAC,MAAM,CAAC,aAAa;gBACtB,CAAC,CAAC,sBAAsB,CAAC,oBAAoB,CAAC,MAAM,CAAC,aAAa,EAAE,GAAG,CAAC,CAAC;SAC5E;QAED,IAAI,MAAM,CAAC,aAAa,IAAI,MAAM,CAAC,aAAa,CAAC,IAAI,EAAE;YACrD,IAAI,CAAC,UAAU,CAAC,IAAI,GAAG,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC;SAClD;aAAM;YACL,IAAI,CAAC,UAAU,CAAC,IAAI,GAAG,UAAU,KAAK,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,UAAU,KAAK,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;SACvG;QAED,IAAI,UAAU,KAAK,QAAQ,EAAE;YAC3B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,MAAM,EAAE,SAAS,CAAC;YACxC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,MAAM,EAAE,SAAS,CAAC;SACzC;QAID,MAAM,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,iBAAiB,CAAC,IAAI,EAAE,qBAAqB,CAAC,CAAC,CAAC,qBAAqB;QAE7G,IAAI,UAAU,KAAK,MAAM,EAAE;YACzB,YAAY,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;gBACvC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;YACvB,CAAC,CAAC,CAAC;SACJ;QAED,YAAY,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YAC5C,IAAI,MAAM,CAAC,OAAO,KAAK,SAAS,EAAE;gBAChC,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC;gBACjD,IAAI,CAAC,cAAc,EAAE,CAAC;aACvB;iBAAM,IAAI,MAAM,CAAC,OAAO,KAAK,MAAM,EAAE;gBACpC,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,IAAI,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC;aAClD;QACH,CAAC,CAAC,CAAC;IAEL,CAAC;IAED,WAAW,CAAC,GAAG;QAEb,IAAI,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;QACtC,IAAI,CAAC,MAAM;YAAE,OAAO;QAEpB,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YAC3D,IAAI,MAAM,IAAI,KAAK,EAAE;gBACnB,IAAI,CAAC,iBAAiB,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAA;gBACrC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;aACjC;QACH,CAAC,CAAC,CAAC;IAEL,CAAC;IAGD,SAAS;IACT,QAAQ,CAAC,UAAkB,EAAE,GAAG;QAE9B,IAAI,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAA;QAElC,IAAI,CAAC,CAAC;YAAE,OAAO;QACf,IAAI,CAAC,CAAC,CAAC,MAAM;YAAE,OAAO;QAEtB,IAAI,CAAC,CAAC,YAAY,IAAI,IAAI,CAAC,MAAM,CAAC,SAAS,EAAC;YAC1C,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC;SACpD;QAGD,IAAI,CAAC,CAAC,OAAO,EAAE;YACb,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;gBACvE,IAAI,MAAM,IAAI,KAAK,EAAE;oBACnB,IAAI,CAAC,UAAU,CAAC,CAAC,EAAE,GAAG,CAAC,CAAA;iBACxB;YACH,CAAC,CAAC,CAAC;SACJ;aAAM;YACL,IAAI,CAAC,UAAU,CAAC,CAAC,EAAE,GAAG,CAAC,CAAA;SACxB;IAEH,CAAC;IAED,UAAU,CAAC,CAAS,EAAE,GAAG;QACvB,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,SAAS,CAAC,CAAC,WAAW,EAAE,EAAE;YAEhE,IAAI,WAAW,CAAC,OAAO,EAAE;gBACvB,IAAI,CAAC,CAAC,MAAM,CAAC,cAAc,EAAE;oBAC3B,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC;iBACpD;qBAAM;oBACL,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;iBACtC;gBAED,IAAI,CAAC,cAAc,EAAE,CAAC;aACvB;iBAAM;gBACL,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,SAAS,GAAG,WAAW,CAAC,OAAO,CAAC,CAAC;aAC5D;QACH,CAAC,EACC,CAAC,KAAK,EAAE,EAAE;YACR,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,SAAS,GAAG,KAAK,CAAC,CAAC;QAC/C,CAAC,CACF,CAAC;IACJ,CAAC;IAGD,MAAM;IACE,iBAAiB,CAAC,SAAiB;QAEzC,IAAI,SAAS,IAAI,MAAM,EAAE;YACvB,OAAO,EAAE,CAAA;SACV;aACI,IAAI,SAAS,IAAI,KAAK,EAAE;YAC3B,OAAO,kBAAkB,CAAA;SAC1B;aACI,IAAI,SAAS,IAAI,QAAQ,EAAE;YAC9B,OAAO,kBAAkB,CAAA;SAC1B;aACI,IAAI,SAAS,IAAI,MAAM,EAAE;YAC5B,OAAO,kBAAkB,CAAA;SAC1B;aACI;YACH,OAAO,kBAAkB,CAAA;SAC1B;IAEH,CAAC;;mHAjcU,sBAAsB;uGAAtB,sBAAsB,8dCtBnC,6sFAgEA;2FD1Ca,sBAAsB;kBALlC,SAAS;+BACE,oBAAoB;mTA6CD,cAAc;sBAA1C,SAAS;uBAAC,gBAAgB;gBAElB,SAAS;sBAAjB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACI,QAAQ;sBAAjB,MAAM;gBACG,YAAY;sBAArB,MAAM;gBACG,WAAW;sBAApB,MAAM;gBACG,WAAW;sBAApB,MAAM;gBACG,WAAW;sBAApB,MAAM;gBACG,WAAW;sBAApB,MAAM","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output, ViewChild } from '@angular/core';\r\nimport { MatTableDataSource } from '@angular/material/table';\r\nimport { DatePipe, CurrencyPipe } from '@angular/common';\r\nimport { Action, Button, Color, Column, DetailsDialogConfig, FormConfig, Icon, TableConfig, ApiResponse } from '../../classes/Classes';\r\nimport { MatPaginator } from '@angular/material/paginator';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { DetailsDialogInternal } from './detailsDialog-internal.component';\r\nimport { BreakpointObserver, BreakpointState } from '@angular/cdk/layout';\r\nimport { DataServiceLib } from '../../services/datalib.service';\r\nimport {  Core, DetailsDialogProcessor } from '../../classes/TinCore';\r\nimport { Subject } from 'rxjs';\r\nimport { ButtonService } from '../../services/button.service';\r\nimport { DialogService } from '../../services/dialog.service';\r\nimport { TableConfigService } from '../../services/table-config.service';\r\nimport { ConditionService } from '../../services/condition.service';\r\n\r\n@Component({\r\n  selector: 'spa-table-internal',\r\n  templateUrl: './table-internal.component.html',\r\n  styleUrls: ['./table-internal.component.css']\r\n})\r\nexport class TableInternalComponent implements OnInit {\r\n\r\n  constructor(private dataService: DataServiceLib, private messageService: MessageService, private breakpointObserver: BreakpointObserver, public dialog: MatDialog,\r\n    private buttonService: ButtonService, private dialogService: DialogService, private tableConfigService: TableConfigService, private conditionService: ConditionService) {\r\n    // detect screen size changes\r\n    this.breakpointObserver.observe([\"(max-width: 600px)\"]).subscribe((result: BreakpointState) => {\r\n      this.smallScreen = result.matches;\r\n      this.updateTableConfiguration();\r\n    });\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.initializeComponent();\r\n  }\r\n\r\n  ngOnChanges() {\r\n\r\n    if (!this.config.loadAction) {\r\n      this.dataSource = this.data;\r\n      this.tableDataSource = new MatTableDataSource<any>(this.dataSource);\r\n    }\r\n\r\n    setTimeout(() => { this.tableDataSource.paginator = this.tablePaginator; }, 1000)\r\n  }\r\n\r\n\r\n  elevation = \"mat-elevation-z5\";\r\n  actionsWidth = \"50px\";\r\n  showFilterButton = true;\r\n  tileReload: Subject<boolean> = new Subject();\r\n\r\n  smallScreen = false\r\n  // createButton: Button;\r\n\r\n  //Table\r\n  tableDataSource;\r\n  dataSource: any[];\r\n  displayedColumns = []\r\n  displayedButtons = []\r\n  originalTableLoadAction: Action\r\n\r\n  @ViewChild('tablePaginator') tablePaginator: MatPaginator;\r\n\r\n  @Input() hideTitle = false;\r\n  @Input() data: any = [];\r\n  @Input() tileData: any = [];\r\n  @Input() config: TableConfig;\r\n  @Input() reload: Subject<boolean>;\r\n  @Output() dataLoad = new EventEmitter();\r\n  @Output() refreshClick = new EventEmitter();\r\n  @Output() searchClick = new EventEmitter();\r\n  @Output() createClick = new EventEmitter();\r\n  @Output() actionClick = new EventEmitter();\r\n  @Output() inputChange = new EventEmitter();\r\n\r\n  private initializeComponent() {\r\n    this.updateTableConfiguration();\r\n    this.setupDataLoading();\r\n    this.formDefaults();\r\n    this.originalTableLoadAction = Core.getClone(this.config.loadAction);\r\n  }\r\n\r\n  private updateTableConfiguration() {\r\n    this.elevation = this.getElevationClass(this.config?.elevation);\r\n    this.displayedColumns = this.tableConfigService.setColumns(this.config, this.smallScreen);\r\n    this.displayedButtons = this.buttonService.getDisplayedButtons(this.config?.buttons, this.smallScreen, this.config?.minButtons);\r\n    this.actionsWidth = this.tableConfigService.getActionsWidth(this.displayedButtons);\r\n\r\n    if (this.config?.searchConfig) {\r\n      this.showFilterButton = false;\r\n    }\r\n\r\n    if (this.config.showFilterButton === false) {\r\n      this.showFilterButton = false;\r\n    }\r\n\r\n    if (this.displayedButtons?.length > 0 && !this.displayedColumns.includes('action')) {\r\n      this.displayedColumns.push('action');\r\n    }\r\n  }\r\n\r\n  private setupDataLoading() {\r\n    if (this.config.loadAction) {\r\n      this.loadData(this.config.loadAction, \"\");\r\n    }\r\n\r\n    if (this.reload) {\r\n      this.reload.subscribe(v => {\r\n        if (v && this.config?.loadAction) {\r\n          this.loadData(this.config.loadAction, \"\");\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  loadData(action: Action, data: any) {\r\n\r\n    if (action) {\r\n      this.dataService.CallApi(action, data).subscribe((apiResponse: ApiResponse) => {\r\n\r\n        if (this.config.logResponse) {\r\n          console.log(apiResponse)\r\n        }\r\n\r\n        this.dataSource = apiResponse.data\r\n\r\n        this.tableDataSource = new MatTableDataSource<any>(apiResponse.data);\r\n        this.tableDataSource.paginator = this.tablePaginator;\r\n\r\n        if (apiResponse.success) {\r\n          this.tableDataSource = new MatTableDataSource(apiResponse.data);\r\n          this.tableDataSource.paginator = this.tablePaginator;\r\n\r\n          this.dataLoaded(apiResponse.data);\r\n\r\n        } else {\r\n          this.messageService.toast(\"Error: \" + apiResponse.message);\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n\r\n  inputChanged(event) {\r\n    this.inputChange.emit({ field: event.field, value: event.value })\r\n  }\r\n\r\n  formDefaults() {\r\n\r\n    if (!this.config.formConfig) {\r\n      let config = new FormConfig\r\n\r\n      config.fields = []\r\n\r\n      this.config.columns.forEach(column => {\r\n\r\n        let field = { name: column.name, type: column.type }\r\n        config.fields.push(field)\r\n\r\n      });\r\n\r\n      this.config.formConfig = config;\r\n    }\r\n  }\r\n\r\n  setColumns() {\r\n    this.displayedColumns = this.tableConfigService.setColumns(this.config, this.smallScreen);\r\n    this.displayedButtons = this.buttonService.getDisplayedButtons(this.config.buttons, this.smallScreen, this.config.minButtons);\r\n    this.actionsWidth = this.tableConfigService.getActionsWidth(this.displayedButtons);\r\n\r\n    if (this.displayedButtons.length > 0 && !this.displayedColumns.includes('action')) {\r\n      this.displayedColumns.push('action');\r\n    }\r\n  }\r\n\r\n  setButtons() {\r\n    if (!this.config.buttons) return\r\n    if (!this.smallScreen) {\r\n      this.displayedButtons = this.config.buttons;\r\n    } else {\r\n      this.displayedButtons = this.config.buttons;\r\n    }\r\n  }\r\n\r\n  getButton(name: string) {\r\n    return this.buttonService.getButton(this.config.buttons, name);\r\n  }\r\n\r\n  getIcon(buttonName: string) {\r\n    const button = this.getButton(buttonName);\r\n    return this.buttonService.getIcon(button, this.config);\r\n  }\r\n\r\n  getButtonColor(button: Button, row) {\r\n    return this.buttonService.getButtonColor(button, row);\r\n  }\r\n\r\n  getOptions(column) {\r\n    let x = this.config.columns.find(opt => opt.name === column);\r\n    return x\r\n  }\r\n\r\n  getColor(value: any, options: any[]): string {\r\n    return this.conditionService.getColor(value, options);\r\n  }\r\n\r\n  testIconCondition(row: any, icon: Icon): boolean {\r\n    return this.conditionService.testIconCondition(icon, row);\r\n  }\r\n\r\n  testColorCondition(row: any, color: Color): boolean {\r\n    return this.conditionService.testColorCondition(color, row);\r\n  }\r\n\r\n  showBanner(message: string) {\r\n    if (message && message !== '') {\r\n      this.messageService.info(message);\r\n    }\r\n  }\r\n\r\n  testDisabled(row, buttonName: string): boolean {\r\n    const button = this.getButton(buttonName);\r\n    return this.buttonService.testDisabled(button, row);\r\n  }\r\n\r\n  testVisible(row, buttonName: string): boolean {\r\n    const button = this.getButton(buttonName);\r\n    return this.buttonService.testVisible(button, row);\r\n  }\r\n\r\n\r\n\r\n  //Events\r\n  searchClicked(x) {\r\n    this.searchClick.emit(x);\r\n\r\n    if (this.config.searchConfig.searchAction) {\r\n      this.config.searchConfig.searchAction.method == 'post'\r\n      this.loadData(this.config.searchConfig.searchAction, x);\r\n    }\r\n  }\r\n\r\n  tileClicked(tile) {\r\n    this.config.loadAction = Core.getClone(tile.data.action);\r\n    this.refreshClicked();\r\n  }\r\n\r\n  tileUnClicked(tile) {\r\n    this.config.loadAction = Core.getClone(this.originalTableLoadAction);\r\n    this.refreshClicked();\r\n  }\r\n\r\n  refreshClicked() {\r\n    this.refreshClick.emit();\r\n\r\n    if (this.config.loadAction) {\r\n      this.loadData(this.config.loadAction, \"\");\r\n    } else {\r\n      this.dataLoad.emit();\r\n    }\r\n  }\r\n\r\n  dataLoaded(x) {\r\n    this.dataLoad.emit(x)\r\n\r\n    if (this.config.tileConfig?.loadAction) {\r\n      this.tileReload.next(true);\r\n    }\r\n  }\r\n\r\n  actionClicked(name: string, row: any) {\r\n    if (name === 'view') {\r\n      this.viewModel(row);\r\n    } else if (name === 'edit') {\r\n      this.editModel(row);\r\n    } else if (name === 'delete') {\r\n      this.deleteModel(row);\r\n    } else {\r\n      this.customModel(name, row);\r\n    }\r\n  }\r\n\r\n\r\n  //Dialog events\r\n  columnClicked(column: Column, row) {\r\n    if (column.detailsConfig) {\r\n      this.open(column.name, row, column);\r\n    } else {\r\n      this.actionClickedEmit(column.name, row);\r\n    }\r\n  }\r\n\r\n  customModel(name, row) {\r\n    this.open(name, row);\r\n  }\r\n\r\n\r\n  actionClickedEmit(name, row) {\r\n    this.actionClick.emit({ name: name, data: row });\r\n  }\r\n\r\n  viewModel(row) {\r\n    this.open('view', row);\r\n  }\r\n\r\n  newModel() {\r\n    this.open('create', null);\r\n  }\r\n\r\n  editModel(row) {\r\n    this.open('edit', row);\r\n  }\r\n\r\n  private open(buttonName: string, row: any | null, column?: Column): void {\r\n    this.dialogService.openConfiguredDetailsDialog( buttonName, row, this.config, DetailsDialogInternal, column ).subscribe(result => {\r\n      if (result.action === 'doAction') {\r\n        this.doAction(result.name, result.row);\r\n        this.actionClickedEmit(result.name, result.row);\r\n      } else if (result.action === 'inputChange') {\r\n        this.inputChanged(result.change);\r\n      } else if (result.message === 'success') {\r\n        this.actionClickedEmit(buttonName, result.data);\r\n        this.refreshClicked();\r\n      } else if (result.message === 'emit') {\r\n        this.actionClickedEmit(buttonName, result.data);\r\n      }\r\n    });\r\n  }\r\n\r\n  private openDetailsDialog(buttonName: string, row: any | null, column?: Column): void {\r\n    const button = column ? { name: column.name, dialog: true, detailsConfig: column.detailsConfig } : this.getButton(buttonName);\r\n    if (!button) return;\r\n\r\n    if (!button.dialog) {\r\n      this.doAction(button.name, row)\r\n      this.actionClickedEmit(button.name, row);\r\n      return;\r\n    }\r\n\r\n    if (!this.config.formConfig && !button.detailsConfig) {\r\n      this.messageService.toast(\"Please configure form\");\r\n      return;\r\n    }\r\n\r\n    let conf: DetailsDialogConfig = {\r\n      formConfig: this.config.formConfig,\r\n      buttons: this.config.buttons,\r\n      details: row,\r\n    };\r\n\r\n    if (button.detailsConfig) {\r\n      conf = buttonName === 'create'\r\n        ? button.detailsConfig\r\n        : DetailsDialogProcessor.processDetailsConfig(button.detailsConfig, row);\r\n    }\r\n\r\n    if (button.detailsConfig && button.detailsConfig.mode) {\r\n      conf.formConfig.mode = button.detailsConfig.mode;\r\n    } else {\r\n      conf.formConfig.mode = buttonName === 'create' ? 'create' : (buttonName === 'edit' ? 'edit' : 'view');\r\n    }\r\n\r\n    if (buttonName === 'create') {\r\n      conf.heroField = this.config?.heroField;\r\n      conf.heroValue = this.config?.heroValue;\r\n    }\r\n\r\n\r\n\r\n    const dialogResult = this.dialogService.openDetailsDialog(conf, DetailsDialogInternal); // Unique to internal\r\n\r\n    if (buttonName === 'edit') {\r\n      dialogResult.inputChange.subscribe((x) => {\r\n        this.inputChanged(x);\r\n      });\r\n    }\r\n\r\n    dialogResult.afterClosed.subscribe((result) => {\r\n      if (result.message === 'success') {\r\n        this.actionClickedEmit(button.name, result.data);\r\n        this.refreshClicked();\r\n      } else if (result.message === 'emit') {\r\n        this.actionClickedEmit(button.name, result.data);\r\n      }\r\n    });\r\n\r\n  }\r\n\r\n  deleteModel(row) {\r\n\r\n    let button = this.getButton('delete');\r\n    if (!button) return;\r\n\r\n    this.messageService.confirm(`DELETE ?`).subscribe((result) => {\r\n      if (result == \"yes\") {\r\n        this.actionClickedEmit('delete', row)\r\n        this.doAction(button.name, row);\r\n      }\r\n    });\r\n\r\n  }\r\n\r\n\r\n  //Actions\r\n  doAction(buttonName: string, row) {\r\n\r\n    let b = this.getButton(buttonName)\r\n\r\n    if (!b) return;\r\n    if (!b.action) return;\r\n\r\n    if (b.setHeroField && this.config.heroValue){\r\n      row[this.config.heroField] = this.config.heroValue;\r\n    }\r\n\r\n\r\n    if (b.confirm) {\r\n      this.messageService.confirm(`${b.confirm.message}`).subscribe((result) => {\r\n        if (result == \"yes\") {\r\n          this.execAction(b, row)\r\n        }\r\n      });\r\n    } else {\r\n      this.execAction(b, row)\r\n    }\r\n\r\n  }\r\n\r\n  execAction(b: Button, row) {\r\n    this.dataService.CallApi(b.action, row).subscribe((apiResponse) => {\r\n\r\n      if (apiResponse.success) {\r\n        if (b.action.successMessage) {\r\n          this.messageService.toast(b.action.successMessage);\r\n        } else {\r\n          this.messageService.toast(\"Updated\");\r\n        }\r\n\r\n        this.refreshClicked();\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse.message);\r\n      }\r\n    },\r\n      (error) => {\r\n        this.messageService.toast(\"Error: \" + error);\r\n      }\r\n    );\r\n  }\r\n\r\n\r\n  //Misc\r\n  private getElevationClass(elevation: string): string {\r\n\r\n    if (elevation == \"none\") {\r\n      return \"\"\r\n    }\r\n    else if (elevation == \"low\") {\r\n      return \"mat-elevation-z1\"\r\n    }\r\n    else if (elevation == \"medium\") {\r\n      return \"mat-elevation-z5\"\r\n    }\r\n    else if (elevation == \"high\") {\r\n      return \"mat-elevation-z9\"\r\n    }\r\n    else {\r\n      return \"mat-elevation-z5\"\r\n    }\r\n\r\n  }\r\n\r\n\r\n}\r\n","\r\n<!-- Search -->\r\n<spa-search\r\n  *ngIf=\"config.searchConfig\" [config]=\"config.searchConfig\" style=\"margin-bottom: 20px;\" (searchClick)=\"searchClicked($event)\">\r\n</spa-search>\r\n\r\n\r\n<!-- Header -->\r\n<app-table-header\r\n  [config]=\"config\" [data]=\"dataSource\" [hideTitle]=\"false\" [tableDataSource]=\"tableDataSource\" [tileConfig]=\"config.tileConfig\" [tileData]=\"tileData\" [smallScreen]=\"smallScreen\" [hideTitle]=\"hideTitle\"\r\n  [tileReload]=\"tileReload\" [showFilterButton]=\"showFilterButton\" (createClick)=\"newModel()\" (refreshClick)=\"refreshClicked()\">\r\n</app-table-header>\r\n\r\n\r\n<!-- Table -->\r\n<div>\r\n\r\n  <p *ngIf=\"!config\"><em>Configure Table</em></p>\r\n  <p *ngIf=\"!dataSource\"><em>Loading...</em></p>\r\n\r\n  <div *ngIf=\"dataSource && (!smallScreen || (smallScreen && dataSource?.length > 0))\">\r\n\r\n    <table mat-table [dataSource]=\"tableDataSource\" [ngClass]=\"elevation\">\r\n\r\n      <ng-container *ngFor=\"let column of config.columns\" [matColumnDef]=\"column.name\">\r\n        <th mat-header-cell *matHeaderCellDef>{{ column.alias ?? column.name | camelToWords }}</th>\r\n        <td mat-cell *matCellDef=\"let row;\" class=\"right-padding\">\r\n\r\n          <!-- Rows -->\r\n          <app-table-row [column]=\"column\" [row]=\"row\" [config]=\"config\" (actionClick)=\"actionClicked(column.name, row)\" (columnClick)=\"columnClicked(column, row)\" (showBannerEvent)=\"showBanner($event)\">\r\n          </app-table-row>\r\n\r\n        </td>\r\n      </ng-container>\r\n\r\n      <ng-container matColumnDef=\"action\">\r\n        <th mat-header-cell *matHeaderCellDef> Action </th>\r\n        <td mat-cell *matCellDef=\"let row\" [ngStyle]=\"{width:false ? '50px' : actionsWidth}\">\r\n          <div class=\"action-buttons-container\">\r\n\r\n            <!-- Actions -->\r\n            <app-table-action [displayedButtons]=\"displayedButtons\" [config]=\"config\" [row]=\"row\" (actionClick)=\"actionClicked($event.name, $event.row)\">\r\n            </app-table-action>\r\n\r\n          </div>\r\n        </td>\r\n      </ng-container>\r\n\r\n\r\n      <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\r\n      <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\" [ngClass]=\"{'make-gray': config.greyOut && config.greyOut(row)}\"></tr>\r\n    </table>\r\n\r\n  </div>\r\n\r\n  <mat-paginator *ngIf=\"dataSource && (!smallScreen || (smallScreen && dataSource?.length > 0))\" #tablePaginator [pageSizeOptions]=\"config.pageSizes ?? [10, 20, 50]\" showFirstLastButtons></mat-paginator>\r\n\r\n</div>\r\n\r\n<div class=\"tin-center\">\r\n  <p *ngIf=\"dataSource?.length == 0\"><em>{{config.noDataMessage ?? 'No Data'}}</em></p>\r\n</div>\r\n\r\n\r\n"]}
|
|
@@ -65,10 +65,10 @@ export class TilesComponent {
|
|
|
65
65
|
}
|
|
66
66
|
}
|
|
67
67
|
TilesComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TilesComponent, deps: [{ token: i1.DataServiceLib }, { token: i2.MessageService }], target: i0.ɵɵFactoryTarget.Component });
|
|
68
|
-
TilesComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TilesComponent, selector: "spa-tiles", inputs: { config: "config", data: "data", reload: "reload" }, outputs: { tileActionSelected: "tileActionSelected", tileClick: "tileClick", tileUnClick: "tileUnClick" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"d-flex row align-items-center justify-content-between\">\r\n <ng-container *ngFor=\"let tile of tiles\">\r\n <mat-card class=\"col\" [class.selected-tile]=\"tile.name === selectedTile\" style=\"margin-left: 5px;margin-right: 5px; padding: 10px 16px ; min-width: 150px; margin-top: 5px;\" (click)=\"clicked(tile)\">\r\n\r\n <!-- Number -->\r\n <div class=\"row d-flex justify-content-center align-items-center\">\r\n <div style=\"text-align: center;font-size: 30px;\">\r\n <mat-label style=\"font-weight:bold;\" *ngIf=\"tile.prefix\" >{{tile.prefix}}</mat-label> \r\n <mat-label style=\"font-weight:bold; text-align: center;\" [ngStyle]=\"{'color':tile.color }\">{{data
|
|
68
|
+
TilesComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TilesComponent, selector: "spa-tiles", inputs: { config: "config", data: "data", reload: "reload" }, outputs: { tileActionSelected: "tileActionSelected", tileClick: "tileClick", tileUnClick: "tileUnClick" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"d-flex row align-items-center justify-content-between\">\r\n <ng-container *ngFor=\"let tile of tiles\">\r\n <mat-card class=\"col\" [class.selected-tile]=\"tile.name === selectedTile\" style=\"margin-left: 5px;margin-right: 5px; padding: 10px 16px ; min-width: 150px; margin-top: 5px;\" (click)=\"clicked(tile)\">\r\n\r\n <!-- Number -->\r\n <div class=\"row d-flex justify-content-center align-items-center\">\r\n <div style=\"text-align: center;font-size: 30px;\">\r\n <mat-label style=\"font-weight:bold;\" *ngIf=\"tile.prefix\" >{{tile.prefix}}</mat-label> \r\n <mat-label style=\"font-weight:bold; text-align: center;\" [ngStyle]=\"{'color':tile.color }\">{{data[tile.name] ?? 0}}</mat-label> \r\n <mat-label style=\"font-weight:bold;\" *ngIf=\"tile.suffix\">{{tile.suffix}}</mat-label>\r\n </div>\r\n </div>\r\n\r\n <!-- Info -->\r\n <div class=\"row d-flex justify-content-center align-items-center\">\r\n <div class=\"d-flex justify-content-center align-items-center\" style=\"text-align: center;\">\r\n <mat-label style=\"padding-left:5px;padding-right:5px; text-align: center;font-size: 14px;\">{{tile.alias ?? tile.name | camelToWords}}</mat-label>\r\n <mat-icon [matTooltip]=\"tile.info\" matTooltipPosition=\"above\" style=\"font-size: 20px; color:steelblue;\">info</mat-icon>\r\n </div>\r\n </div>\r\n\r\n </mat-card>\r\n </ng-container>\r\n</div>\r\n", styles: [".card{min-width:200px;max-width:200px;display:flex;flex-direction:column;align-items:center;padding:5px 10px}.tiles{gap:1;row-gap:5px}.col{transition:all .3s ease;cursor:pointer}.selected-tile{background-color:#e0e0e0;box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.selected-tile mat-label{font-weight:700}.selected-tile{border:2px solid #3f51b5}.col:hover{background-color:#f5f5f5}.selected-tile:hover{background-color:#e0e0e0}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i5.MatLabel, selector: "mat-label" }, { kind: "component", type: i6.MatCard, selector: "mat-card", exportAs: ["matCard"] }, { kind: "directive", type: i7.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "pipe", type: i8.CamelToWordsPipe, name: "camelToWords" }] });
|
|
69
69
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TilesComponent, decorators: [{
|
|
70
70
|
type: Component,
|
|
71
|
-
args: [{ selector: 'spa-tiles', template: "<div class=\"d-flex row align-items-center justify-content-between\">\r\n <ng-container *ngFor=\"let tile of tiles\">\r\n <mat-card class=\"col\" [class.selected-tile]=\"tile.name === selectedTile\" style=\"margin-left: 5px;margin-right: 5px; padding: 10px 16px ; min-width: 150px; margin-top: 5px;\" (click)=\"clicked(tile)\">\r\n\r\n <!-- Number -->\r\n <div class=\"row d-flex justify-content-center align-items-center\">\r\n <div style=\"text-align: center;font-size: 30px;\">\r\n <mat-label style=\"font-weight:bold;\" *ngIf=\"tile.prefix\" >{{tile.prefix}}</mat-label> \r\n <mat-label style=\"font-weight:bold; text-align: center;\" [ngStyle]=\"{'color':tile.color }\">{{data
|
|
71
|
+
args: [{ selector: 'spa-tiles', template: "<div class=\"d-flex row align-items-center justify-content-between\">\r\n <ng-container *ngFor=\"let tile of tiles\">\r\n <mat-card class=\"col\" [class.selected-tile]=\"tile.name === selectedTile\" style=\"margin-left: 5px;margin-right: 5px; padding: 10px 16px ; min-width: 150px; margin-top: 5px;\" (click)=\"clicked(tile)\">\r\n\r\n <!-- Number -->\r\n <div class=\"row d-flex justify-content-center align-items-center\">\r\n <div style=\"text-align: center;font-size: 30px;\">\r\n <mat-label style=\"font-weight:bold;\" *ngIf=\"tile.prefix\" >{{tile.prefix}}</mat-label> \r\n <mat-label style=\"font-weight:bold; text-align: center;\" [ngStyle]=\"{'color':tile.color }\">{{data[tile.name] ?? 0}}</mat-label> \r\n <mat-label style=\"font-weight:bold;\" *ngIf=\"tile.suffix\">{{tile.suffix}}</mat-label>\r\n </div>\r\n </div>\r\n\r\n <!-- Info -->\r\n <div class=\"row d-flex justify-content-center align-items-center\">\r\n <div class=\"d-flex justify-content-center align-items-center\" style=\"text-align: center;\">\r\n <mat-label style=\"padding-left:5px;padding-right:5px; text-align: center;font-size: 14px;\">{{tile.alias ?? tile.name | camelToWords}}</mat-label>\r\n <mat-icon [matTooltip]=\"tile.info\" matTooltipPosition=\"above\" style=\"font-size: 20px; color:steelblue;\">info</mat-icon>\r\n </div>\r\n </div>\r\n\r\n </mat-card>\r\n </ng-container>\r\n</div>\r\n", styles: [".card{min-width:200px;max-width:200px;display:flex;flex-direction:column;align-items:center;padding:5px 10px}.tiles{gap:1;row-gap:5px}.col{transition:all .3s ease;cursor:pointer}.selected-tile{background-color:#e0e0e0;box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.selected-tile mat-label{font-weight:700}.selected-tile{border:2px solid #3f51b5}.col:hover{background-color:#f5f5f5}.selected-tile:hover{background-color:#e0e0e0}\n"] }]
|
|
72
72
|
}], ctorParameters: function () { return [{ type: i1.DataServiceLib }, { type: i2.MessageService }]; }, propDecorators: { config: [{
|
|
73
73
|
type: Input
|
|
74
74
|
}], tileActionSelected: [{
|
|
@@ -82,4 +82,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
82
82
|
}], tileUnClick: [{
|
|
83
83
|
type: Output
|
|
84
84
|
}] } });
|
|
85
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
85
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tiles.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/tiles/tiles.component.ts","../../../../../../projects/tin-spa/src/lib/components/tiles/tiles.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;;;;;;;;;;AAY/E,MAAM,OAAO,cAAc;IAEzB,YAAoB,WAA2B,EAAU,cAA8B;QAAnE,gBAAW,GAAX,WAAW,CAAgB;QAAU,mBAAc,GAAd,cAAc,CAAgB;QA8B7E,uBAAkB,GAAG,IAAI,YAAY,EAAU,CAAC;QAOhD,cAAS,GAAG,IAAI,YAAY,EAAE,CAAC;QAC/B,gBAAW,GAAG,IAAI,YAAY,EAAE,CAAC;QAE3C,iBAAY,GAAW,EAAE,CAAC;IAxCkE,CAAC;IAE7F,QAAQ;QAEN,IAAI,IAAI,CAAC,MAAM,EAAC;YACd,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;YAE/B,IAAI,IAAI,CAAC,MAAM,EAAE,UAAU,IAAI,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE;gBACnD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,UAAU,EAAE,EAAE,CAAC,CAAC;aAC5C;SACF;QAED,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;YAExB,IAAI,CAAC,IAAI,IAAI,EAAC;gBACZ,IAAI,IAAI,CAAC,MAAM,EAAE,UAAU,EAAE;oBAC3B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,UAAU,EAAE,EAAE,CAAC,CAAC;iBAC5C;aACF;QAEH,CAAC,CAAC,CAAC;IAEL,CAAC;IAED,WAAW;IAEX,CAAC;IAiBD,QAAQ,CAAC,MAAc,EAAE,IAAS;QAEhC,IAAI,MAAM,EAAE;YAEV,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,SAAS,CAAC,CAAC,WAAwB,EAAE,EAAE;gBAE5E,IAAI,WAAW,CAAC,OAAO,EAAE;oBACvB,IAAI,CAAC,IAAI,GAAG,WAAW,CAAC,IAAI,CAAA;iBAC7B;qBACI;oBACH,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,SAAS,GAAG,WAAW,CAAC,OAAO,CAAC,CAAC;iBAC5D;YAEH,CAAC,CAAC,CAAC;SACJ;IAEH,CAAC;IAED,OAAO,CAAC,WAAiB;QAIvB,IAAG,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,IAAI,WAAW,CAAC,MAAM,IAAI,SAAS;YAAG,OAAO;QAGtE,IAAG,IAAI,CAAC,YAAY,IAAI,WAAW,CAAC,IAAI,EAAC;YACvC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,WAAW,CAAC,IAAI,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC,CAAC;YACrE,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;SACxB;aAAI;YACH,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAC,IAAI,EAAE,WAAW,CAAC,IAAI,EAAE,IAAI,EAAG,WAAW,EAAC,CAAC,CAAC;YAClE,IAAI,CAAC,YAAY,GAAG,WAAW,CAAC,IAAI,CAAC;SACtC;IAGH,CAAC;IAED,GAAG,CAAC,CAAC;QAEH,IAAI,CAAC,EAAC;YACJ,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;SAC7B;IAEH,CAAC;;2GAvFU,cAAc;+FAAd,cAAc,+OCZ3B,i+CAwBA;2FDZa,cAAc;kBAL1B,SAAS;+BACE,WAAW;kIAmCZ,MAAM;sBAAd,KAAK;gBACI,kBAAkB;sBAA3B,MAAM;gBAGE,IAAI;sBAAZ,KAAK;gBAEG,MAAM;sBAAd,KAAK;gBAEI,SAAS;sBAAlB,MAAM;gBACG,WAAW;sBAApB,MAAM","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport { Action, Tile, TileConfig, ApiResponse } from '../../classes/Classes';\r\nimport { DataServiceLib } from '../../services/datalib.service';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { Subject } from 'rxjs';\r\n\r\n\r\n@Component({\r\n  selector: 'spa-tiles',\r\n  templateUrl: './tiles.component.html',\r\n  styleUrls: ['./tiles.component.css']\r\n})\r\nexport class TilesComponent implements OnInit {\r\n\r\n  constructor(private dataService: DataServiceLib, private messageService: MessageService,) { }\r\n\r\n  ngOnInit(): void {\r\n\r\n    if (this.config){\r\n      this.tiles = this.config.tiles;\r\n\r\n      if (this.config?.loadAction && this.config.loadInit) {\r\n        this.loadData(this.config?.loadAction, \"\");\r\n      }\r\n    }\r\n\r\n    this.reload.subscribe(v => {\r\n\r\n      if (v == true){\r\n        if (this.config?.loadAction) {\r\n          this.loadData(this.config?.loadAction, \"\");\r\n        }\r\n      }\r\n\r\n    });\r\n\r\n  }\r\n\r\n  ngOnChanges() {\r\n\r\n  }\r\n\r\n  tiles: Tile[];\r\n  @Input() config: TileConfig;\r\n  @Output() tileActionSelected = new EventEmitter<Action>();\r\n\r\n\r\n  @Input() data;\r\n  // @Input() clickable: boolean = false;\r\n  @Input() reload: Subject<boolean>;\r\n\r\n  @Output() tileClick = new EventEmitter();\r\n  @Output() tileUnClick = new EventEmitter();\r\n\r\n  selectedTile: string = \"\";\r\n\r\n\r\n  loadData(action: Action, data: any) {\r\n\r\n    if (action) {\r\n\r\n      this.dataService.CallApi(action, data).subscribe((apiResponse: ApiResponse) => {\r\n\r\n        if (apiResponse.success) {\r\n          this.data = apiResponse.data\r\n        }\r\n        else {\r\n          this.messageService.toast(\"Error: \" + apiResponse.message);\r\n        }\r\n\r\n      });\r\n    }\r\n\r\n  }\r\n\r\n  clicked(clickedTile: Tile){\r\n\r\n\r\n\r\n    if(!this.config.clickable || clickedTile.action == undefined ) return;\r\n\r\n\r\n    if(this.selectedTile == clickedTile.name){\r\n      this.tileUnClick.emit({ name: clickedTile.name, data: clickedTile });\r\n      this.selectedTile = \"\";\r\n    }else{\r\n      this.tileClick.emit({name :clickedTile.name, data : clickedTile});\r\n      this.selectedTile = clickedTile.name;\r\n    }\r\n\r\n\r\n  }\r\n\r\n  pop(x){\r\n\r\n    if (x){\r\n      this.messageService.info(x);\r\n    }\r\n\r\n  }\r\n\r\n\r\n\r\n\r\n}\r\n","<div class=\"d-flex row align-items-center justify-content-between\">\r\n  <ng-container *ngFor=\"let tile of tiles\">\r\n    <mat-card class=\"col\" [class.selected-tile]=\"tile.name === selectedTile\" style=\"margin-left: 5px;margin-right: 5px; padding: 10px 16px ; min-width: 150px; margin-top: 5px;\" (click)=\"clicked(tile)\">\r\n\r\n      <!-- Number -->\r\n      <div class=\"row d-flex justify-content-center align-items-center\">\r\n        <div style=\"text-align: center;font-size: 30px;\">\r\n          <mat-label style=\"font-weight:bold;\" *ngIf=\"tile.prefix\" >{{tile.prefix}}</mat-label> &nbsp;\r\n          <mat-label style=\"font-weight:bold; text-align: center;\" [ngStyle]=\"{'color':tile.color }\">{{data[tile.name] ?? 0}}</mat-label>&nbsp;\r\n          <mat-label style=\"font-weight:bold;\" *ngIf=\"tile.suffix\">{{tile.suffix}}</mat-label>\r\n        </div>\r\n      </div>\r\n\r\n      <!-- Info -->\r\n      <div class=\"row d-flex justify-content-center align-items-center\">\r\n        <div class=\"d-flex justify-content-center align-items-center\" style=\"text-align: center;\">\r\n          <mat-label  style=\"padding-left:5px;padding-right:5px; text-align: center;font-size: 14px;\">{{tile.alias ?? tile.name | camelToWords}}</mat-label>\r\n          <mat-icon [matTooltip]=\"tile.info\" matTooltipPosition=\"above\"  style=\"font-size: 20px; color:steelblue;\">info</mat-icon>\r\n        </div>\r\n      </div>\r\n\r\n    </mat-card>\r\n  </ng-container>\r\n</div>\r\n"]}
|
package/fesm2015/tin-spa.mjs
CHANGED
|
@@ -2746,10 +2746,10 @@ class TilesComponent {
|
|
|
2746
2746
|
}
|
|
2747
2747
|
}
|
|
2748
2748
|
TilesComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TilesComponent, deps: [{ token: DataServiceLib }, { token: MessageService }], target: i0.ɵɵFactoryTarget.Component });
|
|
2749
|
-
TilesComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TilesComponent, selector: "spa-tiles", inputs: { config: "config", data: "data", reload: "reload" }, outputs: { tileActionSelected: "tileActionSelected", tileClick: "tileClick", tileUnClick: "tileUnClick" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"d-flex row align-items-center justify-content-between\">\r\n <ng-container *ngFor=\"let tile of tiles\">\r\n <mat-card class=\"col\" [class.selected-tile]=\"tile.name === selectedTile\" style=\"margin-left: 5px;margin-right: 5px; padding: 10px 16px ; min-width: 150px; margin-top: 5px;\" (click)=\"clicked(tile)\">\r\n\r\n <!-- Number -->\r\n <div class=\"row d-flex justify-content-center align-items-center\">\r\n <div style=\"text-align: center;font-size: 30px;\">\r\n <mat-label style=\"font-weight:bold;\" *ngIf=\"tile.prefix\" >{{tile.prefix}}</mat-label> \r\n <mat-label style=\"font-weight:bold; text-align: center;\" [ngStyle]=\"{'color':tile.color }\">{{data
|
|
2749
|
+
TilesComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TilesComponent, selector: "spa-tiles", inputs: { config: "config", data: "data", reload: "reload" }, outputs: { tileActionSelected: "tileActionSelected", tileClick: "tileClick", tileUnClick: "tileUnClick" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"d-flex row align-items-center justify-content-between\">\r\n <ng-container *ngFor=\"let tile of tiles\">\r\n <mat-card class=\"col\" [class.selected-tile]=\"tile.name === selectedTile\" style=\"margin-left: 5px;margin-right: 5px; padding: 10px 16px ; min-width: 150px; margin-top: 5px;\" (click)=\"clicked(tile)\">\r\n\r\n <!-- Number -->\r\n <div class=\"row d-flex justify-content-center align-items-center\">\r\n <div style=\"text-align: center;font-size: 30px;\">\r\n <mat-label style=\"font-weight:bold;\" *ngIf=\"tile.prefix\" >{{tile.prefix}}</mat-label> \r\n <mat-label style=\"font-weight:bold; text-align: center;\" [ngStyle]=\"{'color':tile.color }\">{{data[tile.name] ?? 0}}</mat-label> \r\n <mat-label style=\"font-weight:bold;\" *ngIf=\"tile.suffix\">{{tile.suffix}}</mat-label>\r\n </div>\r\n </div>\r\n\r\n <!-- Info -->\r\n <div class=\"row d-flex justify-content-center align-items-center\">\r\n <div class=\"d-flex justify-content-center align-items-center\" style=\"text-align: center;\">\r\n <mat-label style=\"padding-left:5px;padding-right:5px; text-align: center;font-size: 14px;\">{{tile.alias ?? tile.name | camelToWords}}</mat-label>\r\n <mat-icon [matTooltip]=\"tile.info\" matTooltipPosition=\"above\" style=\"font-size: 20px; color:steelblue;\">info</mat-icon>\r\n </div>\r\n </div>\r\n\r\n </mat-card>\r\n </ng-container>\r\n</div>\r\n", styles: [".card{min-width:200px;max-width:200px;display:flex;flex-direction:column;align-items:center;padding:5px 10px}.tiles{gap:1;row-gap:5px}.col{transition:all .3s ease;cursor:pointer}.selected-tile{background-color:#e0e0e0;box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.selected-tile mat-label{font-weight:700}.selected-tile{border:2px solid #3f51b5}.col:hover{background-color:#f5f5f5}.selected-tile:hover{background-color:#e0e0e0}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i4$1.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i5.MatLabel, selector: "mat-label" }, { kind: "component", type: i15.MatCard, selector: "mat-card", exportAs: ["matCard"] }, { kind: "directive", type: i7.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "pipe", type: CamelToWordsPipe, name: "camelToWords" }] });
|
|
2750
2750
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TilesComponent, decorators: [{
|
|
2751
2751
|
type: Component,
|
|
2752
|
-
args: [{ selector: 'spa-tiles', template: "<div class=\"d-flex row align-items-center justify-content-between\">\r\n <ng-container *ngFor=\"let tile of tiles\">\r\n <mat-card class=\"col\" [class.selected-tile]=\"tile.name === selectedTile\" style=\"margin-left: 5px;margin-right: 5px; padding: 10px 16px ; min-width: 150px; margin-top: 5px;\" (click)=\"clicked(tile)\">\r\n\r\n <!-- Number -->\r\n <div class=\"row d-flex justify-content-center align-items-center\">\r\n <div style=\"text-align: center;font-size: 30px;\">\r\n <mat-label style=\"font-weight:bold;\" *ngIf=\"tile.prefix\" >{{tile.prefix}}</mat-label> \r\n <mat-label style=\"font-weight:bold; text-align: center;\" [ngStyle]=\"{'color':tile.color }\">{{data
|
|
2752
|
+
args: [{ selector: 'spa-tiles', template: "<div class=\"d-flex row align-items-center justify-content-between\">\r\n <ng-container *ngFor=\"let tile of tiles\">\r\n <mat-card class=\"col\" [class.selected-tile]=\"tile.name === selectedTile\" style=\"margin-left: 5px;margin-right: 5px; padding: 10px 16px ; min-width: 150px; margin-top: 5px;\" (click)=\"clicked(tile)\">\r\n\r\n <!-- Number -->\r\n <div class=\"row d-flex justify-content-center align-items-center\">\r\n <div style=\"text-align: center;font-size: 30px;\">\r\n <mat-label style=\"font-weight:bold;\" *ngIf=\"tile.prefix\" >{{tile.prefix}}</mat-label> \r\n <mat-label style=\"font-weight:bold; text-align: center;\" [ngStyle]=\"{'color':tile.color }\">{{data[tile.name] ?? 0}}</mat-label> \r\n <mat-label style=\"font-weight:bold;\" *ngIf=\"tile.suffix\">{{tile.suffix}}</mat-label>\r\n </div>\r\n </div>\r\n\r\n <!-- Info -->\r\n <div class=\"row d-flex justify-content-center align-items-center\">\r\n <div class=\"d-flex justify-content-center align-items-center\" style=\"text-align: center;\">\r\n <mat-label style=\"padding-left:5px;padding-right:5px; text-align: center;font-size: 14px;\">{{tile.alias ?? tile.name | camelToWords}}</mat-label>\r\n <mat-icon [matTooltip]=\"tile.info\" matTooltipPosition=\"above\" style=\"font-size: 20px; color:steelblue;\">info</mat-icon>\r\n </div>\r\n </div>\r\n\r\n </mat-card>\r\n </ng-container>\r\n</div>\r\n", styles: [".card{min-width:200px;max-width:200px;display:flex;flex-direction:column;align-items:center;padding:5px 10px}.tiles{gap:1;row-gap:5px}.col{transition:all .3s ease;cursor:pointer}.selected-tile{background-color:#e0e0e0;box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.selected-tile mat-label{font-weight:700}.selected-tile{border:2px solid #3f51b5}.col:hover{background-color:#f5f5f5}.selected-tile:hover{background-color:#e0e0e0}\n"] }]
|
|
2753
2753
|
}], ctorParameters: function () { return [{ type: DataServiceLib }, { type: MessageService }]; }, propDecorators: { config: [{
|
|
2754
2754
|
type: Input
|
|
2755
2755
|
}], tileActionSelected: [{
|
|
@@ -4161,10 +4161,10 @@ class SearchComponent {
|
|
|
4161
4161
|
}
|
|
4162
4162
|
}
|
|
4163
4163
|
SearchComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: SearchComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
4164
|
-
SearchComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: SearchComponent, selector: "spa-search", inputs: { config: "config" }, outputs: { searchClick: "searchClick" }, ngImport: i0, template: "\n<div class=\"tin-between\">\n\n<div class=\"col tin-row\">\n\n <div *ngFor=\"let field of config.fields\">\n\n <spa-option [type]=\"field.type\" [required]=\"field.required\" [show]=\"field.show\" [display]=\"field.alias ?? field.name | camelToWords\" [options]=\"field.options\" [optionDisplay]=\"field.optionDisplay\" [optionValue]=\"field.optionValue\" [(value)]=\"data[field.name]\" (enterPress)=\"search()\"></spa-option>\n\n </div>\n\n</div>\n\n<div class=\"col-1 tin-end\">\n <button mat-fab color=\"primary\" (click)=\"search()\" matTooltip=\"Search\" matTooltipPosition=\"right\">\n <mat-icon>search</mat-icon>\n </button>\n</div>\n\n\n\n</div>\n\n\n\n", styles: [".tin-row{column-gap:30px}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i3.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i4$1.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i7.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "component", type: OptionComponent, selector: "spa-option", inputs: ["options", "optionValue", "optionDisplay", "readonly", "type", "value", "display", "show", "required"], outputs: ["valueChange", "enterPress"] }, { kind: "pipe", type: CamelToWordsPipe, name: "camelToWords" }] });
|
|
4164
|
+
SearchComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: SearchComponent, selector: "spa-search", inputs: { config: "config" }, outputs: { searchClick: "searchClick" }, ngImport: i0, template: "\n<div class=\"tin-between\">\n\n<div class=\"col tin-row\">\n\n <div *ngFor=\"let field of config.fields\">\n\n <spa-option [type]=\"field.type\" [required]=\"field.required\" [show]=\"field.show\" [display]=\"field.alias ?? field.name | camelToWords\" [options]=\"field.options\" [optionDisplay]=\"field.optionDisplay ?? 'name'\" [optionValue]=\"field.optionValue ?? 'value'\" [(value)]=\"data[field.name]\" (enterPress)=\"search()\"></spa-option>\n\n </div>\n\n</div>\n\n<div class=\"col-1 tin-end\">\n <button mat-fab color=\"primary\" (click)=\"search()\" matTooltip=\"Search\" matTooltipPosition=\"right\">\n <mat-icon>search</mat-icon>\n </button>\n</div>\n\n\n\n</div>\n\n\n\n", styles: [".tin-row{column-gap:30px}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i3.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i4$1.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i7.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "component", type: OptionComponent, selector: "spa-option", inputs: ["options", "optionValue", "optionDisplay", "readonly", "type", "value", "display", "show", "required"], outputs: ["valueChange", "enterPress"] }, { kind: "pipe", type: CamelToWordsPipe, name: "camelToWords" }] });
|
|
4165
4165
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: SearchComponent, decorators: [{
|
|
4166
4166
|
type: Component,
|
|
4167
|
-
args: [{ selector: 'spa-search', template: "\n<div class=\"tin-between\">\n\n<div class=\"col tin-row\">\n\n <div *ngFor=\"let field of config.fields\">\n\n <spa-option [type]=\"field.type\" [required]=\"field.required\" [show]=\"field.show\" [display]=\"field.alias ?? field.name | camelToWords\" [options]=\"field.options\" [optionDisplay]=\"field.optionDisplay\" [optionValue]=\"field.optionValue\" [(value)]=\"data[field.name]\" (enterPress)=\"search()\"></spa-option>\n\n </div>\n\n</div>\n\n<div class=\"col-1 tin-end\">\n <button mat-fab color=\"primary\" (click)=\"search()\" matTooltip=\"Search\" matTooltipPosition=\"right\">\n <mat-icon>search</mat-icon>\n </button>\n</div>\n\n\n\n</div>\n\n\n\n", styles: [".tin-row{column-gap:30px}\n"] }]
|
|
4167
|
+
args: [{ selector: 'spa-search', template: "\n<div class=\"tin-between\">\n\n<div class=\"col tin-row\">\n\n <div *ngFor=\"let field of config.fields\">\n\n <spa-option [type]=\"field.type\" [required]=\"field.required\" [show]=\"field.show\" [display]=\"field.alias ?? field.name | camelToWords\" [options]=\"field.options\" [optionDisplay]=\"field.optionDisplay ?? 'name'\" [optionValue]=\"field.optionValue ?? 'value'\" [(value)]=\"data[field.name]\" (enterPress)=\"search()\"></spa-option>\n\n </div>\n\n</div>\n\n<div class=\"col-1 tin-end\">\n <button mat-fab color=\"primary\" (click)=\"search()\" matTooltip=\"Search\" matTooltipPosition=\"right\">\n <mat-icon>search</mat-icon>\n </button>\n</div>\n\n\n\n</div>\n\n\n\n", styles: [".tin-row{column-gap:30px}\n"] }]
|
|
4168
4168
|
}], ctorParameters: function () { return []; }, propDecorators: { config: [{
|
|
4169
4169
|
type: Input
|
|
4170
4170
|
}], searchClick: [{
|
|
@@ -4509,7 +4509,12 @@ class TableInternalComponent {
|
|
|
4509
4509
|
this.displayedColumns = this.tableConfigService.setColumns(this.config, this.smallScreen);
|
|
4510
4510
|
this.displayedButtons = this.buttonService.getDisplayedButtons((_b = this.config) === null || _b === void 0 ? void 0 : _b.buttons, this.smallScreen, (_c = this.config) === null || _c === void 0 ? void 0 : _c.minButtons);
|
|
4511
4511
|
this.actionsWidth = this.tableConfigService.getActionsWidth(this.displayedButtons);
|
|
4512
|
-
|
|
4512
|
+
if ((_d = this.config) === null || _d === void 0 ? void 0 : _d.searchConfig) {
|
|
4513
|
+
this.showFilterButton = false;
|
|
4514
|
+
}
|
|
4515
|
+
if (this.config.showFilterButton === false) {
|
|
4516
|
+
this.showFilterButton = false;
|
|
4517
|
+
}
|
|
4513
4518
|
if (((_e = this.displayedButtons) === null || _e === void 0 ? void 0 : _e.length) > 0 && !this.displayedColumns.includes('action')) {
|
|
4514
4519
|
this.displayedColumns.push('action');
|
|
4515
4520
|
}
|
|
@@ -5135,7 +5140,12 @@ class TableComponent {
|
|
|
5135
5140
|
this.displayedColumns = this.tableConfigService.setColumns(this.config, this.smallScreen);
|
|
5136
5141
|
this.displayedButtons = this.buttonService.getDisplayedButtons((_b = this.config) === null || _b === void 0 ? void 0 : _b.buttons, this.smallScreen, (_c = this.config) === null || _c === void 0 ? void 0 : _c.minButtons);
|
|
5137
5142
|
this.actionsWidth = this.tableConfigService.getActionsWidth(this.displayedButtons);
|
|
5138
|
-
|
|
5143
|
+
if ((_d = this.config) === null || _d === void 0 ? void 0 : _d.searchConfig) {
|
|
5144
|
+
this.showFilterButton = false;
|
|
5145
|
+
}
|
|
5146
|
+
if (this.config.showFilterButton === false) {
|
|
5147
|
+
this.showFilterButton = false;
|
|
5148
|
+
}
|
|
5139
5149
|
if (((_e = this.displayedButtons) === null || _e === void 0 ? void 0 : _e.length) > 0 && !this.displayedColumns.includes('action')) {
|
|
5140
5150
|
this.displayedColumns.push('action');
|
|
5141
5151
|
}
|
|
@@ -5166,6 +5176,9 @@ class TableComponent {
|
|
|
5166
5176
|
this.tableDataSource = new MatTableDataSource(apiResponse.data);
|
|
5167
5177
|
this.tableDataSource.paginator = this.tablePaginator;
|
|
5168
5178
|
this.dataLoaded(apiResponse.data);
|
|
5179
|
+
if (apiResponse.message != "success" && apiResponse.message != "") {
|
|
5180
|
+
this.messageService.toast(apiResponse.message);
|
|
5181
|
+
}
|
|
5169
5182
|
}
|
|
5170
5183
|
else {
|
|
5171
5184
|
this.messageService.toast("Error: " + apiResponse.message);
|
|
@@ -5449,10 +5462,10 @@ class TableComponent {
|
|
|
5449
5462
|
}
|
|
5450
5463
|
}
|
|
5451
5464
|
TableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TableComponent, deps: [{ token: DataServiceLib }, { token: MessageService }, { token: i3$1.BreakpointObserver }, { token: i4.MatDialog }, { token: ButtonService }, { token: DialogService }, { token: TableConfigService }, { token: ConditionService }], target: i0.ɵɵFactoryTarget.Component });
|
|
5452
|
-
TableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TableComponent, selector: "spa-table", inputs: { hideTitle: "hideTitle", data: "data", tileData: "tileData", config: "config", reload: "reload" }, outputs: { dataLoad: "dataLoad", refreshClick: "refreshClick", searchClick: "searchClick", createClick: "createClick", actionClick: "actionClick", inputChange: "inputChange" }, viewQueries: [{ propertyName: "tablePaginator", first: true, predicate: ["tablePaginator"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "\r\n<!-- Search -->\r\n<spa-search\r\n *ngIf=\"config.searchConfig\" [config]=\"config.searchConfig\" style=\"margin-bottom: 20px;\" (searchClick)=\"searchClicked($event)\">\r\n</spa-search>\r\n\r\n<!-- Header -->\r\n<app-table-header\r\n [config]=\"config\" [data]=\"dataSource\" [
|
|
5465
|
+
TableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: TableComponent, selector: "spa-table", inputs: { hideTitle: "hideTitle", data: "data", tileData: "tileData", config: "config", reload: "reload" }, outputs: { dataLoad: "dataLoad", refreshClick: "refreshClick", searchClick: "searchClick", createClick: "createClick", actionClick: "actionClick", inputChange: "inputChange" }, viewQueries: [{ propertyName: "tablePaginator", first: true, predicate: ["tablePaginator"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "\r\n<!-- Search -->\r\n<spa-search\r\n *ngIf=\"config.searchConfig\" [config]=\"config.searchConfig\" style=\"margin-bottom: 20px;\" (searchClick)=\"searchClicked($event)\">\r\n</spa-search>\r\n\r\n<!-- Header -->\r\n<app-table-header\r\n [config]=\"config\" [data]=\"dataSource\" [tableDataSource]=\"tableDataSource\" [tileConfig]=\"config.tileConfig\" [tileData]=\"tileData\" [smallScreen]=\"smallScreen\" [hideTitle]=\"hideTitle\"\r\n [tileReload]=\"tileReload\" [showFilterButton]=\"showFilterButton\" (createClick)=\"newModel()\" (customClick)=\"customModel($event,null)\"\r\n (refreshClick)=\"refreshClicked()\" (tileClick)=\"tileClicked($event)\" (tileUnClick)=\"tileUnClicked($event)\">\r\n</app-table-header>\r\n\r\n\r\n<!-- Table -->\r\n<div>\r\n\r\n <p *ngIf=\"!config\"><em>Configure Table</em></p>\r\n <p *ngIf=\"!dataSource\"><em>Loading...</em></p>\r\n\r\n <div *ngIf=\"dataSource && (!smallScreen || (smallScreen && dataSource?.length > 0))\">\r\n\r\n <table mat-table [dataSource]=\"tableDataSource\" [ngClass]=\"elevation\">\r\n\r\n <ng-container *ngFor=\"let column of config.columns\" [matColumnDef]=\"column.name\">\r\n <th mat-header-cell *matHeaderCellDef >{{ column.alias ?? column.name | camelToWords }}</th>\r\n <td mat-cell *matCellDef=\"let row;\" class=\"right-padding\" >\r\n\r\n <!-- Rows -->\r\n <app-table-row [column]=\"column\" [row]=\"row\" [config]=\"config\"\r\n (actionClick)=\"actionClicked(column.name, row)\" (columnClick)=\"columnClicked(column, row)\" (showBannerEvent)=\"showBanner($event)\">\r\n </app-table-row>\r\n\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container matColumnDef=\"action\">\r\n <th mat-header-cell *matHeaderCellDef> Action </th>\r\n <td mat-cell *matCellDef=\"let row\" [ngStyle]=\"{width:false ? '50px' : actionsWidth}\">\r\n <div class=\"action-buttons-container\">\r\n\r\n <!-- Actions -->\r\n <app-table-action\r\n [displayedButtons]=\"displayedButtons\" [config]=\"config\" [row]=\"row\" (actionClick)=\"actionClicked($event.name, $event.row)\">\r\n </app-table-action>\r\n\r\n </div>\r\n </td>\r\n </ng-container>\r\n\r\n\r\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\r\n <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\" [ngClass]=\"{'make-gray': config.greyOut && config.greyOut(row)}\"></tr>\r\n </table>\r\n\r\n </div>\r\n\r\n <mat-paginator *ngIf=\"dataSource && (!smallScreen || (smallScreen && dataSource?.length > 0))\" #tablePaginator [pageSizeOptions]=\"config.pageSizes ?? [10, 20, 50]\" showFirstLastButtons></mat-paginator>\r\n\r\n</div>\r\n\r\n<div class=\"tin-center\">\r\n <p *ngIf=\"dataSource?.length == 0\"><em>{{config.noDataMessage ?? 'No Data'}}</em></p>\r\n</div>\r\n\r\n\r\n\r\n", styles: [".top{display:flex;flex-direction:row;flex-wrap:wrap;justify-content:space-between;align-items:center;margin-bottom:10px;margin-top:10px}.mat-mini-fab{width:32px;height:32px}.mat-mini-fab mat-icon{font-size:16px;margin-top:-3px}.mat-icon-button{width:32px;height:32px}.mat-icon-button mat-icon{font-size:20px;margin-top:-7px}.col-icon{margin-left:10px}.title{margin-top:10px;font-size:larger;font-weight:300}.make-gray{background-color:#e5e5e5}.right-padding{padding-right:10px}.action-buttons-container{display:flex;justify-content:flex-end;align-items:center}.refreshIcon{font-size:22px!important;margin-top:-7px!important}.dialog-container{display:flex;flex-direction:column;height:100%}.dialog-content{flex:1;display:flex;flex-direction:column}.dialog-scroll-content{flex:1;overflow-y:auto}mat-dialog-actions{flex-shrink:0}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i10.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i10.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i10.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i10.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { kind: "directive", type: i10.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i10.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i10.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i10.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "component", type: i10.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i10.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "component", type: i11$1.MatPaginator, selector: "mat-paginator", inputs: ["disabled"], exportAs: ["matPaginator"] }, { kind: "component", type: SearchComponent, selector: "spa-search", inputs: ["config"], outputs: ["searchClick"] }, { kind: "component", type: TableHeaderComponent, selector: "app-table-header", inputs: ["config", "hideTitle", "tableDataSource", "tileConfig", "smallScreen", "tileReload", "showFilterButton", "data", "tileData"], outputs: ["createClick", "customClick", "refreshClick", "tileClick", "tileUnClick"] }, { kind: "component", type: TableRowComponent, selector: "app-table-row", inputs: ["column", "row", "config"], outputs: ["actionClick", "columnClick", "showBannerEvent"] }, { kind: "component", type: TableActionComponent, selector: "app-table-action", inputs: ["displayedButtons", "config", "row"], outputs: ["actionClick"] }, { kind: "pipe", type: CamelToWordsPipe, name: "camelToWords" }] });
|
|
5453
5466
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: TableComponent, decorators: [{
|
|
5454
5467
|
type: Component,
|
|
5455
|
-
args: [{ selector: 'spa-table', template: "\r\n<!-- Search -->\r\n<spa-search\r\n *ngIf=\"config.searchConfig\" [config]=\"config.searchConfig\" style=\"margin-bottom: 20px;\" (searchClick)=\"searchClicked($event)\">\r\n</spa-search>\r\n\r\n<!-- Header -->\r\n<app-table-header\r\n [config]=\"config\" [data]=\"dataSource\" [
|
|
5468
|
+
args: [{ selector: 'spa-table', template: "\r\n<!-- Search -->\r\n<spa-search\r\n *ngIf=\"config.searchConfig\" [config]=\"config.searchConfig\" style=\"margin-bottom: 20px;\" (searchClick)=\"searchClicked($event)\">\r\n</spa-search>\r\n\r\n<!-- Header -->\r\n<app-table-header\r\n [config]=\"config\" [data]=\"dataSource\" [tableDataSource]=\"tableDataSource\" [tileConfig]=\"config.tileConfig\" [tileData]=\"tileData\" [smallScreen]=\"smallScreen\" [hideTitle]=\"hideTitle\"\r\n [tileReload]=\"tileReload\" [showFilterButton]=\"showFilterButton\" (createClick)=\"newModel()\" (customClick)=\"customModel($event,null)\"\r\n (refreshClick)=\"refreshClicked()\" (tileClick)=\"tileClicked($event)\" (tileUnClick)=\"tileUnClicked($event)\">\r\n</app-table-header>\r\n\r\n\r\n<!-- Table -->\r\n<div>\r\n\r\n <p *ngIf=\"!config\"><em>Configure Table</em></p>\r\n <p *ngIf=\"!dataSource\"><em>Loading...</em></p>\r\n\r\n <div *ngIf=\"dataSource && (!smallScreen || (smallScreen && dataSource?.length > 0))\">\r\n\r\n <table mat-table [dataSource]=\"tableDataSource\" [ngClass]=\"elevation\">\r\n\r\n <ng-container *ngFor=\"let column of config.columns\" [matColumnDef]=\"column.name\">\r\n <th mat-header-cell *matHeaderCellDef >{{ column.alias ?? column.name | camelToWords }}</th>\r\n <td mat-cell *matCellDef=\"let row;\" class=\"right-padding\" >\r\n\r\n <!-- Rows -->\r\n <app-table-row [column]=\"column\" [row]=\"row\" [config]=\"config\"\r\n (actionClick)=\"actionClicked(column.name, row)\" (columnClick)=\"columnClicked(column, row)\" (showBannerEvent)=\"showBanner($event)\">\r\n </app-table-row>\r\n\r\n </td>\r\n </ng-container>\r\n\r\n <ng-container matColumnDef=\"action\">\r\n <th mat-header-cell *matHeaderCellDef> Action </th>\r\n <td mat-cell *matCellDef=\"let row\" [ngStyle]=\"{width:false ? '50px' : actionsWidth}\">\r\n <div class=\"action-buttons-container\">\r\n\r\n <!-- Actions -->\r\n <app-table-action\r\n [displayedButtons]=\"displayedButtons\" [config]=\"config\" [row]=\"row\" (actionClick)=\"actionClicked($event.name, $event.row)\">\r\n </app-table-action>\r\n\r\n </div>\r\n </td>\r\n </ng-container>\r\n\r\n\r\n <tr mat-header-row *matHeaderRowDef=\"displayedColumns\"></tr>\r\n <tr mat-row *matRowDef=\"let row; columns: displayedColumns;\" [ngClass]=\"{'make-gray': config.greyOut && config.greyOut(row)}\"></tr>\r\n </table>\r\n\r\n </div>\r\n\r\n <mat-paginator *ngIf=\"dataSource && (!smallScreen || (smallScreen && dataSource?.length > 0))\" #tablePaginator [pageSizeOptions]=\"config.pageSizes ?? [10, 20, 50]\" showFirstLastButtons></mat-paginator>\r\n\r\n</div>\r\n\r\n<div class=\"tin-center\">\r\n <p *ngIf=\"dataSource?.length == 0\"><em>{{config.noDataMessage ?? 'No Data'}}</em></p>\r\n</div>\r\n\r\n\r\n\r\n", styles: [".top{display:flex;flex-direction:row;flex-wrap:wrap;justify-content:space-between;align-items:center;margin-bottom:10px;margin-top:10px}.mat-mini-fab{width:32px;height:32px}.mat-mini-fab mat-icon{font-size:16px;margin-top:-3px}.mat-icon-button{width:32px;height:32px}.mat-icon-button mat-icon{font-size:20px;margin-top:-7px}.col-icon{margin-left:10px}.title{margin-top:10px;font-size:larger;font-weight:300}.make-gray{background-color:#e5e5e5}.right-padding{padding-right:10px}.action-buttons-container{display:flex;justify-content:flex-end;align-items:center}.refreshIcon{font-size:22px!important;margin-top:-7px!important}.dialog-container{display:flex;flex-direction:column;height:100%}.dialog-content{flex:1;display:flex;flex-direction:column}.dialog-scroll-content{flex:1;overflow-y:auto}mat-dialog-actions{flex-shrink:0}\n"] }]
|
|
5456
5469
|
}], ctorParameters: function () { return [{ type: DataServiceLib }, { type: MessageService }, { type: i3$1.BreakpointObserver }, { type: i4.MatDialog }, { type: ButtonService }, { type: DialogService }, { type: TableConfigService }, { type: ConditionService }]; }, propDecorators: { tablePaginator: [{
|
|
5457
5470
|
type: ViewChild,
|
|
5458
5471
|
args: ['tablePaginator']
|
|
@@ -6654,12 +6667,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
6654
6667
|
}], ctorParameters: function () { return []; } });
|
|
6655
6668
|
|
|
6656
6669
|
class PageComponent {
|
|
6657
|
-
constructor(
|
|
6658
|
-
this.messageService = messageService;
|
|
6670
|
+
constructor(dataServiceLib, messageService) {
|
|
6659
6671
|
this.dataServiceLib = dataServiceLib;
|
|
6672
|
+
this.messageService = messageService;
|
|
6660
6673
|
this.searchModeActivated = new EventEmitter();
|
|
6674
|
+
this.searchModeDeactivated = new EventEmitter();
|
|
6675
|
+
this.refreshClick = new EventEmitter();
|
|
6661
6676
|
this.tableReload = new Subject();
|
|
6662
6677
|
this.searchMode = false;
|
|
6678
|
+
this.searchTileData = [];
|
|
6663
6679
|
this.searchTableData = [];
|
|
6664
6680
|
}
|
|
6665
6681
|
ngOnInit() {
|
|
@@ -6670,13 +6686,20 @@ class PageComponent {
|
|
|
6670
6686
|
this.dataServiceLib.CallApi(this.config.searchConfig.searchAction, data).subscribe((apiResponse) => {
|
|
6671
6687
|
this.searchTableData = apiResponse.data.results;
|
|
6672
6688
|
this.searchTileData = apiResponse.data.tiles;
|
|
6689
|
+
if (apiResponse.success && apiResponse.message != "success" && apiResponse.message != "") {
|
|
6690
|
+
this.messageService.toast(apiResponse.message);
|
|
6691
|
+
}
|
|
6673
6692
|
});
|
|
6674
6693
|
}
|
|
6675
6694
|
toggleSearch() {
|
|
6676
6695
|
if (this.searchMode) {
|
|
6677
|
-
// this.loadSearchMeta();
|
|
6678
6696
|
this.searchModeActivated.emit();
|
|
6679
6697
|
}
|
|
6698
|
+
else {
|
|
6699
|
+
this.searchModeDeactivated.emit();
|
|
6700
|
+
this.searchTableData = [];
|
|
6701
|
+
this.searchTileData = [];
|
|
6702
|
+
}
|
|
6680
6703
|
}
|
|
6681
6704
|
getNormalTableConfig() {
|
|
6682
6705
|
return Object.assign(Object.assign({}, this.config.tableConfig), { searchConfig: null });
|
|
@@ -6684,21 +6707,28 @@ class PageComponent {
|
|
|
6684
6707
|
getSearchTableConfig() {
|
|
6685
6708
|
//Basic search
|
|
6686
6709
|
if (this.config.searchConfig && !this.config.searchTableConfig) {
|
|
6687
|
-
return Object.assign(Object.assign({}, this.config.tableConfig), { searchConfig: null, tileConfig: null, holdHeaderButtonSpace: true, buttons: this.config.tableConfig.buttons.filter(x => x.name != 'create'), loadAction: null });
|
|
6710
|
+
return Object.assign(Object.assign({}, this.config.tableConfig), { searchConfig: null, tileConfig: null, holdHeaderButtonSpace: true, buttons: this.config.tableConfig.buttons.filter(x => x.name != 'create'), loadAction: null, showFilterButton: false });
|
|
6688
6711
|
}
|
|
6689
6712
|
//Advanced Search
|
|
6690
|
-
return Object.assign(Object.assign({}, this.config.searchTableConfig), { searchConfig: null, holdHeaderButtonSpace: true, buttons: this.config.tableConfig.buttons.filter(x => x.name != 'create'), loadAction: null });
|
|
6713
|
+
return Object.assign(Object.assign({}, this.config.searchTableConfig), { searchConfig: null, holdHeaderButtonSpace: true, buttons: this.config.tableConfig.buttons.filter(x => x.name != 'create'), loadAction: null, showFilterButton: false });
|
|
6714
|
+
}
|
|
6715
|
+
refreshClicked() {
|
|
6716
|
+
this.refreshClick.emit();
|
|
6691
6717
|
}
|
|
6692
6718
|
}
|
|
6693
|
-
PageComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: PageComponent, deps: [{ token:
|
|
6694
|
-
PageComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: PageComponent, selector: "spa-page", inputs: { config: "config" }, outputs: { searchModeActivated: "searchModeActivated" }, ngImport: i0, template: "<div class=\"row\">\n\n <div class=\"col\">\n <h4>{{config.title ?? 'Untitled'}} </h4>\n </div>\n\n <div class=\"col d-flex justify-content-end\" style=\"font-size: 14px;\">\n <spa-check *ngIf=\"config.searchConfig\" [(value)]=\"searchMode\" display=\"Search Mode\" (valueChange)=\"toggleSearch()\" style=\"margin-right: 10px;\"></spa-check>\n </div>\n\n</div>\n\n<hr style=\"margin-top: 0px;\" />\n\n<!-- Normal -->\n<div *ngIf=\"!searchMode\" style=\" font-size: 14px;\">\n <spa-table [config]=\"getNormalTableConfig()\" [reload]=\"tableReload\"></spa-table>\n</div>\n\n<!-- Search -->\n<div *ngIf=\"searchMode\" style=\" font-size: 14px;\">\n <spa-search [config]=\"config.searchConfig\" (searchClick)=\"searchClicked($event, false)\"></spa-search>\n <spa-table [config]=\"getSearchTableConfig()\" [reload]=\"tableReload\" [data]=\"searchTableData\" [tileData]=\"searchTileData\" (refreshClick)=\"searchClicked(lastSearch, false)\"></spa-table>\n</div>\n", styles: [".mat-mini-fab{width:32px;height:32px}.mat-mini-fab mat-icon{font-size:16px;margin-top:-3px}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: CheckComponent, selector: "spa-check", inputs: ["readonly", "display", "value", "infoMessage"], outputs: ["valueChange", "click", "check", "uncheck", "infoClick"] }, { kind: "component", type: TableComponent, selector: "spa-table", inputs: ["hideTitle", "data", "tileData", "config", "reload"], outputs: ["dataLoad", "refreshClick", "searchClick", "createClick", "actionClick", "inputChange"] }, { kind: "component", type: SearchComponent, selector: "spa-search", inputs: ["config"], outputs: ["searchClick"] }] });
|
|
6719
|
+
PageComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: PageComponent, deps: [{ token: DataServiceLib }, { token: MessageService }], target: i0.ɵɵFactoryTarget.Component });
|
|
6720
|
+
PageComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: PageComponent, selector: "spa-page", inputs: { config: "config" }, outputs: { searchModeActivated: "searchModeActivated", searchModeDeactivated: "searchModeDeactivated", refreshClick: "refreshClick" }, ngImport: i0, template: "<div class=\"row\">\r\n\r\n <div class=\"col\">\r\n <h4>{{config.title ?? 'Untitled'}} </h4>\r\n </div>\r\n\r\n <div class=\"col d-flex justify-content-end\" style=\"font-size: 14px;\">\r\n <spa-check *ngIf=\"config.searchConfig\" [(value)]=\"searchMode\" display=\"Search Mode\" (valueChange)=\"toggleSearch()\" style=\"margin-right: 10px;\"></spa-check>\r\n </div>\r\n\r\n</div>\r\n\r\n<hr style=\"margin-top: 0px;\" />\r\n\r\n<!-- Normal -->\r\n<div *ngIf=\"!searchMode\" style=\" font-size: 14px;\">\r\n <spa-table [config]=\"getNormalTableConfig()\" [reload]=\"tableReload\" (refreshClick)=\"refreshClicked()\"></spa-table>\r\n</div>\r\n\r\n<!-- Search -->\r\n<div *ngIf=\"searchMode\" style=\" font-size: 14px;\">\r\n <spa-search [config]=\"config.searchConfig\" (searchClick)=\"searchClicked($event, false)\"></spa-search>\r\n <spa-table [config]=\"getSearchTableConfig()\" [reload]=\"tableReload\" [data]=\"searchTableData\" [tileData]=\"searchTileData\" (refreshClick)=\"searchClicked(lastSearch, false)\" (refreshClick)=\"refreshClicked()\"></spa-table>\r\n</div>\r\n", styles: [".mat-mini-fab{width:32px;height:32px}.mat-mini-fab mat-icon{font-size:16px;margin-top:-3px}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: CheckComponent, selector: "spa-check", inputs: ["readonly", "display", "value", "infoMessage"], outputs: ["valueChange", "click", "check", "uncheck", "infoClick"] }, { kind: "component", type: TableComponent, selector: "spa-table", inputs: ["hideTitle", "data", "tileData", "config", "reload"], outputs: ["dataLoad", "refreshClick", "searchClick", "createClick", "actionClick", "inputChange"] }, { kind: "component", type: SearchComponent, selector: "spa-search", inputs: ["config"], outputs: ["searchClick"] }] });
|
|
6695
6721
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: PageComponent, decorators: [{
|
|
6696
6722
|
type: Component,
|
|
6697
|
-
args: [{ selector: 'spa-page', template: "<div class=\"row\">\n\n <div class=\"col\">\n <h4>{{config.title ?? 'Untitled'}} </h4>\n </div>\n\n <div class=\"col d-flex justify-content-end\" style=\"font-size: 14px;\">\n <spa-check *ngIf=\"config.searchConfig\" [(value)]=\"searchMode\" display=\"Search Mode\" (valueChange)=\"toggleSearch()\" style=\"margin-right: 10px;\"></spa-check>\n </div>\n\n</div>\n\n<hr style=\"margin-top: 0px;\" />\n\n<!-- Normal -->\n<div *ngIf=\"!searchMode\" style=\" font-size: 14px;\">\n <spa-table [config]=\"getNormalTableConfig()\" [reload]=\"tableReload\"></spa-table>\n</div>\n\n<!-- Search -->\n<div *ngIf=\"searchMode\" style=\" font-size: 14px;\">\n <spa-search [config]=\"config.searchConfig\" (searchClick)=\"searchClicked($event, false)\"></spa-search>\n <spa-table [config]=\"getSearchTableConfig()\" [reload]=\"tableReload\" [data]=\"searchTableData\" [tileData]=\"searchTileData\" (refreshClick)=\"searchClicked(lastSearch, false)\"></spa-table>\n</div>\n", styles: [".mat-mini-fab{width:32px;height:32px}.mat-mini-fab mat-icon{font-size:16px;margin-top:-3px}\n"] }]
|
|
6698
|
-
}], ctorParameters: function () { return [{ type:
|
|
6723
|
+
args: [{ selector: 'spa-page', template: "<div class=\"row\">\r\n\r\n <div class=\"col\">\r\n <h4>{{config.title ?? 'Untitled'}} </h4>\r\n </div>\r\n\r\n <div class=\"col d-flex justify-content-end\" style=\"font-size: 14px;\">\r\n <spa-check *ngIf=\"config.searchConfig\" [(value)]=\"searchMode\" display=\"Search Mode\" (valueChange)=\"toggleSearch()\" style=\"margin-right: 10px;\"></spa-check>\r\n </div>\r\n\r\n</div>\r\n\r\n<hr style=\"margin-top: 0px;\" />\r\n\r\n<!-- Normal -->\r\n<div *ngIf=\"!searchMode\" style=\" font-size: 14px;\">\r\n <spa-table [config]=\"getNormalTableConfig()\" [reload]=\"tableReload\" (refreshClick)=\"refreshClicked()\"></spa-table>\r\n</div>\r\n\r\n<!-- Search -->\r\n<div *ngIf=\"searchMode\" style=\" font-size: 14px;\">\r\n <spa-search [config]=\"config.searchConfig\" (searchClick)=\"searchClicked($event, false)\"></spa-search>\r\n <spa-table [config]=\"getSearchTableConfig()\" [reload]=\"tableReload\" [data]=\"searchTableData\" [tileData]=\"searchTileData\" (refreshClick)=\"searchClicked(lastSearch, false)\" (refreshClick)=\"refreshClicked()\"></spa-table>\r\n</div>\r\n", styles: [".mat-mini-fab{width:32px;height:32px}.mat-mini-fab mat-icon{font-size:16px;margin-top:-3px}\n"] }]
|
|
6724
|
+
}], ctorParameters: function () { return [{ type: DataServiceLib }, { type: MessageService }]; }, propDecorators: { config: [{
|
|
6699
6725
|
type: Input
|
|
6700
6726
|
}], searchModeActivated: [{
|
|
6701
6727
|
type: Output
|
|
6728
|
+
}], searchModeDeactivated: [{
|
|
6729
|
+
type: Output
|
|
6730
|
+
}], refreshClick: [{
|
|
6731
|
+
type: Output
|
|
6702
6732
|
}] } });
|
|
6703
6733
|
|
|
6704
6734
|
class TinSpaModule {
|