tin-spa 2.3.6 → 2.3.7
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/TinCore.mjs +3 -3
- package/esm2020/lib/components/create-account/create-account.component.mjs +1 -3
- package/esm2020/lib/components/filter/filter.component.mjs +1 -2
- package/esm2020/lib/components/form/form.component.mjs +1 -13
- package/esm2020/lib/components/inventory/inventory.component.mjs +1 -2
- package/esm2020/lib/components/profile/profile.component.mjs +1 -3
- package/esm2020/lib/components/table/detailsDialog.component.mjs +1 -4
- package/esm2020/lib/components/table/table.component.mjs +1 -8
- package/esm2020/lib/components/table-internal/detailsDialog-internal.component.mjs +1 -4
- package/esm2020/lib/components/table-internal/table-internal.component.mjs +1 -8
- package/esm2020/lib/components/tenant-settings/tenant-settings.component.mjs +1 -2
- package/esm2020/lib/components/tiles/tiles.component.mjs +1 -2
- package/esm2020/lib/components/users/users.component.mjs +1 -2
- package/esm2020/lib/components/viewer/viewer.component.mjs +1 -3
- package/fesm2015/tin-spa.mjs +2 -45
- package/fesm2015/tin-spa.mjs.map +1 -1
- package/fesm2020/tin-spa.mjs +2 -45
- package/fesm2020/tin-spa.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -93,7 +93,6 @@ export class TableInternalComponent {
|
|
|
93
93
|
}
|
|
94
94
|
}
|
|
95
95
|
loadData(action, data) {
|
|
96
|
-
console.log("loading");
|
|
97
96
|
if (action) {
|
|
98
97
|
this.dataService.CallApi(action, data).subscribe((apiResponse) => {
|
|
99
98
|
if (this.config.logResponse) {
|
|
@@ -183,7 +182,6 @@ export class TableInternalComponent {
|
|
|
183
182
|
}
|
|
184
183
|
//Events
|
|
185
184
|
searchClicked(x) {
|
|
186
|
-
console.log("Search");
|
|
187
185
|
this.searchClick.emit(x);
|
|
188
186
|
if (this.config.searchConfig.searchAction) {
|
|
189
187
|
this.config.searchConfig.searchAction.method == 'post';
|
|
@@ -191,7 +189,6 @@ export class TableInternalComponent {
|
|
|
191
189
|
}
|
|
192
190
|
}
|
|
193
191
|
refreshClicked() {
|
|
194
|
-
console.log("Refresh");
|
|
195
192
|
this.refreshClick.emit();
|
|
196
193
|
if (this.config.loadAction) {
|
|
197
194
|
this.loadData(this.config.loadAction, "");
|
|
@@ -201,7 +198,6 @@ export class TableInternalComponent {
|
|
|
201
198
|
}
|
|
202
199
|
}
|
|
203
200
|
dataLoaded(x) {
|
|
204
|
-
console.log("dataloaded");
|
|
205
201
|
this.dataLoad.emit(x);
|
|
206
202
|
if (this.config.tileConfig?.loadAction) {
|
|
207
203
|
this.tileReload.next(true);
|
|
@@ -234,11 +230,9 @@ export class TableInternalComponent {
|
|
|
234
230
|
this.open(name, row);
|
|
235
231
|
}
|
|
236
232
|
actionClickedEmit(name, row) {
|
|
237
|
-
console.log("Action clicked");
|
|
238
233
|
this.actionClick.emit({ name: name, data: row });
|
|
239
234
|
}
|
|
240
235
|
viewModel(row) {
|
|
241
|
-
console.log("view Clicked");
|
|
242
236
|
this.open('view', row);
|
|
243
237
|
}
|
|
244
238
|
newModel() {
|
|
@@ -366,7 +360,6 @@ export class TableInternalComponent {
|
|
|
366
360
|
}
|
|
367
361
|
//Misc
|
|
368
362
|
getElevationClass(elevation) {
|
|
369
|
-
console.log(elevation);
|
|
370
363
|
if (elevation == "none") {
|
|
371
364
|
return "";
|
|
372
365
|
}
|
|
@@ -413,4 +406,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
413
406
|
}], inputChange: [{
|
|
414
407
|
type: Output
|
|
415
408
|
}] } });
|
|
416
|
-
//# 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\r\n  @ViewChild('tablePaginator') tablePaginator: MatPaginator;\r\n\r\n  @Input() hideTitle = false;\r\n  @Input() data: 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  }\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.createButton = this.buttonService.getCreateButton(this.config?.buttons);\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    console.log(\"loading\")\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    console.log(\"Search\")\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  refreshClicked() {\r\n    console.log(\"Refresh\")\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    console.log(\"dataloaded\")\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    console.log(\"Action clicked\")\r\n    this.actionClick.emit({ name: name, data: row });\r\n  }\r\n\r\n  viewModel(row) {\r\n    console.log(\"view Clicked\");\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    console.log(elevation)\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 *ngIf=\"config.searchConfig\" [config]=\"config.searchConfig\" style=\"margin-bottom: 20px;\" (searchClick)=\"searchClicked($event)\"></spa-search>\r\n\r\n\r\n<!-- Header -->\r\n<div class=\"top\">\r\n\r\n  <!-- Unique to internal -->\r\n  <div class=\"tin-row\">\r\n    <button *ngIf=\"createButton && !config.flatButtons && testVisible(config.parentData,createButton.name)\"\r\n      [disabled]=\"testDisabled(config.parentData,createButton.name)\" id=\"btnNew\" mat-raised-button color=\"primary\" style=\"margin-right: 10px;\" (click)=\"newModel()\">{{createButton.display}}\r\n    </button>\r\n    <button *ngIf=\"createButton && config.flatButtons && testVisible(config.parentData,createButton.name)\"\r\n      [ngStyle]=\"{'color': getButtonColor(createButton, config.parentData)}\"\r\n      [disabled]=\"testDisabled(config.parentData,createButton.name)\" id=\"btnNew\" mat-stroked-button  style=\"margin-right: 10px; color: green;\" (click)=\"newModel()\">{{createButton.display}}\r\n    </button>\r\n  </div>\r\n\r\n  <div *ngIf=\"config.tileConfig && !smallScreen\" style=\"min-width: 75%;\">\r\n    <spa-tiles [reload]=\"tileReload\" [config]=\"config.tileConfig\"></spa-tiles>\r\n  </div>\r\n\r\n  <div *ngIf=\"config.showFilter\" class=\"d-flex justify-content-end\">\r\n    <spa-filter [showText]=\"!smallScreen || (smallScreen && dataSource?.length > 10)\" [showButton]=\"showFilterButton\" [data]=\"tableDataSource\" [flatButtons]=\"config.flatButtons\" (refreshClick)=\"refreshClicked()\"></spa-filter>\r\n  </div>\r\n\r\n</div>\r\n\r\n<div *ngIf=\"config.tileConfig && smallScreen\" style=\"width: 100%;\">\r\n  <spa-tiles [reload]=\"tileReload\" [config]=\"config.tileConfig\"></spa-tiles>\r\n</div>\r\n\r\n<div *ngIf=\"config.title && !hideTitle\" class=\"title\">\r\n  <label style=\"font-size: larger;\">{{config.title | camelToWords}}</label>\r\n</div>\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]=\"[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>No Data</em></p>\r\n</div>\r\n\r\n\r\n"]}
|
|
409
|
+
//# 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,EAAS,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;QAIZ,cAAS,GAAG,KAAK,CAAC;QAClB,SAAI,GAAQ,EAAE,CAAC;QAGd,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;QA/CzC,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;IA8BO,mBAAmB;QACzB,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAChC,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACxB,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,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;QACnF,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QAC7E,IAAI,CAAC,gBAAgB,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,YAAY,CAAC;QAEnD,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,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;;mHA9aU,sBAAsB;uGAAtB,sBAAsB,wcCtBnC,+5HAuFA;2FDjEa,sBAAsB;kBALlC,SAAS;+BACE,oBAAoB;mTA4CD,cAAc;sBAA1C,SAAS;uBAAC,gBAAgB;gBAElB,SAAS;sBAAjB,KAAK;gBACG,IAAI;sBAAZ,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\r\n  @ViewChild('tablePaginator') tablePaginator: MatPaginator;\r\n\r\n  @Input() hideTitle = false;\r\n  @Input() data: 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  }\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.createButton = this.buttonService.getCreateButton(this.config?.buttons);\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  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 *ngIf=\"config.searchConfig\" [config]=\"config.searchConfig\" style=\"margin-bottom: 20px;\" (searchClick)=\"searchClicked($event)\"></spa-search>\r\n\r\n\r\n<!-- Header -->\r\n<div class=\"top\">\r\n\r\n  <!-- Unique to internal -->\r\n  <div class=\"tin-row\">\r\n    <button *ngIf=\"createButton && !config.flatButtons && testVisible(config.parentData,createButton.name)\"\r\n      [disabled]=\"testDisabled(config.parentData,createButton.name)\" id=\"btnNew\" mat-raised-button color=\"primary\" style=\"margin-right: 10px;\" (click)=\"newModel()\">{{createButton.display}}\r\n    </button>\r\n    <button *ngIf=\"createButton && config.flatButtons && testVisible(config.parentData,createButton.name)\"\r\n      [ngStyle]=\"{'color': getButtonColor(createButton, config.parentData)}\"\r\n      [disabled]=\"testDisabled(config.parentData,createButton.name)\" id=\"btnNew\" mat-stroked-button  style=\"margin-right: 10px; color: green;\" (click)=\"newModel()\">{{createButton.display}}\r\n    </button>\r\n  </div>\r\n\r\n  <div *ngIf=\"config.tileConfig && !smallScreen\" style=\"min-width: 75%;\">\r\n    <spa-tiles [reload]=\"tileReload\" [config]=\"config.tileConfig\"></spa-tiles>\r\n  </div>\r\n\r\n  <div *ngIf=\"config.showFilter\" class=\"d-flex justify-content-end\">\r\n    <spa-filter [showText]=\"!smallScreen || (smallScreen && dataSource?.length > 10)\" [showButton]=\"showFilterButton\" [data]=\"tableDataSource\" [flatButtons]=\"config.flatButtons\" (refreshClick)=\"refreshClicked()\"></spa-filter>\r\n  </div>\r\n\r\n</div>\r\n\r\n<div *ngIf=\"config.tileConfig && smallScreen\" style=\"width: 100%;\">\r\n  <spa-tiles [reload]=\"tileReload\" [config]=\"config.tileConfig\"></spa-tiles>\r\n</div>\r\n\r\n<div *ngIf=\"config.title && !hideTitle\" class=\"title\">\r\n  <label style=\"font-size: larger;\">{{config.title | camelToWords}}</label>\r\n</div>\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]=\"[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>No Data</em></p>\r\n</div>\r\n\r\n\r\n"]}
|
|
@@ -90,7 +90,6 @@ export class TenantSettingsComponent {
|
|
|
90
90
|
this.messageService.confirm(`Rename ?`).subscribe((result) => {
|
|
91
91
|
if (result == "yes") {
|
|
92
92
|
this.dataService.CallApi({ url: 'tenant/tenants?action=rename', method: 'post' }, this.currTenant).subscribe((apiResponse) => {
|
|
93
|
-
console.log(apiResponse);
|
|
94
93
|
if (apiResponse.success) {
|
|
95
94
|
this.authService.updateTenantName(this.currTenant.name);
|
|
96
95
|
this.messageService.toast("Renamed Successfully");
|
|
@@ -153,4 +152,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
153
152
|
type: Component,
|
|
154
153
|
args: [{ selector: 'spa-tenant-settings', template: "<div class=\"container\">\r\n\r\n <div>\r\n\r\n <label class=\"title\" >Organisation Details</label>\r\n <hr style=\"margin-top: 0px; margin-bottom: 0px;\">\r\n\r\n <div *ngIf=\"currTenant && plan\" class=\"mb-2 mt-3 tin-grid\" style=\" font-size: 14px;\">\r\n\r\n <div class=\"tin-col mb-3\" *ngIf=\"ownTenant\" style=\"max-width: 500px;\">\r\n <spa-text display=\"Name\" [(value)]=\"currTenant.name\" hint=\"This name will be displayed to all members of your organisation.\" style=\"min-width: 300px;\"> </spa-text>\r\n <button mat-stroked-button color=\"primary\" (click)=\"renameTenant()\">Save</button>\r\n </div>\r\n\r\n <div class=\"tin-col mb-3\" style=\"max-width: 500px;\">\r\n <spa-select display=\"Current Organisation\" [options]=\"tenants\" optionDisplay=\"name\" optionValue=\"tenantID\" [(value)]=\"currentTenantID\"\r\n hint=\"You are required to login again after switching organisations.\" style=\"min-width: 300px;\"></spa-select>\r\n <button mat-stroked-button color=\"primary\" (click)=\"switchTenant()\">Switch</button>\r\n </div>\r\n\r\n <div *ngIf=\"ownTenant\">\r\n <spa-label display=\"Plan\" [value]=\"plan.name\"></spa-label>\r\n </div>\r\n\r\n </div>\r\n\r\n </div>\r\n\r\n\r\n\r\n <!-- Members -->\r\n <div class=\"mt-3\" *ngIf=\"ownTenant\">\r\n\r\n <label class=\"title\" >Members</label>\r\n <hr style=\"margin-top: 0px; margin-bottom: 0px;\">\r\n <label class=\"subtitle text-muted\">Invite other users to join your organisation as partners or employees to form a partnership or company.</label>\r\n\r\n <spa-table [config]=\"membersTableConfig\" [reload]=\"tableReload\" (actionClick)=\"inviteActionClicked($event)\"></spa-table>\r\n\r\n </div>\r\n\r\n\r\n <!-- Invitations -->\r\n <div class=\"mt-3\" *ngIf=\"ownTenant\">\r\n\r\n <label class=\"title\" >Invitations</label>\r\n <hr style=\"margin-top: 0px; margin-bottom: 0px;\">\r\n <label class=\"subtitle text-muted\">Requests for you to join other organisations.</label>\r\n\r\n\r\n <spa-invitations-table></spa-invitations-table>\r\n\r\n </div>\r\n\r\n\r\n<!-- Member Organisations -->\r\n <div class=\"mt-3\" *ngIf=\"ownTenant\">\r\n\r\n <label class=\"title\" >Member Organisations</label>\r\n <hr style=\"margin-top: 0px; margin-bottom: 0px;\">\r\n <label class=\"subtitle text-muted\">Organisations that you are a member of.</label>\r\n\r\n <spa-table [config]=\"orgsTableConfig\" [reload]=\"orgsReload\"></spa-table>\r\n\r\n </div>\r\n\r\n\r\n <!-- New Organisation -->\r\n <div class=\"mt-3\" *ngIf=\"ownTenant\">\r\n\r\n <label class=\"title\">New Organisation</label>\r\n <hr style=\"margin-top: 0px; margin-bottom: 0px;\">\r\n <label class=\"subtitle text-muted\">Create another organisation</label>\r\n\r\n <div class=\"tin-col mb-3\" *ngIf=\"ownTenant\" style=\"max-width: 500px;\">\r\n <spa-text display=\"Name\" [(value)]=\"newName\" style=\"min-width: 300px;\"> </spa-text>\r\n <button mat-stroked-button color=\"primary\" (click)=\"newTenant()\">Create</button>\r\n </div>\r\n\r\n\r\n </div>\r\n\r\n\r\n <!-- Billing -->\r\n <div class=\"mt-3 mb-5\" *ngIf=\"ownTenant\">\r\n\r\n <label class=\"title\" >Billing and Subscription</label>\r\n <hr style=\"margin-top: 0px; margin-bottom: 0px;\">\r\n\r\n <div *ngIf=\"currTenant && plan\" class=\"mb-1 mt-3\" style=\"max-width: 300px; font-size: 14px;\">\r\n <spa-label display=\"Plan\" [value]=\"plan.name\"></spa-label>\r\n <spa-label display=\"Next Payment\" format=\"money\" [value]=\"plan.price\"></spa-label>\r\n <spa-label display=\"Due Date\" format=\"date\" value=\"2024-01-01\"></spa-label>\r\n </div>\r\n\r\n </div>\r\n\r\n\r\n</div>\r\n\r\n\r\n", styles: [".title{margin-top:1em;font-size:28px;font-weight:300}.subtitle{font-size:smaller}\n"] }]
|
|
155
154
|
}], ctorParameters: function () { return [{ type: i1.DataServiceLib }, { type: i2.MessageService }, { type: i3.AuthService }, { type: i4.MatDialog }]; } });
|
|
156
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tenant-settings.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/tenant-settings/tenant-settings.component.ts","../../../../../../projects/tin-spa/src/lib/components/tenant-settings/tenant-settings.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit } from '@angular/core';\r\nimport { FormConfig, TableConfig, ApiResponse } from '../../classes/Classes';\r\nimport { DataServiceLib } from '../../services/datalib.service';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { AuthService } from '../../services/auth.service';\r\nimport { inviteDialog } from './inviteDialog.component';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { Subject } from 'rxjs';\r\n\r\n@Component({\r\n  selector: 'spa-tenant-settings',\r\n  templateUrl: './tenant-settings.component.html',\r\n  styleUrls: ['./tenant-settings.component.css']\r\n})\r\nexport class TenantSettingsComponent implements OnInit {\r\n\r\n  constructor(public dataService: DataServiceLib, private messageService: MessageService, public authService: AuthService, public dialog: MatDialog ) { }\r\n\r\n  ngOnInit(): void {\r\n    this.authService.myRoleObserv.subscribe(rol => this.myRole = rol);\r\n    this.loadData();\r\n    this.loadTenants()\r\n  }\r\n\r\n  newName;\r\n\r\n  myRole\r\n  tenants;\r\n  currTenant;\r\n  currentTenantID;\r\n  plan;\r\n  ownTenant;\r\n  roles = [\r\n    { name: 'Default', value: 1 },\r\n    // { name: 'Admin', value: 2 },\r\n    // { name: 'Owner', value: 3 },\r\n  ]\r\n\r\n  loadData(){\r\n    this.dataService.CallApi({ url: 'tenant/meta/x' }, \"\").subscribe((apiResponse: ApiResponse) => {\r\n      this.currTenant = apiResponse.data.tenant;\r\n      this.currentTenantID = apiResponse.data.currentTenantID;\r\n      this.plan = apiResponse.data.plan;\r\n      this.ownTenant = apiResponse.data.ownTenant\r\n    });\r\n  }\r\n\r\n  loadTenants() {\r\n    this.dataService.CallApi({ url: 'tenant/meta_tenants/x' }, \"\").subscribe((apiResponse: ApiResponse) => {\r\n      // this.tenant = apiResponse.data.tenant;\r\n      this.tenants = apiResponse.data.tenants;\r\n    });\r\n  }\r\n\r\n  renameTenant() {\r\n\r\n    this.messageService.confirm(`Rename ?`).subscribe((result) => {\r\n      if (result == \"yes\") {\r\n\r\n        this.dataService.CallApi({ url: 'tenant/tenants?action=rename', method: 'post' }, this.currTenant).subscribe((apiResponse: ApiResponse) => {\r\n\r\n          console.log(apiResponse)\r\n          if (apiResponse.success) {\r\n            this.authService.updateTenantName(this.currTenant.name)\r\n            this.messageService.toast(\"Renamed Successfully\");\r\n            this.refreshOrgsLists();\r\n          }\r\n        });\r\n      }\r\n    });\r\n  }\r\n\r\n  refreshOrgsLists(){\r\n    this.loadTenants();\r\n    this.orgsReload.next(true)\r\n  }\r\n\r\n  switchTenant() {\r\n\r\n    this.messageService.confirm(`Switch ?`).subscribe((result) => {\r\n      if (result == \"yes\") {\r\n\r\n        this.currTenant.tenantID = this.currentTenantID;\r\n\r\n        this.dataService.CallApi({ url: 'tenant/tenants?action=switch', method: 'post' }, this.currTenant).subscribe((apiResponse: ApiResponse) => {\r\n\r\n          if (apiResponse.success) {\r\n            this.messageService.toast(\"Switched Successfully, please login again\");\r\n            this.authService.logoff();\r\n          }\r\n        });\r\n      }\r\n    });\r\n  }\r\n\r\n  newTenant() {\r\n\r\n    this.messageService.confirm(`Create ${this.newName} ?`).subscribe((result) => {\r\n      if (result == \"yes\") {\r\n\r\n        let tenant = {tenantID : 0, name : this.newName}\r\n\r\n        this.dataService.CallApi({ url: 'tenant/tenants?action=create', method: 'post' }, tenant).subscribe((apiResponse: ApiResponse) => {\r\n\r\n          if (apiResponse.success) {\r\n            this.messageService.toast(\"Created Successfully\");\r\n            this.refreshOrgsLists();\r\n          }\r\n        });\r\n      }\r\n    });\r\n  }\r\n\r\n\r\n\r\n  membersFormConfig: FormConfig = {\r\n\r\n    fields: [\r\n      { name: 'email', type: 'text',  required: true, min: 2 },\r\n      { name: 'roleID', type: 'select', required: true, options: this.roles, optionDisplay : 'name', optionValue : 'value', defaultValue: 1 },\r\n    ],\r\n\r\n  }\r\n\r\n  inviteActionClicked(x){\r\n\r\n\r\n    if (x.name ==\"create\"){\r\n      this.inviteDiag();\r\n    }\r\n\r\n  }\r\n\r\n\r\n  inviteDiag() {\r\n    const dialogRef = this.dialog.open(inviteDialog, {\r\n      width: \"900px\",\r\n      data: '',\r\n    });\r\n\r\n    dialogRef.afterClosed().subscribe((result) => {\r\n      if (result == \"success\") {\r\n        this.tableReload.next(true);\r\n      }\r\n    });\r\n  }\r\n\r\n  tableReload: Subject<boolean> = new Subject();\r\n  membersTableConfig: TableConfig = {\r\n\r\n    greyOut : (value) => value.accepted == false,\r\n    elevation: 'low',\r\n    logResponse : true,\r\n    minColumns: ['name'],\r\n    minButtons: ['delete'],\r\n    flatButtons: true,\r\n\r\n    columns: [\r\n      { name: 'name', type: 'text' },\r\n      { name: 'email', type: 'text' },\r\n      { name: 'roleName', alias : 'Role', type: 'text'},\r\n    ],\r\n\r\n    buttons: [\r\n      { name: 'create', display: 'Invite', },\r\n      { name: 'edit', dialog : true, action: { url: 'tenant/members?action=role', method: 'post' }, disabled: x => x.roleID != 1 },\r\n      { name: 'delete', confirm: { message: 'Remove Member from this Organisation ?' }, action: { url: 'tenant/members?action=remove', method: 'post' }, disabled : x => x.roleID != 1 },\r\n    ],\r\n\r\n    loadAction: { url: 'tenant/members/x' },\r\n\r\n    formConfig: this.membersFormConfig,\r\n  }\r\n\r\n\r\n\r\n\r\n  orgsReload: Subject<boolean> = new Subject();\r\n  orgsTableConfig: TableConfig = {\r\n    greyOut: (value) => value.accepted == false,\r\n    elevation: 'low',\r\n    minColumns: ['name'],\r\n    flatButtons: true,\r\n\r\n    columns: [\r\n      { name: 'name', type: 'text' },\r\n      { name: 'createdByName', type: 'text', alias: 'Owner' },\r\n    ],\r\n\r\n    buttons: [\r\n      { name: 'delete', confirm: { message: 'Remove Member from this Organisation ?' }, action: { url: 'tenant/members?action=remove', method: 'post' } , disabled : x => x.own}, //action: { url: 'tenant/members?action=delete', method: 'post' }\r\n    ],\r\n\r\n    loadAction: { url: 'tenant/my_tenants/x' },\r\n\r\n  }\r\n}\r\n","<div class=\"container\">\r\n\r\n  <div>\r\n\r\n    <label class=\"title\" >Organisation Details</label>\r\n    <hr style=\"margin-top: 0px; margin-bottom: 0px;\">\r\n\r\n    <div *ngIf=\"currTenant && plan\" class=\"mb-2 mt-3 tin-grid\" style=\" font-size: 14px;\">\r\n\r\n      <div class=\"tin-col mb-3\" *ngIf=\"ownTenant\" style=\"max-width: 500px;\">\r\n        <spa-text display=\"Name\" [(value)]=\"currTenant.name\" hint=\"This name will be displayed to all members of your organisation.\" style=\"min-width: 300px;\"> </spa-text>\r\n        <button mat-stroked-button color=\"primary\" (click)=\"renameTenant()\">Save</button>\r\n      </div>\r\n\r\n      <div class=\"tin-col mb-3\" style=\"max-width: 500px;\">\r\n        <spa-select display=\"Current Organisation\" [options]=\"tenants\" optionDisplay=\"name\" optionValue=\"tenantID\" [(value)]=\"currentTenantID\"\r\n          hint=\"You are required to login again after switching organisations.\" style=\"min-width: 300px;\"></spa-select>\r\n        <button mat-stroked-button color=\"primary\" (click)=\"switchTenant()\">Switch</button>\r\n      </div>\r\n\r\n      <div *ngIf=\"ownTenant\">\r\n        <spa-label display=\"Plan\" [value]=\"plan.name\"></spa-label>\r\n      </div>\r\n\r\n    </div>\r\n\r\n  </div>\r\n\r\n\r\n\r\n  <!-- Members -->\r\n  <div class=\"mt-3\" *ngIf=\"ownTenant\">\r\n\r\n    <label class=\"title\" >Members</label>\r\n    <hr style=\"margin-top: 0px; margin-bottom: 0px;\">\r\n    <label class=\"subtitle text-muted\">Invite other users to join your organisation as partners or employees to form a partnership or company.</label>\r\n\r\n    <spa-table [config]=\"membersTableConfig\" [reload]=\"tableReload\" (actionClick)=\"inviteActionClicked($event)\"></spa-table>\r\n\r\n  </div>\r\n\r\n\r\n  <!-- Invitations -->\r\n  <div class=\"mt-3\" *ngIf=\"ownTenant\">\r\n\r\n    <label class=\"title\" >Invitations</label>\r\n    <hr style=\"margin-top: 0px; margin-bottom: 0px;\">\r\n    <label class=\"subtitle text-muted\">Requests for you to join other organisations.</label>\r\n\r\n\r\n    <spa-invitations-table></spa-invitations-table>\r\n\r\n  </div>\r\n\r\n\r\n<!-- Member Organisations -->\r\n  <div class=\"mt-3\" *ngIf=\"ownTenant\">\r\n\r\n    <label class=\"title\" >Member Organisations</label>\r\n    <hr style=\"margin-top: 0px; margin-bottom: 0px;\">\r\n    <label class=\"subtitle text-muted\">Organisations that you are a member of.</label>\r\n\r\n    <spa-table [config]=\"orgsTableConfig\" [reload]=\"orgsReload\"></spa-table>\r\n\r\n  </div>\r\n\r\n\r\n  <!-- New Organisation -->\r\n  <div class=\"mt-3\" *ngIf=\"ownTenant\">\r\n\r\n    <label class=\"title\">New Organisation</label>\r\n    <hr style=\"margin-top: 0px; margin-bottom: 0px;\">\r\n    <label class=\"subtitle text-muted\">Create another organisation</label>\r\n\r\n    <div class=\"tin-col mb-3\" *ngIf=\"ownTenant\" style=\"max-width: 500px;\">\r\n      <spa-text display=\"Name\" [(value)]=\"newName\" style=\"min-width: 300px;\"> </spa-text>\r\n      <button mat-stroked-button color=\"primary\" (click)=\"newTenant()\">Create</button>\r\n    </div>\r\n\r\n\r\n  </div>\r\n\r\n\r\n  <!-- Billing -->\r\n  <div class=\"mt-3 mb-5\" *ngIf=\"ownTenant\">\r\n\r\n    <label class=\"title\" >Billing and Subscription</label>\r\n    <hr style=\"margin-top: 0px; margin-bottom: 0px;\">\r\n\r\n      <div *ngIf=\"currTenant && plan\" class=\"mb-1 mt-3\" style=\"max-width: 300px; font-size: 14px;\">\r\n        <spa-label display=\"Plan\" [value]=\"plan.name\"></spa-label>\r\n        <spa-label display=\"Next Payment\" format=\"money\" [value]=\"plan.price\"></spa-label>\r\n        <spa-label display=\"Due Date\" format=\"date\" value=\"2024-01-01\"></spa-label>\r\n      </div>\r\n\r\n  </div>\r\n\r\n\r\n</div>\r\n\r\n\r\n"]}
|
|
155
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tenant-settings.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/tenant-settings/tenant-settings.component.ts","../../../../../../projects/tin-spa/src/lib/components/tenant-settings/tenant-settings.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit } from '@angular/core';\r\nimport { FormConfig, TableConfig, ApiResponse } from '../../classes/Classes';\r\nimport { DataServiceLib } from '../../services/datalib.service';\r\nimport { MessageService } from '../../services/message.service';\r\nimport { AuthService } from '../../services/auth.service';\r\nimport { inviteDialog } from './inviteDialog.component';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { Subject } from 'rxjs';\r\n\r\n@Component({\r\n  selector: 'spa-tenant-settings',\r\n  templateUrl: './tenant-settings.component.html',\r\n  styleUrls: ['./tenant-settings.component.css']\r\n})\r\nexport class TenantSettingsComponent implements OnInit {\r\n\r\n  constructor(public dataService: DataServiceLib, private messageService: MessageService, public authService: AuthService, public dialog: MatDialog ) { }\r\n\r\n  ngOnInit(): void {\r\n    this.authService.myRoleObserv.subscribe(rol => this.myRole = rol);\r\n    this.loadData();\r\n    this.loadTenants()\r\n  }\r\n\r\n  newName;\r\n\r\n  myRole\r\n  tenants;\r\n  currTenant;\r\n  currentTenantID;\r\n  plan;\r\n  ownTenant;\r\n  roles = [\r\n    { name: 'Default', value: 1 },\r\n    // { name: 'Admin', value: 2 },\r\n    // { name: 'Owner', value: 3 },\r\n  ]\r\n\r\n  loadData(){\r\n    this.dataService.CallApi({ url: 'tenant/meta/x' }, \"\").subscribe((apiResponse: ApiResponse) => {\r\n      this.currTenant = apiResponse.data.tenant;\r\n      this.currentTenantID = apiResponse.data.currentTenantID;\r\n      this.plan = apiResponse.data.plan;\r\n      this.ownTenant = apiResponse.data.ownTenant\r\n    });\r\n  }\r\n\r\n  loadTenants() {\r\n    this.dataService.CallApi({ url: 'tenant/meta_tenants/x' }, \"\").subscribe((apiResponse: ApiResponse) => {\r\n      // this.tenant = apiResponse.data.tenant;\r\n      this.tenants = apiResponse.data.tenants;\r\n    });\r\n  }\r\n\r\n  renameTenant() {\r\n\r\n    this.messageService.confirm(`Rename ?`).subscribe((result) => {\r\n      if (result == \"yes\") {\r\n\r\n        this.dataService.CallApi({ url: 'tenant/tenants?action=rename', method: 'post' }, this.currTenant).subscribe((apiResponse: ApiResponse) => {\r\n\r\n          if (apiResponse.success) {\r\n            this.authService.updateTenantName(this.currTenant.name)\r\n            this.messageService.toast(\"Renamed Successfully\");\r\n            this.refreshOrgsLists();\r\n          }\r\n        });\r\n      }\r\n    });\r\n  }\r\n\r\n  refreshOrgsLists(){\r\n    this.loadTenants();\r\n    this.orgsReload.next(true)\r\n  }\r\n\r\n  switchTenant() {\r\n\r\n    this.messageService.confirm(`Switch ?`).subscribe((result) => {\r\n      if (result == \"yes\") {\r\n\r\n        this.currTenant.tenantID = this.currentTenantID;\r\n\r\n        this.dataService.CallApi({ url: 'tenant/tenants?action=switch', method: 'post' }, this.currTenant).subscribe((apiResponse: ApiResponse) => {\r\n\r\n          if (apiResponse.success) {\r\n            this.messageService.toast(\"Switched Successfully, please login again\");\r\n            this.authService.logoff();\r\n          }\r\n        });\r\n      }\r\n    });\r\n  }\r\n\r\n  newTenant() {\r\n\r\n    this.messageService.confirm(`Create ${this.newName} ?`).subscribe((result) => {\r\n      if (result == \"yes\") {\r\n\r\n        let tenant = {tenantID : 0, name : this.newName}\r\n\r\n        this.dataService.CallApi({ url: 'tenant/tenants?action=create', method: 'post' }, tenant).subscribe((apiResponse: ApiResponse) => {\r\n\r\n          if (apiResponse.success) {\r\n            this.messageService.toast(\"Created Successfully\");\r\n            this.refreshOrgsLists();\r\n          }\r\n        });\r\n      }\r\n    });\r\n  }\r\n\r\n\r\n\r\n  membersFormConfig: FormConfig = {\r\n\r\n    fields: [\r\n      { name: 'email', type: 'text',  required: true, min: 2 },\r\n      { name: 'roleID', type: 'select', required: true, options: this.roles, optionDisplay : 'name', optionValue : 'value', defaultValue: 1 },\r\n    ],\r\n\r\n  }\r\n\r\n  inviteActionClicked(x){\r\n\r\n\r\n    if (x.name ==\"create\"){\r\n      this.inviteDiag();\r\n    }\r\n\r\n  }\r\n\r\n\r\n  inviteDiag() {\r\n    const dialogRef = this.dialog.open(inviteDialog, {\r\n      width: \"900px\",\r\n      data: '',\r\n    });\r\n\r\n    dialogRef.afterClosed().subscribe((result) => {\r\n      if (result == \"success\") {\r\n        this.tableReload.next(true);\r\n      }\r\n    });\r\n  }\r\n\r\n  tableReload: Subject<boolean> = new Subject();\r\n  membersTableConfig: TableConfig = {\r\n\r\n    greyOut : (value) => value.accepted == false,\r\n    elevation: 'low',\r\n    logResponse : true,\r\n    minColumns: ['name'],\r\n    minButtons: ['delete'],\r\n    flatButtons: true,\r\n\r\n    columns: [\r\n      { name: 'name', type: 'text' },\r\n      { name: 'email', type: 'text' },\r\n      { name: 'roleName', alias : 'Role', type: 'text'},\r\n    ],\r\n\r\n    buttons: [\r\n      { name: 'create', display: 'Invite', },\r\n      { name: 'edit', dialog : true, action: { url: 'tenant/members?action=role', method: 'post' }, disabled: x => x.roleID != 1 },\r\n      { name: 'delete', confirm: { message: 'Remove Member from this Organisation ?' }, action: { url: 'tenant/members?action=remove', method: 'post' }, disabled : x => x.roleID != 1 },\r\n    ],\r\n\r\n    loadAction: { url: 'tenant/members/x' },\r\n\r\n    formConfig: this.membersFormConfig,\r\n  }\r\n\r\n\r\n\r\n\r\n  orgsReload: Subject<boolean> = new Subject();\r\n  orgsTableConfig: TableConfig = {\r\n    greyOut: (value) => value.accepted == false,\r\n    elevation: 'low',\r\n    minColumns: ['name'],\r\n    flatButtons: true,\r\n\r\n    columns: [\r\n      { name: 'name', type: 'text' },\r\n      { name: 'createdByName', type: 'text', alias: 'Owner' },\r\n    ],\r\n\r\n    buttons: [\r\n      { name: 'delete', confirm: { message: 'Remove Member from this Organisation ?' }, action: { url: 'tenant/members?action=remove', method: 'post' } , disabled : x => x.own}, //action: { url: 'tenant/members?action=delete', method: 'post' }\r\n    ],\r\n\r\n    loadAction: { url: 'tenant/my_tenants/x' },\r\n\r\n  }\r\n}\r\n","<div class=\"container\">\r\n\r\n  <div>\r\n\r\n    <label class=\"title\" >Organisation Details</label>\r\n    <hr style=\"margin-top: 0px; margin-bottom: 0px;\">\r\n\r\n    <div *ngIf=\"currTenant && plan\" class=\"mb-2 mt-3 tin-grid\" style=\" font-size: 14px;\">\r\n\r\n      <div class=\"tin-col mb-3\" *ngIf=\"ownTenant\" style=\"max-width: 500px;\">\r\n        <spa-text display=\"Name\" [(value)]=\"currTenant.name\" hint=\"This name will be displayed to all members of your organisation.\" style=\"min-width: 300px;\"> </spa-text>\r\n        <button mat-stroked-button color=\"primary\" (click)=\"renameTenant()\">Save</button>\r\n      </div>\r\n\r\n      <div class=\"tin-col mb-3\" style=\"max-width: 500px;\">\r\n        <spa-select display=\"Current Organisation\" [options]=\"tenants\" optionDisplay=\"name\" optionValue=\"tenantID\" [(value)]=\"currentTenantID\"\r\n          hint=\"You are required to login again after switching organisations.\" style=\"min-width: 300px;\"></spa-select>\r\n        <button mat-stroked-button color=\"primary\" (click)=\"switchTenant()\">Switch</button>\r\n      </div>\r\n\r\n      <div *ngIf=\"ownTenant\">\r\n        <spa-label display=\"Plan\" [value]=\"plan.name\"></spa-label>\r\n      </div>\r\n\r\n    </div>\r\n\r\n  </div>\r\n\r\n\r\n\r\n  <!-- Members -->\r\n  <div class=\"mt-3\" *ngIf=\"ownTenant\">\r\n\r\n    <label class=\"title\" >Members</label>\r\n    <hr style=\"margin-top: 0px; margin-bottom: 0px;\">\r\n    <label class=\"subtitle text-muted\">Invite other users to join your organisation as partners or employees to form a partnership or company.</label>\r\n\r\n    <spa-table [config]=\"membersTableConfig\" [reload]=\"tableReload\" (actionClick)=\"inviteActionClicked($event)\"></spa-table>\r\n\r\n  </div>\r\n\r\n\r\n  <!-- Invitations -->\r\n  <div class=\"mt-3\" *ngIf=\"ownTenant\">\r\n\r\n    <label class=\"title\" >Invitations</label>\r\n    <hr style=\"margin-top: 0px; margin-bottom: 0px;\">\r\n    <label class=\"subtitle text-muted\">Requests for you to join other organisations.</label>\r\n\r\n\r\n    <spa-invitations-table></spa-invitations-table>\r\n\r\n  </div>\r\n\r\n\r\n<!-- Member Organisations -->\r\n  <div class=\"mt-3\" *ngIf=\"ownTenant\">\r\n\r\n    <label class=\"title\" >Member Organisations</label>\r\n    <hr style=\"margin-top: 0px; margin-bottom: 0px;\">\r\n    <label class=\"subtitle text-muted\">Organisations that you are a member of.</label>\r\n\r\n    <spa-table [config]=\"orgsTableConfig\" [reload]=\"orgsReload\"></spa-table>\r\n\r\n  </div>\r\n\r\n\r\n  <!-- New Organisation -->\r\n  <div class=\"mt-3\" *ngIf=\"ownTenant\">\r\n\r\n    <label class=\"title\">New Organisation</label>\r\n    <hr style=\"margin-top: 0px; margin-bottom: 0px;\">\r\n    <label class=\"subtitle text-muted\">Create another organisation</label>\r\n\r\n    <div class=\"tin-col mb-3\" *ngIf=\"ownTenant\" style=\"max-width: 500px;\">\r\n      <spa-text display=\"Name\" [(value)]=\"newName\" style=\"min-width: 300px;\"> </spa-text>\r\n      <button mat-stroked-button color=\"primary\" (click)=\"newTenant()\">Create</button>\r\n    </div>\r\n\r\n\r\n  </div>\r\n\r\n\r\n  <!-- Billing -->\r\n  <div class=\"mt-3 mb-5\" *ngIf=\"ownTenant\">\r\n\r\n    <label class=\"title\" >Billing and Subscription</label>\r\n    <hr style=\"margin-top: 0px; margin-bottom: 0px;\">\r\n\r\n      <div *ngIf=\"currTenant && plan\" class=\"mb-1 mt-3\" style=\"max-width: 300px; font-size: 14px;\">\r\n        <spa-label display=\"Plan\" [value]=\"plan.name\"></spa-label>\r\n        <spa-label display=\"Next Payment\" format=\"money\" [value]=\"plan.price\"></spa-label>\r\n        <spa-label display=\"Due Date\" format=\"date\" value=\"2024-01-01\"></spa-label>\r\n      </div>\r\n\r\n  </div>\r\n\r\n\r\n</div>\r\n\r\n\r\n"]}
|
|
@@ -52,7 +52,6 @@ export class TilesComponent {
|
|
|
52
52
|
}
|
|
53
53
|
}
|
|
54
54
|
loadData(action, data) {
|
|
55
|
-
console.log("loading");
|
|
56
55
|
if (action) {
|
|
57
56
|
this.dataService.CallApi(action, data).subscribe((apiResponse) => {
|
|
58
57
|
if (apiResponse.success) {
|
|
@@ -79,4 +78,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
79
78
|
}], tileClick: [{
|
|
80
79
|
type: Output
|
|
81
80
|
}] } });
|
|
82
|
-
//# 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;QAoC7E,cAAS,GAAG,IAAI,YAAY,EAAE,CAAC;QAEzC,iBAAY,GAAW,EAAE,CAAC;QAE1B,QAAG,GAAG,IAAI,CAAA;IAxCkF,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;IAgBD,OAAO,CAAC,CAAO;QAIb,IAAG,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS;YAAE,OAAO;QAGlC,IAAG,IAAI,CAAC,YAAY,IAAI,CAAC,CAAC,IAAI,EAAC;YAC7B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YACxB,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;SACxB;aAAI;YACH,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;YAC5B,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC,IAAI,CAAC;SAC5B;IAGH,CAAC;IAED,GAAG,CAAC,CAAC;QAEH,IAAI,CAAC,EAAC;YACJ,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;SAC7B;IAEH,CAAC;IAGD,QAAQ,CAAC,MAAc,EAAE,IAAS;QAChC,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,CAAA;QAEtB,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;;2GAxFU,cAAc;+FAAd,cAAc,yKCZ3B,u2HAkEA;2FDtDa,cAAc;kBAL1B,SAAS;+BACE,WAAW;kIAmCZ,MAAM;sBAAd,KAAK;gBAGG,IAAI;sBAAZ,KAAK;gBAEG,MAAM;sBAAd,KAAK;gBAEI,SAAS;sBAAlB,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\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\r\n  selectedTile: string = \"\";\r\n\r\n  new = true\r\n\r\n  clicked(v: Tile){\r\n\r\n\r\n\r\n    if(!this.config.clickable) return;\r\n\r\n\r\n    if(this.selectedTile == v.name){\r\n      this.tileClick.emit(\"\");\r\n      this.selectedTile = \"\";\r\n    }else{\r\n      this.tileClick.emit(v.name);\r\n      this.selectedTile = v.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  loadData(action: Action, data: any) {\r\n    console.log(\"loading\")\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}\r\n","      <div class=\"tin-row align-items-center tiles\" *ngIf=\"!new\">\r\n\r\n        <ng-container *ngFor=\"let tile of tiles\">\r\n\r\n          <mat-card class=\"card tin-col\" *ngIf=\"!tile.hidden\" (click)=\"clicked(tile)\">\r\n\r\n            <mat-label style=\"font-weight:bold; text-align: center; padding: 0px; margin: 0px;\" [ngStyle]=\"{'color':tile.color,'font-size':tile.name == selectedTile ? '45px' : '35px' }\">{{data ? data[tile.name] : 0}}</mat-label>\r\n\r\n            <div class=\"d-flex justify-content-center align-items-center\">\r\n\r\n              <!-- <button mat-icon-button (click)=\"pop(tile.info)\">\r\n                <mat-label [ngStyle]=\"{'font-size':tile.name == selectedTile ? '14px' : '14px' }\" style=\"padding-left:5px;padding-right:5px; margin-right: 10px;\">{{tile.alias ?? tile.name | camelToWords}}</mat-label>\r\n                <mat-icon [matTooltip]=\"tile.info\" matTooltipPosition=\"above\" [ngStyle]=\"{'font-size':tile.name == selectedTile ? '24x' : '24px' }\" style=\" color:steelblue;\">info</mat-icon>\r\n              </button> -->\r\n\r\n              <button mat-icon-button (click)=\"pop(tile.info)\" style=\"margin: 0px; padding: 0px;\">\r\n                <mat-label [ngStyle]=\"{'font-size':tile.name == selectedTile ? '14px' : '14px' }\" style=\"padding-left:5px;padding-right:5px; margin-right: 10px;\">{{tile.alias ?? tile.name | camelToWords}}</mat-label>\r\n                <mat-icon [matTooltip]=\"tile.info\" matTooltipPosition=\"above\" [ngStyle]=\"{'font-size':tile.name == selectedTile ? '24x' : '18px' }\" style=\" color:steelblue;\">info</mat-icon>\r\n              </button>\r\n\r\n              <!-- <div class=\"row d-flex justify-content-center row align-items-center\">\r\n                <mat-label [ngStyle]=\"{'font-size':tile.name == selectedTile ? '18px' : '12px' }\" style=\"padding-left:5px;padding-right:5px\">{{tile.name}}</mat-label>\r\n                <mat-icon [matTooltip]=\"tile.info\" matTooltipPosition=\"above\" [ngStyle]=\"{'font-size':tile.name == selectedTile ? '20px' : '17px' }\" style=\" color:steelblue;\">info</mat-icon>\r\n              </div> -->\r\n\r\n            </div>\r\n\r\n          </mat-card>\r\n\r\n        </ng-container>\r\n\r\n      </div>\r\n\r\n\r\n      <div class=\"d-flex row align-items-center justify-content-between\" *ngIf=\"new\">\r\n\r\n        <ng-container *ngFor=\"let tile of tiles\">\r\n\r\n          <mat-card class=\"col\" style=\"margin-left: 5px;margin-right: 5px; padding: 10px 16px ; min-width: 150px; margin-top: 5px;\" (click)=\"clicked(tile)\">\r\n\r\n            <div class=\"row d-flex justify-content-center align-items-center\">\r\n\r\n              <div style=\"text-align: center;\">\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,'font-size':tile.name == selectedTile ? '35px' : '30px' }\">{{data ? 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\r\n\r\n            </div>\r\n\r\n            <div class=\"row d-flex justify-content-center align-items-center\">\r\n\r\n              <div class=\"d-flex justify-content-center align-items-center\" style=\"text-align: center;\">\r\n                <mat-label [ngStyle]=\"{'font-size':tile.name == selectedTile ? '18px' : '14px' }\" style=\"padding-left:5px;padding-right:5px; text-align: center;\">{{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\r\n            </div>\r\n\r\n          </mat-card>\r\n\r\n\r\n        </ng-container>\r\n\r\n      </div>\r\n"]}
|
|
81
|
+
//# 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;QAoC7E,cAAS,GAAG,IAAI,YAAY,EAAE,CAAC;QAEzC,iBAAY,GAAW,EAAE,CAAC;QAE1B,QAAG,GAAG,IAAI,CAAA;IAxCkF,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;IAgBD,OAAO,CAAC,CAAO;QAIb,IAAG,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS;YAAE,OAAO;QAGlC,IAAG,IAAI,CAAC,YAAY,IAAI,CAAC,CAAC,IAAI,EAAC;YAC7B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YACxB,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;SACxB;aAAI;YACH,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;YAC5B,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC,IAAI,CAAC;SAC5B;IAGH,CAAC;IAED,GAAG,CAAC,CAAC;QAEH,IAAI,CAAC,EAAC;YACJ,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;SAC7B;IAEH,CAAC;IAGD,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;;2GAvFU,cAAc;+FAAd,cAAc,yKCZ3B,u2HAkEA;2FDtDa,cAAc;kBAL1B,SAAS;+BACE,WAAW;kIAmCZ,MAAM;sBAAd,KAAK;gBAGG,IAAI;sBAAZ,KAAK;gBAEG,MAAM;sBAAd,KAAK;gBAEI,SAAS;sBAAlB,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\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\r\n  selectedTile: string = \"\";\r\n\r\n  new = true\r\n\r\n  clicked(v: Tile){\r\n\r\n\r\n\r\n    if(!this.config.clickable) return;\r\n\r\n\r\n    if(this.selectedTile == v.name){\r\n      this.tileClick.emit(\"\");\r\n      this.selectedTile = \"\";\r\n    }else{\r\n      this.tileClick.emit(v.name);\r\n      this.selectedTile = v.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  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}\r\n","      <div class=\"tin-row align-items-center tiles\" *ngIf=\"!new\">\r\n\r\n        <ng-container *ngFor=\"let tile of tiles\">\r\n\r\n          <mat-card class=\"card tin-col\" *ngIf=\"!tile.hidden\" (click)=\"clicked(tile)\">\r\n\r\n            <mat-label style=\"font-weight:bold; text-align: center; padding: 0px; margin: 0px;\" [ngStyle]=\"{'color':tile.color,'font-size':tile.name == selectedTile ? '45px' : '35px' }\">{{data ? data[tile.name] : 0}}</mat-label>\r\n\r\n            <div class=\"d-flex justify-content-center align-items-center\">\r\n\r\n              <!-- <button mat-icon-button (click)=\"pop(tile.info)\">\r\n                <mat-label [ngStyle]=\"{'font-size':tile.name == selectedTile ? '14px' : '14px' }\" style=\"padding-left:5px;padding-right:5px; margin-right: 10px;\">{{tile.alias ?? tile.name | camelToWords}}</mat-label>\r\n                <mat-icon [matTooltip]=\"tile.info\" matTooltipPosition=\"above\" [ngStyle]=\"{'font-size':tile.name == selectedTile ? '24x' : '24px' }\" style=\" color:steelblue;\">info</mat-icon>\r\n              </button> -->\r\n\r\n              <button mat-icon-button (click)=\"pop(tile.info)\" style=\"margin: 0px; padding: 0px;\">\r\n                <mat-label [ngStyle]=\"{'font-size':tile.name == selectedTile ? '14px' : '14px' }\" style=\"padding-left:5px;padding-right:5px; margin-right: 10px;\">{{tile.alias ?? tile.name | camelToWords}}</mat-label>\r\n                <mat-icon [matTooltip]=\"tile.info\" matTooltipPosition=\"above\" [ngStyle]=\"{'font-size':tile.name == selectedTile ? '24x' : '18px' }\" style=\" color:steelblue;\">info</mat-icon>\r\n              </button>\r\n\r\n              <!-- <div class=\"row d-flex justify-content-center row align-items-center\">\r\n                <mat-label [ngStyle]=\"{'font-size':tile.name == selectedTile ? '18px' : '12px' }\" style=\"padding-left:5px;padding-right:5px\">{{tile.name}}</mat-label>\r\n                <mat-icon [matTooltip]=\"tile.info\" matTooltipPosition=\"above\" [ngStyle]=\"{'font-size':tile.name == selectedTile ? '20px' : '17px' }\" style=\" color:steelblue;\">info</mat-icon>\r\n              </div> -->\r\n\r\n            </div>\r\n\r\n          </mat-card>\r\n\r\n        </ng-container>\r\n\r\n      </div>\r\n\r\n\r\n      <div class=\"d-flex row align-items-center justify-content-between\" *ngIf=\"new\">\r\n\r\n        <ng-container *ngFor=\"let tile of tiles\">\r\n\r\n          <mat-card class=\"col\" style=\"margin-left: 5px;margin-right: 5px; padding: 10px 16px ; min-width: 150px; margin-top: 5px;\" (click)=\"clicked(tile)\">\r\n\r\n            <div class=\"row d-flex justify-content-center align-items-center\">\r\n\r\n              <div style=\"text-align: center;\">\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,'font-size':tile.name == selectedTile ? '35px' : '30px' }\">{{data ? 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\r\n\r\n            </div>\r\n\r\n            <div class=\"row d-flex justify-content-center align-items-center\">\r\n\r\n              <div class=\"d-flex justify-content-center align-items-center\" style=\"text-align: center;\">\r\n                <mat-label [ngStyle]=\"{'font-size':tile.name == selectedTile ? '18px' : '14px' }\" style=\"padding-left:5px;padding-right:5px; text-align: center;\">{{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\r\n            </div>\r\n\r\n          </mat-card>\r\n\r\n\r\n        </ng-container>\r\n\r\n      </div>\r\n"]}
|
|
@@ -32,7 +32,6 @@ export class UsersComponent {
|
|
|
32
32
|
}
|
|
33
33
|
UpdateData() {
|
|
34
34
|
this.dataService.GetUser().subscribe((apiResponse) => {
|
|
35
|
-
// console.log(apiResponse)
|
|
36
35
|
this.usersRaw = apiResponse.data;
|
|
37
36
|
this.users = new MatTableDataSource(apiResponse.data);
|
|
38
37
|
this.users.paginator = this.usersPaginator;
|
|
@@ -116,4 +115,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
116
115
|
type: ViewChild,
|
|
117
116
|
args: ["usersPaginator"]
|
|
118
117
|
}] } });
|
|
119
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"users.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/users/users.component.ts","../../../../../../projects/tin-spa/src/lib/components/users/users.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Inject, ViewChild } from \"@angular/core\";\r\nimport { MatTableDataSource } from \"@angular/material/table\";\r\nimport { MatPaginator } from \"@angular/material/paginator\";\r\nimport { MatDialog, MatDialogRef, MAT_DIALOG_DATA } from \"@angular/material/dialog\";\r\nimport { DataServiceLib } from \"../../services/datalib.service\";\r\nimport { Router } from \"@angular/router\";\r\nimport { MessageService } from \"../../services/message.service\";\r\nimport { AuthService } from \"../../services/auth.service\";\r\nimport { TableConfig, User, ApiResponse } from '../../classes/Classes';\r\nimport { HttpService } from \"../../services/http.service\";\r\n\r\n@Component({\r\n  selector: \"spa-users\",\r\n  templateUrl: \"./users.component.html\",\r\n  styleUrls: [\"./users.component.css\"],\r\n})\r\nexport class UsersComponent implements OnInit {\r\n  constructor(private httpService: HttpService, public router: Router, private authService: AuthService, private dataService: DataServiceLib, public dialog: MatDialog, private messageService: MessageService) { }\r\n\r\n  ngOnInit() {\r\n    this.authService.isAuthorised(this.dataService.capUsers.name);\r\n    this.UpdateData();\r\n  }\r\n\r\n  isProcessing: boolean = false;\r\n  @ViewChild(\"usersPaginator\") usersPaginator: MatPaginator;\r\n\r\n  _filterText = \"\";\r\n\r\n  users;\r\n  usersRaw;\r\n  displayedColumns: string[] = [\"userName\", \"fullName\", \"roleName\", \"locked\", \"dateCreated\", \"Action\"];\r\n\r\n  public UpdateData() {\r\n    this.dataService.GetUser().subscribe(\r\n      (apiResponse) => {\r\n\r\n        // console.log(apiResponse)\r\n\r\n\r\n        this.usersRaw = apiResponse.data;\r\n        this.users = new MatTableDataSource(apiResponse.data);\r\n        this.users.paginator = this.usersPaginator;\r\n        this.applyFilter(this._filterText);\r\n\r\n      },\r\n      (error) => {\r\n        this.isProcessing = false;\r\n        this.messageService.toast(this.httpService.Error(error));\r\n      }\r\n    );\r\n  }\r\n\r\n  applyFilter(filterValue: string) {\r\n    this.users.filter = filterValue.trim().toLowerCase();\r\n  }\r\n\r\n  createAccount() {\r\n    this.router.navigate([\"home/admin/create-account\"]);\r\n  }\r\n\r\n  viewProfile(user: User) {\r\n\r\n    this.dataService.tmpProfileuserName = user.userName;\r\n    this.router.navigate([\"home/user/profile\"]);\r\n\r\n  }\r\n\r\n  lock(u) {\r\n    let login = { userName: u.userName, password: \"Abcdef@123\" }\r\n\r\n    this.dataService.LockUser(login).subscribe((apiResponse) => {\r\n\r\n      if (apiResponse.success) {\r\n        this.messageService.toast(\"User Locked\");\r\n        this.UpdateData();\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse);\r\n      }\r\n    });\r\n  }\r\n\r\n  unlock(u) {\r\n    let login = { userName: u.userName, password: \"Abcdef@123\" }\r\n\r\n    this.dataService.UnlockUser(login).subscribe((apiResponse) => {\r\n\r\n      if (apiResponse.success) {\r\n        this.messageService.toast(\"User Unlocked\");\r\n        this.UpdateData();\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse);\r\n      }\r\n    });\r\n  }\r\n\r\n  recover(u: User) {\r\n    this.dataService.SelfReset(u).subscribe((apiResponse: ApiResponse) => {\r\n      if (apiResponse.message == \"success\") {\r\n        this.messageService.toast(\"The password has been sent on email\");\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse.message);\r\n      }\r\n    });\r\n\r\n  }\r\n\r\n  deleteUser(user: User) {\r\n\r\n\r\n\r\n    this.messageService.confirm(`Delete ${user.userName} ?`).subscribe((result) => {\r\n\r\n      if (result == \"yes\") {\r\n\r\n        this.isProcessing = true;\r\n        this.dataService.DeleteUser(user).subscribe(\r\n          (apiResponse: ApiResponse) => {\r\n            this.isProcessing = false;\r\n\r\n            if (apiResponse.message == \"success\") {\r\n              this.messageService.toast(\"User Deleted\");\r\n\r\n              this.UpdateData();\r\n\r\n            } else {\r\n              this.messageService.toast(\"Error: \" + apiResponse.message);\r\n            }\r\n          },\r\n          (error) => {\r\n            this.messageService.toast(\"Connection failed \");\r\n            this.isProcessing = false;\r\n          }\r\n        );\r\n\r\n      }\r\n    })\r\n  }\r\n\r\n\r\n\r\n  //----------------------------------------\r\n\r\n  // config: TableConfig = {\r\n  //   showFilter: true,\r\n  //   newText: \"Create Account\",\r\n  //   minColumns: ['firstName', 'lastName', 'roleID'],\r\n\r\n  //   columns: [\r\n  //     { name: 'userName', type: 'text', icon: { name: 'person', color: 'green', tip: 'name desc' } },\r\n  //     { name: 'firstName', type: 'text',},\r\n  //     { name: 'lastName', type: 'text' },\r\n  //     { name: 'roleID', type: 'text' },\r\n  //     { name: 'locked', type: 'checkbox' },\r\n  //     { name: 'createdDate', type: 'date' },\r\n  //   ],\r\n\r\n  //   buttons: [\r\n  //     { name:'create', display:'Create Account', dialog: true },\r\n  //     { name: 'view', dialog: true, icon: { name: 'account_circle'} },\r\n  //     { name: 'custom1', action: { method: 'post', url: 'User/lock', successMessage: \"User locked\" }, color:'red', tip:'lock', icon: { name: 'lock'}, visible: (value) => value.locked == 0},\r\n  //     { name: 'custom2', action: { method: 'post', url: 'User/unlock', successMessage: \"User Unlocked\" }, color: 'green', tip: 'unlock', icon: { name: 'lock_open' }, visible: (value) => value.locked == 1 },\r\n  //     { name: 'delete' },\r\n  //   ],\r\n\r\n  //   loadAction: { url: 'User/all/x' }\r\n\r\n  // }\r\n\r\n}\r\n\r\n\r\n\r\n","\r\n<h4>Users</h4>\r\n<hr />\r\n\r\n<div class=\"container-fluid\" style=\"font-size: 14px;\">\r\n\r\n  <div class=\"row justify-content-between\" style=\"padding-bottom: 10px\">\r\n    <div class=\"col-2\">\r\n      <button id=\"btnCreateAccount\" mat-raised-button color=\"primary\" (click)=\"createAccount()\">Create User</button>\r\n    </div>\r\n\r\n    <div class=\"d-flex justify-content-end\">\r\n      <spa-filter [data]=\"users\" (refreshClick)=\"UpdateData()\"></spa-filter>\r\n    </div>\r\n  </div>\r\n\r\n\r\n  <p *ngIf=\"!users\"><em>Loading...</em></p>\r\n\r\n\r\n  <div class=\"mat-elevation-z8\" *ngIf=\"users\">\r\n\r\n    <table id=\"tblTable\" mat-table [dataSource]=\"users\">\r\n\r\n      <ng-container matColumnDef=\"userName\">\r\n        <th mat-header-cell *matHeaderCellDef> UserName </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.userName}} </td>\r\n      </ng-container>\r\n\r\n      <ng-container matColumnDef=\"locked\">\r\n        <th mat-header-cell *matHeaderCellDef> Locked </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.locked}} </td>\r\n      </ng-container>\r\n\r\n      <ng-container matColumnDef=\"fullName\">\r\n        <th mat-header-cell *matHeaderCellDef> Name </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.firstName}} {{user.lastName}} </td>\r\n      </ng-container>\r\n\r\n      <ng-container matColumnDef=\"roleName\">\r\n        <th mat-header-cell *matHeaderCellDef> Role </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.role.roleName}} </td>\r\n      </ng-container>\r\n\r\n      <ng-container matColumnDef=\"disabled\">\r\n        <th mat-header-cell *matHeaderCellDef> Disabled </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.disabled}} </td>\r\n      </ng-container>\r\n\r\n      <ng-container matColumnDef=\"dateCreated\">\r\n        <th mat-header-cell *matHeaderCellDef> Created </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.createdDate | date: 'dd/MM/yyyy'}} </td>\r\n      </ng-container>\r\n\r\n      <ng-container matColumnDef=\"dateUpdated\">\r\n        <th mat-header-cell *matHeaderCellDef> Updated </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.updatedDate | date: 'dd/MM/yyyy'}} </td>\r\n      </ng-container>\r\n\r\n\r\n      <ng-container matColumnDef=\"Action\">\r\n        <th mat-header-cell *matHeaderCellDef> Action </th>\r\n        <td mat-cell *matCellDef=\"let user\" style=\"width: 250px;\">\r\n\r\n          <button mat-mini-fab color=\"primary\" (click)=\"viewProfile(user)\" style=\"margin-right:30px\" matTooltip=\"View Profile\" matTooltipPosition=\"above\"> <mat-icon>account_circle</mat-icon></button>\r\n\r\n          <button *ngIf=\"user.locked=='0'\" mat-mini-fab color=\"warn\" (click)=\"lock(user)\" style=\"margin-right:10px\" matTooltip=\"Lock\" matTooltipPosition=\"above\"> <mat-icon>lock</mat-icon></button>\r\n          <button *ngIf=\"user.locked=='1'\" mat-mini-fab  (click)=\"unlock(user)\" style=\"margin-right:10px; background-color: green;\" matTooltip=\"Unlock\" matTooltipPosition=\"above\"> <mat-icon >lock_open</mat-icon></button>\r\n\r\n          <!-- <button *ngIf=\"user.disabled=='0'\" mat-mini-fab color=\"warn\" (click)=\"disable(user)\" style=\"margin-right:10px\" matTooltip=\"Disable\" matTooltipPosition=\"above\"> <mat-icon>block</mat-icon></button>\r\n          <button *ngIf=\"user.disabled=='1'\" mat-mini-fab (click)=\"enable(user)\" style=\"margin-right:10px; background-color: green\" matTooltip=\"Enable\" matTooltipPosition=\"above\"> <mat-icon>done</mat-icon></button> -->\r\n\r\n          <button mat-mini-fab color=\"warn\" (click)=\"deleteUser(user)\" style=\"margin-right:10px\" matTooltip=\"Delete\" matTooltipPosition=\"above\"> <mat-icon>delete</mat-icon></button>\r\n          <!-- <button mat-mini-fab color=\"primary\" (click)=\"recover(user)\" style=\"margin-right:10px\" matTooltip=\"Reset Password\" matTooltipPosition=\"above\"> <mat-icon>vpn_key</mat-icon></button> -->\r\n\r\n\r\n\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': row.disabled =='1'}\"></tr>\r\n\r\n    </table>\r\n\r\n  </div>\r\n\r\n  <mat-paginator #usersPaginator [pageSizeOptions]=\"[10, 20, 50]\" showFirstLastButtons></mat-paginator>\r\n</div>\r\n\r\n<!-- ------------------ -->\r\n\r\n<!-- <div class=\"container mt-5\" style=\" font-size: 14px;\">\r\n<spa-table  [data]=\"usersRaw\" [config]=\"config\" (refreshClick)=\"UpdateData()\" (viewClick)=\"viewProfile($event)\" (createClick)=\"createAccount()\" (deleteClick)=\"deleteUser($event)\"></spa-table>\r\n</div> -->\r\n\r\n"]}
|
|
118
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"users.component.js","sourceRoot":"","sources":["../../../../../../projects/tin-spa/src/lib/components/users/users.component.ts","../../../../../../projects/tin-spa/src/lib/components/users/users.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Inject, ViewChild } from \"@angular/core\";\r\nimport { MatTableDataSource } from \"@angular/material/table\";\r\nimport { MatPaginator } from \"@angular/material/paginator\";\r\nimport { MatDialog, MatDialogRef, MAT_DIALOG_DATA } from \"@angular/material/dialog\";\r\nimport { DataServiceLib } from \"../../services/datalib.service\";\r\nimport { Router } from \"@angular/router\";\r\nimport { MessageService } from \"../../services/message.service\";\r\nimport { AuthService } from \"../../services/auth.service\";\r\nimport { TableConfig, User, ApiResponse } from '../../classes/Classes';\r\nimport { HttpService } from \"../../services/http.service\";\r\n\r\n@Component({\r\n  selector: \"spa-users\",\r\n  templateUrl: \"./users.component.html\",\r\n  styleUrls: [\"./users.component.css\"],\r\n})\r\nexport class UsersComponent implements OnInit {\r\n  constructor(private httpService: HttpService, public router: Router, private authService: AuthService, private dataService: DataServiceLib, public dialog: MatDialog, private messageService: MessageService) { }\r\n\r\n  ngOnInit() {\r\n    this.authService.isAuthorised(this.dataService.capUsers.name);\r\n    this.UpdateData();\r\n  }\r\n\r\n  isProcessing: boolean = false;\r\n  @ViewChild(\"usersPaginator\") usersPaginator: MatPaginator;\r\n\r\n  _filterText = \"\";\r\n\r\n  users;\r\n  usersRaw;\r\n  displayedColumns: string[] = [\"userName\", \"fullName\", \"roleName\", \"locked\", \"dateCreated\", \"Action\"];\r\n\r\n  public UpdateData() {\r\n    this.dataService.GetUser().subscribe(\r\n      (apiResponse) => {\r\n\r\n        this.usersRaw = apiResponse.data;\r\n        this.users = new MatTableDataSource(apiResponse.data);\r\n        this.users.paginator = this.usersPaginator;\r\n        this.applyFilter(this._filterText);\r\n\r\n      },\r\n      (error) => {\r\n        this.isProcessing = false;\r\n        this.messageService.toast(this.httpService.Error(error));\r\n      }\r\n    );\r\n  }\r\n\r\n  applyFilter(filterValue: string) {\r\n    this.users.filter = filterValue.trim().toLowerCase();\r\n  }\r\n\r\n  createAccount() {\r\n    this.router.navigate([\"home/admin/create-account\"]);\r\n  }\r\n\r\n  viewProfile(user: User) {\r\n\r\n    this.dataService.tmpProfileuserName = user.userName;\r\n    this.router.navigate([\"home/user/profile\"]);\r\n\r\n  }\r\n\r\n  lock(u) {\r\n    let login = { userName: u.userName, password: \"Abcdef@123\" }\r\n\r\n    this.dataService.LockUser(login).subscribe((apiResponse) => {\r\n\r\n      if (apiResponse.success) {\r\n        this.messageService.toast(\"User Locked\");\r\n        this.UpdateData();\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse);\r\n      }\r\n    });\r\n  }\r\n\r\n  unlock(u) {\r\n    let login = { userName: u.userName, password: \"Abcdef@123\" }\r\n\r\n    this.dataService.UnlockUser(login).subscribe((apiResponse) => {\r\n\r\n      if (apiResponse.success) {\r\n        this.messageService.toast(\"User Unlocked\");\r\n        this.UpdateData();\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse);\r\n      }\r\n    });\r\n  }\r\n\r\n  recover(u: User) {\r\n    this.dataService.SelfReset(u).subscribe((apiResponse: ApiResponse) => {\r\n      if (apiResponse.message == \"success\") {\r\n        this.messageService.toast(\"The password has been sent on email\");\r\n      } else {\r\n        this.messageService.toast(\"Error: \" + apiResponse.message);\r\n      }\r\n    });\r\n\r\n  }\r\n\r\n  deleteUser(user: User) {\r\n\r\n\r\n\r\n    this.messageService.confirm(`Delete ${user.userName} ?`).subscribe((result) => {\r\n\r\n      if (result == \"yes\") {\r\n\r\n        this.isProcessing = true;\r\n        this.dataService.DeleteUser(user).subscribe(\r\n          (apiResponse: ApiResponse) => {\r\n            this.isProcessing = false;\r\n\r\n            if (apiResponse.message == \"success\") {\r\n              this.messageService.toast(\"User Deleted\");\r\n\r\n              this.UpdateData();\r\n\r\n            } else {\r\n              this.messageService.toast(\"Error: \" + apiResponse.message);\r\n            }\r\n          },\r\n          (error) => {\r\n            this.messageService.toast(\"Connection failed \");\r\n            this.isProcessing = false;\r\n          }\r\n        );\r\n\r\n      }\r\n    })\r\n  }\r\n\r\n\r\n\r\n  //----------------------------------------\r\n\r\n  // config: TableConfig = {\r\n  //   showFilter: true,\r\n  //   newText: \"Create Account\",\r\n  //   minColumns: ['firstName', 'lastName', 'roleID'],\r\n\r\n  //   columns: [\r\n  //     { name: 'userName', type: 'text', icon: { name: 'person', color: 'green', tip: 'name desc' } },\r\n  //     { name: 'firstName', type: 'text',},\r\n  //     { name: 'lastName', type: 'text' },\r\n  //     { name: 'roleID', type: 'text' },\r\n  //     { name: 'locked', type: 'checkbox' },\r\n  //     { name: 'createdDate', type: 'date' },\r\n  //   ],\r\n\r\n  //   buttons: [\r\n  //     { name:'create', display:'Create Account', dialog: true },\r\n  //     { name: 'view', dialog: true, icon: { name: 'account_circle'} },\r\n  //     { name: 'custom1', action: { method: 'post', url: 'User/lock', successMessage: \"User locked\" }, color:'red', tip:'lock', icon: { name: 'lock'}, visible: (value) => value.locked == 0},\r\n  //     { name: 'custom2', action: { method: 'post', url: 'User/unlock', successMessage: \"User Unlocked\" }, color: 'green', tip: 'unlock', icon: { name: 'lock_open' }, visible: (value) => value.locked == 1 },\r\n  //     { name: 'delete' },\r\n  //   ],\r\n\r\n  //   loadAction: { url: 'User/all/x' }\r\n\r\n  // }\r\n\r\n}\r\n\r\n\r\n\r\n","\r\n<h4>Users</h4>\r\n<hr />\r\n\r\n<div class=\"container-fluid\" style=\"font-size: 14px;\">\r\n\r\n  <div class=\"row justify-content-between\" style=\"padding-bottom: 10px\">\r\n    <div class=\"col-2\">\r\n      <button id=\"btnCreateAccount\" mat-raised-button color=\"primary\" (click)=\"createAccount()\">Create User</button>\r\n    </div>\r\n\r\n    <div class=\"d-flex justify-content-end\">\r\n      <spa-filter [data]=\"users\" (refreshClick)=\"UpdateData()\"></spa-filter>\r\n    </div>\r\n  </div>\r\n\r\n\r\n  <p *ngIf=\"!users\"><em>Loading...</em></p>\r\n\r\n\r\n  <div class=\"mat-elevation-z8\" *ngIf=\"users\">\r\n\r\n    <table id=\"tblTable\" mat-table [dataSource]=\"users\">\r\n\r\n      <ng-container matColumnDef=\"userName\">\r\n        <th mat-header-cell *matHeaderCellDef> UserName </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.userName}} </td>\r\n      </ng-container>\r\n\r\n      <ng-container matColumnDef=\"locked\">\r\n        <th mat-header-cell *matHeaderCellDef> Locked </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.locked}} </td>\r\n      </ng-container>\r\n\r\n      <ng-container matColumnDef=\"fullName\">\r\n        <th mat-header-cell *matHeaderCellDef> Name </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.firstName}} {{user.lastName}} </td>\r\n      </ng-container>\r\n\r\n      <ng-container matColumnDef=\"roleName\">\r\n        <th mat-header-cell *matHeaderCellDef> Role </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.role.roleName}} </td>\r\n      </ng-container>\r\n\r\n      <ng-container matColumnDef=\"disabled\">\r\n        <th mat-header-cell *matHeaderCellDef> Disabled </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.disabled}} </td>\r\n      </ng-container>\r\n\r\n      <ng-container matColumnDef=\"dateCreated\">\r\n        <th mat-header-cell *matHeaderCellDef> Created </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.createdDate | date: 'dd/MM/yyyy'}} </td>\r\n      </ng-container>\r\n\r\n      <ng-container matColumnDef=\"dateUpdated\">\r\n        <th mat-header-cell *matHeaderCellDef> Updated </th>\r\n        <td mat-cell *matCellDef=\"let user\"> {{user.updatedDate | date: 'dd/MM/yyyy'}} </td>\r\n      </ng-container>\r\n\r\n\r\n      <ng-container matColumnDef=\"Action\">\r\n        <th mat-header-cell *matHeaderCellDef> Action </th>\r\n        <td mat-cell *matCellDef=\"let user\" style=\"width: 250px;\">\r\n\r\n          <button mat-mini-fab color=\"primary\" (click)=\"viewProfile(user)\" style=\"margin-right:30px\" matTooltip=\"View Profile\" matTooltipPosition=\"above\"> <mat-icon>account_circle</mat-icon></button>\r\n\r\n          <button *ngIf=\"user.locked=='0'\" mat-mini-fab color=\"warn\" (click)=\"lock(user)\" style=\"margin-right:10px\" matTooltip=\"Lock\" matTooltipPosition=\"above\"> <mat-icon>lock</mat-icon></button>\r\n          <button *ngIf=\"user.locked=='1'\" mat-mini-fab  (click)=\"unlock(user)\" style=\"margin-right:10px; background-color: green;\" matTooltip=\"Unlock\" matTooltipPosition=\"above\"> <mat-icon >lock_open</mat-icon></button>\r\n\r\n          <!-- <button *ngIf=\"user.disabled=='0'\" mat-mini-fab color=\"warn\" (click)=\"disable(user)\" style=\"margin-right:10px\" matTooltip=\"Disable\" matTooltipPosition=\"above\"> <mat-icon>block</mat-icon></button>\r\n          <button *ngIf=\"user.disabled=='1'\" mat-mini-fab (click)=\"enable(user)\" style=\"margin-right:10px; background-color: green\" matTooltip=\"Enable\" matTooltipPosition=\"above\"> <mat-icon>done</mat-icon></button> -->\r\n\r\n          <button mat-mini-fab color=\"warn\" (click)=\"deleteUser(user)\" style=\"margin-right:10px\" matTooltip=\"Delete\" matTooltipPosition=\"above\"> <mat-icon>delete</mat-icon></button>\r\n          <!-- <button mat-mini-fab color=\"primary\" (click)=\"recover(user)\" style=\"margin-right:10px\" matTooltip=\"Reset Password\" matTooltipPosition=\"above\"> <mat-icon>vpn_key</mat-icon></button> -->\r\n\r\n\r\n\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': row.disabled =='1'}\"></tr>\r\n\r\n    </table>\r\n\r\n  </div>\r\n\r\n  <mat-paginator #usersPaginator [pageSizeOptions]=\"[10, 20, 50]\" showFirstLastButtons></mat-paginator>\r\n</div>\r\n\r\n<!-- ------------------ -->\r\n\r\n<!-- <div class=\"container mt-5\" style=\" font-size: 14px;\">\r\n<spa-table  [data]=\"usersRaw\" [config]=\"config\" (refreshClick)=\"UpdateData()\" (viewClick)=\"viewProfile($event)\" (createClick)=\"createAccount()\" (deleteClick)=\"deleteUser($event)\"></spa-table>\r\n</div> -->\r\n\r\n"]}
|
|
@@ -18,8 +18,6 @@ export class ViewerComponent {
|
|
|
18
18
|
this.title = "Documents";
|
|
19
19
|
}
|
|
20
20
|
ngOnInit() {
|
|
21
|
-
// this.fileNames = 'tinashe.jpg'
|
|
22
|
-
console.log("Viewer Init");
|
|
23
21
|
if (this.fileAction) {
|
|
24
22
|
this.loadData();
|
|
25
23
|
}
|
|
@@ -78,4 +76,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
78
76
|
}], title: [{
|
|
79
77
|
type: Input
|
|
80
78
|
}] } });
|
|
81
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlld2VyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Rpbi1zcGEvc3JjL2xpYi9jb21wb25lbnRzL3ZpZXdlci92aWV3ZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGluLXNwYS9zcmMvbGliL2NvbXBvbmVudHMvdmlld2VyL3ZpZXdlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQVUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRS9FLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQzs7Ozs7OztBQVN4RCxNQUFNLE9BQU8sZUFBZTtJQUUxQixZQUFvQixXQUEyQixFQUFRLE1BQWlCO1FBQXBELGdCQUFXLEdBQVgsV0FBVyxDQUFnQjtRQUFRLFdBQU0sR0FBTixNQUFNLENBQVc7UUFjL0QsU0FBSSxHQUFHLEVBQUUsQ0FBQztRQUNWLGVBQVUsR0FBQyxFQUFFLENBQUM7UUFFZCxjQUFTLEdBQUcsS0FBSyxDQUFDO1FBQ2pCLFdBQU0sR0FBRyxJQUFJLFlBQVksRUFBRSxDQUFDO1FBQzdCLFlBQU8sR0FBRyxXQUFXLENBQUM7UUFDdEIsVUFBSyxHQUFHLFdBQVcsQ0FBQztJQXBCK0MsQ0FBQztJQUU3RSxRQUFRO1FBRU4sSUFBSSxJQUFJLENBQUMsVUFBVSxFQUFDO1lBQ2xCLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQztTQUNqQjthQUFJO1lBQ0gsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO1NBQ2hCO0lBQ0gsQ0FBQztJQWFELHNCQUFzQjtJQUV0QixRQUFRO1FBRU4sT0FBTyxDQUFDLEdBQUcsQ0FBQyxlQUFlLENBQUMsQ0FBQTtRQUM1QixJQUFJLEdBQUcsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFFLEdBQUcsR0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUE7UUFDaEUsSUFBSSxDQUFDLFdBQVcsQ0FBQyxPQUFPLENBQUMsRUFBQyxHQUFHLEVBQUUsR0FBRyxFQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsV0FBd0IsRUFBRSxFQUFFO1lBQzlFLElBQUksQ0FBQyxTQUFTLEdBQUcsV0FBVyxDQUFDLElBQUksQ0FBQztZQUNsQyw4QkFBOEI7WUFDOUIsSUFBSSxDQUFDLE9BQU8sRUFBRSxDQUFDO1FBQ2pCLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELE9BQU87UUFDTCxJQUFJLE9BQU8sSUFBSSxDQUFDLFNBQVMsSUFBSSxRQUFRLEVBQUU7WUFDckMsSUFBSSxDQUFDLFNBQVMsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQTtTQUMzQztJQUNILENBQUM7SUFFRCxRQUFRLENBQUMsUUFBZ0I7UUFFdkIsSUFBSSxPQUFPLFFBQVEsSUFBSSxRQUFRLEVBQUU7WUFDL0IsT0FBTztTQUNSO1FBSUQsTUFBTSxTQUFTLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsWUFBWSxFQUFFO1lBQy9DLFFBQVEsRUFBRSxLQUFLO1lBQ2YsUUFBUSxFQUFFLE1BQU07WUFFaEIsSUFBSSxFQUFFLEVBQUUsU0FBUyxFQUFFLElBQUksQ0FBQyxTQUFTLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsR0FBRyxJQUFJLENBQUMsSUFBSSxJQUFJLEVBQUUsSUFBSSxJQUFJLENBQUMsVUFBVSxJQUFJLEVBQUUsRUFBRSxFQUFFO1NBQzdHLENBQUMsQ0FBQztJQUVMLENBQUM7SUFFRCxPQUFPLENBQUMsQ0FBQztRQUNQLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ3RCLENBQUM7OzRHQTlEVSxlQUFlO2dHQUFmLGVBQWUsbVBDWDVCLHFnQkFhQTsyRkRGYSxlQUFlO2tCQUwzQixTQUFTOytCQUNFLFlBQVk7NkhBbUJiLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csSUFBSTtzQkFBWixLQUFLO2dCQUNHLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csU0FBUztzQkFBakIsS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUNJLE1BQU07c0JBQWYsTUFBTTtnQkFDRSxPQUFPO3NCQUFmLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkluaXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBNYXREaWFsb2csIE1hdERpYWxvZ1JlZiB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpYWxvZyc7XHJcbmltcG9ydCB7IHZpZXdlckRpYWxvZyB9IGZyb20gJy4vdmlld2VyRGlhbG9nLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IERhdGFTZXJ2aWNlTGliIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvZGF0YWxpYi5zZXJ2aWNlJztcclxuaW1wb3J0IHsgQWN0aW9uLCBBcGlSZXNwb25zZSB9IGZyb20gJy4uLy4uL2NsYXNzZXMvQ2xhc3Nlcyc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ3NwYS12aWV3ZXInLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi92aWV3ZXIuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL3ZpZXdlci5jb21wb25lbnQuY3NzJ11cclxufSlcclxuZXhwb3J0IGNsYXNzIFZpZXdlckNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcblxyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgZGF0YVNlcnZpY2U6IERhdGFTZXJ2aWNlTGliLHB1YmxpYyBkaWFsb2c6IE1hdERpYWxvZykgeyB9XHJcblxyXG4gIG5nT25Jbml0KCk6IHZvaWQge1xyXG5cclxuICAgIGlmICh0aGlzLmZpbGVBY3Rpb24pe1xyXG4gICAgICB0aGlzLmxvYWREYXRhKCk7XHJcbiAgICB9ZWxzZXtcclxuICAgICAgdGhpcy5jb252ZXJ0KCk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuXHJcblxyXG4gIEBJbnB1dCgpIGZpbGVBY3Rpb24gOiBBY3Rpb247XHJcbiAgQElucHV0KCkgcGF0aCA9IFwiXCI7XHJcbiAgQElucHV0KCkgZm9sZGVyTmFtZT1cIlwiO1xyXG4gIEBJbnB1dCgpIGZpbGVOYW1lczsvLyBuZXcgQXJyYXkoKVxyXG4gIEBJbnB1dCgpIHJlbW92YWJsZSA9IGZhbHNlO1xyXG4gIEBPdXRwdXQoKSByZW1vdmUgPSBuZXcgRXZlbnRFbWl0dGVyKCk7XHJcbiAgQElucHV0KCkgZGlzcGxheSA9IFwiRG9jdW1lbnRzXCI7XHJcbiAgQElucHV0KCkgdGl0bGUgPSBcIkRvY3VtZW50c1wiO1xyXG5cclxuICAvLyBmaWxlTGlzdDogc3RyaW5nW107XHJcblxyXG4gIGxvYWREYXRhKCkge1xyXG5cclxuICAgIGNvbnNvbGUubG9nKFwiQ2FsbGluZyBmaWxlc1wiKVxyXG4gICAgbGV0IHVybCA9IHRoaXMuZmlsZUFjdGlvbi51cmwucmVwbGFjZShcIi94XCIsICcvJyt0aGlzLmZvbGRlck5hbWUpXHJcbiAgICB0aGlzLmRhdGFTZXJ2aWNlLkNhbGxBcGkoe3VybDogdXJsfSwgXCJcIikuc3Vic2NyaWJlKChhcGlSZXNwb25zZTogQXBpUmVzcG9uc2UpID0+IHtcclxuICAgICAgdGhpcy5maWxlTmFtZXMgPSBhcGlSZXNwb25zZS5kYXRhO1xyXG4gICAgICAvLyBjb25zb2xlLmxvZyh0aGlzLmZpbGVOYW1lcylcclxuICAgICAgdGhpcy5jb252ZXJ0KCk7XHJcbiAgICB9KTtcclxuICB9XHJcblxyXG4gIGNvbnZlcnQoKXtcclxuICAgIGlmICh0eXBlb2YgdGhpcy5maWxlTmFtZXMgPT0gJ3N0cmluZycpIHtcclxuICAgICAgdGhpcy5maWxlTmFtZXMgPSB0aGlzLmZpbGVOYW1lcy5zcGxpdChcInxcIilcclxuICAgIH1cclxuICB9XHJcblxyXG4gIHZpZXdEb2NzKGZpbGVOYW1lOiBzdHJpbmcpIHtcclxuXHJcbiAgICBpZiAodHlwZW9mIGZpbGVOYW1lICE9ICdzdHJpbmcnKSB7XHJcbiAgICAgIHJldHVybjtcclxuICAgIH1cclxuXHJcblxyXG5cclxuICAgIGNvbnN0IGRpYWxvZ1JlZiA9IHRoaXMuZGlhbG9nLm9wZW4odmlld2VyRGlhbG9nLCB7XHJcbiAgICAgIG1pbldpZHRoOiAnOTUlJyxcclxuICAgICAgbWF4V2lkdGg6ICc4MHZ3JyxcclxuXHJcbiAgICAgIGRhdGE6IHsgZmlsZU5hbWVzOiB0aGlzLmZpbGVOYW1lcywgZmlsZU5hbWU6IGZpbGVOYW1lLCBwYXRoOiBgJHt0aGlzLnBhdGggPz8gJyd9LyR7dGhpcy5mb2xkZXJOYW1lID8/ICcnfWAgfVxyXG4gICAgfSk7XHJcblxyXG4gIH1cclxuXHJcbiAgcmVtb3ZlZChpKXtcclxuICAgIHRoaXMucmVtb3ZlLmVtaXQoaSk7XHJcbiAgfVxyXG5cclxufVxyXG4iLCI8ZGl2IGNsYXNzPVwidGluLWlucHV0LXJvdyBtdC0zXCIgKm5nSWY9XCJ0aXRsZSAhPSAnJ1wiPlxyXG4gIDxtYXQtbGFiZWwgc3R5bGU9XCJmb250LXNpemU6IDIwcHg7IGZvbnQtd2VpZ2h0OiAzMDBcIiA+ICB7e3RpdGxlfX08L21hdC1sYWJlbCA+XHJcbjwvZGl2PlxyXG5cclxuPHNwYS1jaGlwcyBbY2hpcHNdPVwiZmlsZU5hbWVzXCIgW3RpdGxlXT1cInRpdGxlXCIgIFtyZW1vdmFibGVdPVwicmVtb3ZhYmxlXCIgaWNvbj1cImRlc2NyaXB0aW9uXCIgKGNsaWNrKT1cInZpZXdEb2NzKCRldmVudClcIiAocmVtb3ZlKT1cInJlbW92ZWQoJGV2ZW50KVwiPjwvc3BhLWNoaXBzPlxyXG5cclxuXHJcblxyXG48ZGl2ICpuZ0lmPVwiIWZpbGVOYW1lc1wiIGNsYXNzPVwiZC1mbGV4IGp1c3RpZnktY29udGVudC1jZW50ZXIgcm93IGFsaWduLWl0ZW1zLWNlbnRlclwiIHN0eWxlPVwibWF4LWhlaWdodDoyMDBweFwiPlxyXG5cclxuICBObyB7e3RpdGxlLnRvTG93ZXJDYXNlKCl9fVxyXG5cclxuPC9kaXY+XHJcbiJdfQ==
|