@one-paragon/angular-utilities 0.0.11-b → 0.0.13

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.
@@ -23,7 +23,7 @@ export class PaginatorComponent {
23
23
  }
24
24
  paginatorChange() {
25
25
  if (!this.ourPageEvent) {
26
- //setTimeout(() => this.tableElRef?.nativeElement?.scrollIntoView(), 0);
26
+ setTimeout(() => this.tableElRef?.nativeElement?.scrollIntoView(), 0);
27
27
  }
28
28
  else {
29
29
  this.ourPageEvent = false;
@@ -71,4 +71,4 @@ const delayToAllowForProperUpdate = delay(0, asyncScheduler);
71
71
  const metaDataPageSizeChange = (state) => state.state$.pipe(map(state => state.pageSize), distinct());
72
72
  const setPaginatorPageSize = (paginator) => (pageSize) => paginator._changePageSize(pageSize);
73
73
  const onPagiantorPageSizeChange = (paginator) => paginator.page.pipe(map(e => e.pageSize), distinct());
74
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"paginator.component.js","sourceRoot":"","sources":["../../../../../../projects/angular-utilities/src/table-builder/components/generic-table/paginator.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ChangeDetectionStrategy,\n  ViewChild,\n  Input,\n  ElementRef,\n  AfterViewInit,\n  OnInit,\n} from '@angular/core';\nimport { MatPaginator, PageEvent } from '@angular/material/paginator';\nimport { asyncScheduler, merge, Observable } from 'rxjs';\nimport { delay, distinct, distinctUntilKeyChanged, map } from 'rxjs/operators';\nimport { GenericTableDataSource } from '../../classes/GenericTableDataSource';\nimport { TableStore } from '../../classes/table-store';\n@Component({\n  selector: 'tb-paginator',\n  template: `\n  <div [ngClass]=\"{'hide' : !(collapseFooter$ | async), 'page-amounts':true}\" *ngIf=\"currentPageData$ | async as pageData\">\n    {{pageData.currentStart}} - {{pageData.currentEnd}} of {{pageData.total}}\n  </div>\n  <mat-paginator [pageSizeOptions]=\"[5, 10, 20, 50, 100, 500]\" showFirstLastButtons (page)=\"paginatorChange()\"\n    [ngClass]=\"{'hide' : (collapseFooter$ | async)}\">\n  </mat-paginator>\n  `,\n  styleUrls: ['./generic-table.component.scss','../../styles/collapser.styles.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class PaginatorComponent implements OnInit, AfterViewInit{\n  @Input() dataSource! : GenericTableDataSource<any>;\n  @Input() tableElRef! : ElementRef\n  @ViewChild(MatPaginator, { static: true }) paginator!: MatPaginator;\n  currentPageData$!: Observable<CurrentPageDetails>;\n  collapseFooter$!:Observable<boolean>;\n  @Input() data$!: Observable<any[]>;\n\n  constructor(private state : TableStore){}\n  ngOnInit(){\n    this.dataSource.paginator = this.paginator;\n    this.ourPageEvent = true;\n    this.state.on(metaDataPageSizeChange(this.state), setPaginatorPageSize(this.paginator));\n    this.state.setPageSize(onPagiantorPageSizeChange(this.paginator));\n    this.collapseFooter$ = this.state.state$.pipe(map(state => state.persistedTableSettings.collapseFooter));\n\n  }\n  ngAfterViewInit(){\n    this.currentPageData$ = merge(\n      this.paginator.page.pipe(map(mapPaginationEventToCurrentPageDetails)),\n      this.data$.pipe(\n        distinctUntilKeyChanged(\"length\"),\n        delayToAllowForProperUpdate,\n        map(updateCurrentPageDetailsOnDataLengthChange(this.paginator)))\n    );\n  }\n\n  paginatorChange() : void {\n    if(!this.ourPageEvent){\n      //setTimeout(() => this.tableElRef?.nativeElement?.scrollIntoView(), 0);\n    } else {\n      this.ourPageEvent = false;\n    }\n  }\n  ourPageEvent = false;\n\n}\n\nconst mapPaginationEventToCurrentPageDetails = (pageData: PageEvent):CurrentPageDetails => ({\n  currentStart : (pageData.pageIndex * pageData.pageSize) + 1,\n  currentEnd : Math.min(pageData.length , ((pageData.pageIndex + 1) * pageData.pageSize)),\n  total : pageData.length\n});\n\nconst updateCurrentPageDetailsOnDataLengthChange = (paginator:MatPaginator) => () => ({currentStart:(paginator.pageIndex * paginator.pageSize) + 1,\n  currentEnd: Math.min(paginator.length , ((paginator.pageIndex + 1) * paginator.pageSize)),\n  total:paginator.length})\n\nconst delayToAllowForProperUpdate = delay<any[]>(0,asyncScheduler);\n\ninterface CurrentPageDetails {\n  currentStart:number,\n  currentEnd:number,\n  total:number\n}\n\nconst metaDataPageSizeChange = (state:TableStore) => state.state$.pipe(map(state => state.pageSize),distinct());\n\nconst setPaginatorPageSize = (paginator:MatPaginator) => (pageSize: number) =>\n  paginator._changePageSize(pageSize);\n\nconst onPagiantorPageSizeChange = (paginator: MatPaginator) => paginator.page.pipe(map( e => e.pageSize ), distinct());\n"]}
74
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"paginator.component.js","sourceRoot":"","sources":["../../../../../../projects/angular-utilities/src/table-builder/components/generic-table/paginator.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ChangeDetectionStrategy,\n  ViewChild,\n  Input,\n  ElementRef,\n  AfterViewInit,\n  OnInit,\n} from '@angular/core';\nimport { MatPaginator, PageEvent } from '@angular/material/paginator';\nimport { asyncScheduler, merge, Observable } from 'rxjs';\nimport { delay, distinct, distinctUntilKeyChanged, map } from 'rxjs/operators';\nimport { GenericTableDataSource } from '../../classes/GenericTableDataSource';\nimport { TableStore } from '../../classes/table-store';\n@Component({\n  selector: 'tb-paginator',\n  template: `\n  <div [ngClass]=\"{'hide' : !(collapseFooter$ | async), 'page-amounts':true}\" *ngIf=\"currentPageData$ | async as pageData\">\n    {{pageData.currentStart}} - {{pageData.currentEnd}} of {{pageData.total}}\n  </div>\n  <mat-paginator [pageSizeOptions]=\"[5, 10, 20, 50, 100, 500]\" showFirstLastButtons (page)=\"paginatorChange()\"\n    [ngClass]=\"{'hide' : (collapseFooter$ | async)}\">\n  </mat-paginator>\n  `,\n  styleUrls: ['./generic-table.component.scss','../../styles/collapser.styles.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class PaginatorComponent implements OnInit, AfterViewInit{\n  @Input() dataSource! : GenericTableDataSource<any>;\n  @Input() tableElRef! : ElementRef\n  @ViewChild(MatPaginator, { static: true }) paginator!: MatPaginator;\n  currentPageData$!: Observable<CurrentPageDetails>;\n  collapseFooter$!:Observable<boolean>;\n  @Input() data$!: Observable<any[]>;\n\n  constructor(private state : TableStore){}\n  ngOnInit(){\n    this.dataSource.paginator = this.paginator;\n    this.ourPageEvent = true;\n    this.state.on(metaDataPageSizeChange(this.state), setPaginatorPageSize(this.paginator));\n    this.state.setPageSize(onPagiantorPageSizeChange(this.paginator));\n    this.collapseFooter$ = this.state.state$.pipe(map(state => state.persistedTableSettings.collapseFooter));\n\n  }\n  ngAfterViewInit(){\n    this.currentPageData$ = merge(\n      this.paginator.page.pipe(map(mapPaginationEventToCurrentPageDetails)),\n      this.data$.pipe(\n        distinctUntilKeyChanged(\"length\"),\n        delayToAllowForProperUpdate,\n        map(updateCurrentPageDetailsOnDataLengthChange(this.paginator)))\n    );\n  }\n\n  paginatorChange() : void {\n    if(!this.ourPageEvent){\n      setTimeout(() => this.tableElRef?.nativeElement?.scrollIntoView(), 0);\n    } else {\n      this.ourPageEvent = false;\n    }\n  }\n  ourPageEvent = false;\n\n}\n\nconst mapPaginationEventToCurrentPageDetails = (pageData: PageEvent):CurrentPageDetails => ({\n  currentStart : (pageData.pageIndex * pageData.pageSize) + 1,\n  currentEnd : Math.min(pageData.length , ((pageData.pageIndex + 1) * pageData.pageSize)),\n  total : pageData.length\n});\n\nconst updateCurrentPageDetailsOnDataLengthChange = (paginator:MatPaginator) => () => ({currentStart:(paginator.pageIndex * paginator.pageSize) + 1,\n  currentEnd: Math.min(paginator.length , ((paginator.pageIndex + 1) * paginator.pageSize)),\n  total:paginator.length})\n\nconst delayToAllowForProperUpdate = delay<any[]>(0,asyncScheduler);\n\ninterface CurrentPageDetails {\n  currentStart:number,\n  currentEnd:number,\n  total:number\n}\n\nconst metaDataPageSizeChange = (state:TableStore) => state.state$.pipe(map(state => state.pageSize),distinct());\n\nconst setPaginatorPageSize = (paginator:MatPaginator) => (pageSize: number) =>\n  paginator._changePageSize(pageSize);\n\nconst onPagiantorPageSizeChange = (paginator: MatPaginator) => paginator.page.pipe(map( e => e.pageSize ), distinct());\n"]}
@@ -1,5 +1,4 @@
1
1
  import { Directive, Input, Component, Output, EventEmitter } from '@angular/core';
2
- import { MatDialogConfig } from '@angular/material/dialog';
3
2
  import { Subject } from 'rxjs';
4
3
  import { switchAll } from 'rxjs/operators';
5
4
  import * as i0 from "@angular/core";
@@ -37,13 +36,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.2", ngImpor
37
36
  template: ``
38
37
  }]
39
38
  }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }]; } });
39
+ const defaultDialogConfig = {
40
+ maxHeight: '95vh'
41
+ };
40
42
  export class DialogDirective {
41
43
  constructor(templateRef, dialog, service) {
42
44
  this.templateRef = templateRef;
43
45
  this.dialog = dialog;
44
46
  this.service = service;
45
47
  this.opDialogClosed = new EventEmitter();
46
- this.opDialogConfig = new MatDialogConfig();
48
+ this._dialogConfig = defaultDialogConfig;
47
49
  this._data = new Subject();
48
50
  this.subscription = this._data.pipe(switchAll()).subscribe(d => {
49
51
  if (d) {
@@ -55,6 +57,12 @@ export class DialogDirective {
55
57
  }
56
58
  });
57
59
  }
60
+ set opDialogConfig(config) {
61
+ this._dialogConfig = { ...defaultDialogConfig, ...config };
62
+ }
63
+ get opDialogConfig() {
64
+ return this._dialogConfig;
65
+ }
58
66
  set state(open_close) {
59
67
  this._data.next(open_close);
60
68
  }
@@ -65,14 +73,14 @@ export class DialogDirective {
65
73
  if (this.nativeElement) {
66
74
  const rect = this.nativeElement.getBoundingClientRect();
67
75
  const position = { left: `${rect.left}px`, top: `${rect.bottom - 50}px` };
68
- this.opDialogConfig = { ...(this.opDialogConfig ?? {}), position };
76
+ this.opDialogConfig = { ...this.opDialogConfig, position };
69
77
  }
70
78
  this.dialogRef = this.dialog.open(DialogWrapper, this.opDialogConfig);
71
79
  this.componentWrapper = this.dialogRef.componentInstance;
72
80
  this.componentWrapper.close = () => this.dialogRef?.close();
73
81
  this.componentWrapper.data = this.opDialogConfig.data;
74
82
  this.componentWrapper.template = this.templateRef;
75
- if (!this.opDialogConfig || !this.opDialogConfig.disableClose) {
83
+ if (!this.opDialogConfig.disableClose) {
76
84
  this.service.addDialogRef(this.dialogRef);
77
85
  }
78
86
  const sub = this.dialogRef.afterClosed().subscribe(() => {
@@ -120,4 +128,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.2", ngImpor
120
128
  type: Input,
121
129
  args: ['opDialogOrigin']
122
130
  }] } });
123
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.js","sourceRoot":"","sources":["../../../../../projects/angular-utilities/src/utilities/directives/dialog.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, TemplateRef, Input, OnDestroy, Component, Output, EventEmitter, ViewContainerRef, Injector, ComponentFactoryResolver } from '@angular/core';\nimport { MatDialog, MatDialogRef, MatDialogConfig } from '@angular/material/dialog';\nimport { Observable, Subscription, Subject } from 'rxjs';\nimport { switchAll } from 'rxjs/operators';\nimport { DialogService } from './dialog-service';\n\n\ninterface DialogViewContext<T> {\n  $implicit?: T,\n  opDialog?: T,\n  close: () => void,\n\n}\n\n@Component({\n  selector: 'app-dialog-content',\n  template: ``\n})\nexport class DialogWrapper<T = any> {\n  viewEmbeded = false;\n  viewContext = {\n    close: () => {},\n  } as DialogViewContext<T>;\n  set template(tmpl: TemplateRef<DialogViewContext<T>>) {\n    if (this.viewEmbeded) {\n      this.vcr.clear();\n    }\n    this.viewEmbeded = true;\n    this.vcr.createEmbeddedView(tmpl, this.viewContext);\n  }\n\n  set close(closeMethod: () => void ) {\n    this.viewContext.close = closeMethod;\n  }\n\n  set data(value: T) {\n    this.viewContext.$implicit = value;\n    this.viewContext.opDialog = value;\n  }\n  constructor(private vcr: ViewContainerRef ) {\n  }\n\n}\n\n\n@Directive(\n  { selector: '[opDialog]' }\n) export class DialogDirective<T> implements OnDestroy {\n  @Output() opDialogClosed: EventEmitter<boolean> = new EventEmitter();\n  @Input() opDialogConfig: MatDialogConfig<T> = new MatDialogConfig<T>();\n  @Input('opDialog') set state(open_close: Observable<T>) {\n    this._data.next(open_close);\n  }\n  @Input('opDialogOrigin') nativeElement? : HTMLElement;\n  dialogRef?: MatDialogRef<any, boolean>;\n  subscription: Subscription;\n  componentWrapper?: DialogWrapper<T>;\n\n  constructor(\n    private templateRef: TemplateRef<DialogViewContext<T>>,\n    private dialog: MatDialog,\n    private service: DialogService) {\n    this.subscription = this._data.pipe(\n      switchAll()\n    ).subscribe(d => {\n      if (d) {\n        this.opDialogConfig.data = d;\n        this.setDialogState(true);\n      } else {\n        this.setDialogState(false);\n      }\n    });\n  }\n\n  _data = new Subject<Observable<T>>();\n\n  close() {\n    this.dialogRef?.close();\n  }\n\n  initDialog() {\n    if(this.nativeElement){\n      const rect = this.nativeElement.getBoundingClientRect();\n      const position = { left: `${rect.left}px`, top: `${rect.bottom - 50}px` };\n      this.opDialogConfig = {...(this.opDialogConfig ?? {} as MatDialogConfig), position};\n    }\n    this.dialogRef = this.dialog.open(DialogWrapper, this.opDialogConfig);\n    this.componentWrapper = this.dialogRef.componentInstance;\n    this.componentWrapper!.close = () => this.dialogRef?.close();\n    this.componentWrapper!.data = this.opDialogConfig.data as T;\n    this.componentWrapper!.template = this.templateRef;\n    if (!this.opDialogConfig || !this.opDialogConfig.disableClose) {\n      this.service.addDialogRef(this.dialogRef);\n    }\n    const sub = this.dialogRef.afterClosed().subscribe(() => {\n      this.opDialogClosed.emit(true);\n      this.service.removeDialogRef(this.dialogRef!);\n      this.dialogRef = undefined;\n      sub.unsubscribe();\n    });\n  }\n\n  setDialogState(open: boolean) {\n    if (open) {\n      if (!this.dialogRef) {\n        this.initDialog();\n      } else {\n        this.componentWrapper!.data = this.opDialogConfig.data as T;\n      }\n    } else if (!open && this.dialogRef) {\n      this.dialogRef.close();\n    }\n  }\n\n  ngOnDestroy() {\n    if (this.subscription) {\n      this.subscription.unsubscribe();\n    }\n  }\n\n  static ngTemplateContextGuard<T>(dir: DialogDirective<T>, ctx: any): ctx is { $implicit: T } {\n    return true;\n  }\n\n}\n"]}
131
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.js","sourceRoot":"","sources":["../../../../../projects/angular-utilities/src/utilities/directives/dialog.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, TemplateRef, Input, OnDestroy, Component, Output, EventEmitter, ViewContainerRef, Injector, ComponentFactoryResolver } from '@angular/core';\nimport { MatDialog, MatDialogRef, MatDialogConfig } from '@angular/material/dialog';\nimport { Observable, Subscription, Subject } from 'rxjs';\nimport { switchAll } from 'rxjs/operators';\nimport { DialogService } from './dialog-service';\n\n\ninterface DialogViewContext<T> {\n  $implicit?: T,\n  opDialog?: T,\n  close: () => void,\n\n}\n\n@Component({\n  selector: 'app-dialog-content',\n  template: ``\n})\nexport class DialogWrapper<T = any> {\n  viewEmbeded = false;\n  viewContext = {\n    close: () => {},\n  } as DialogViewContext<T>;\n  set template(tmpl: TemplateRef<DialogViewContext<T>>) {\n    if (this.viewEmbeded) {\n      this.vcr.clear();\n    }\n    this.viewEmbeded = true;\n    this.vcr.createEmbeddedView(tmpl, this.viewContext);\n  }\n\n  set close(closeMethod: () => void ) {\n    this.viewContext.close = closeMethod;\n  }\n\n  set data(value: T) {\n    this.viewContext.$implicit = value;\n    this.viewContext.opDialog = value;\n  }\n  constructor(private vcr: ViewContainerRef ) {\n  }\n\n}\n\n\nconst defaultDialogConfig: MatDialogConfig = {\n  maxHeight: '95vh'\n}\n\n\n@Directive(\n  { selector: '[opDialog]' }\n) export class DialogDirective<T> implements OnDestroy {\n  @Output() opDialogClosed: EventEmitter<boolean> = new EventEmitter();\n  _dialogConfig: MatDialogConfig<T> = defaultDialogConfig;\n  @Input() set opDialogConfig(config: MatDialogConfig<T>) {\n    this._dialogConfig = {...defaultDialogConfig, ...config};\n  }\n\n  get opDialogConfig() : MatDialogConfig<T> {\n    return this._dialogConfig;\n  }\n  @Input('opDialog') set state(open_close: Observable<T>) {\n    this._data.next(open_close);\n  }\n  @Input('opDialogOrigin') nativeElement? : HTMLElement;\n  dialogRef?: MatDialogRef<any, boolean>;\n  subscription: Subscription;\n  componentWrapper?: DialogWrapper<T>;\n\n  constructor(\n    private templateRef: TemplateRef<DialogViewContext<T>>,\n    private dialog: MatDialog,\n    private service: DialogService) {\n    this.subscription = this._data.pipe(\n      switchAll()\n    ).subscribe(d => {\n      if (d) {\n        this.opDialogConfig.data = d;\n        this.setDialogState(true);\n      } else {\n        this.setDialogState(false);\n      }\n    });\n  }\n\n  _data = new Subject<Observable<T>>();\n\n  close() {\n    this.dialogRef?.close();\n  }\n\n  initDialog() {\n    if(this.nativeElement){\n      const rect = this.nativeElement.getBoundingClientRect();\n      const position = { left: `${rect.left}px`, top: `${rect.bottom - 50}px` };\n      this.opDialogConfig = {...this.opDialogConfig , position};\n    }\n    this.dialogRef = this.dialog.open(DialogWrapper, this.opDialogConfig);\n    this.componentWrapper = this.dialogRef.componentInstance;\n    this.componentWrapper!.close = () => this.dialogRef?.close();\n    this.componentWrapper!.data = this.opDialogConfig.data as T;\n    this.componentWrapper!.template = this.templateRef;\n    if (!this.opDialogConfig.disableClose) {\n      this.service.addDialogRef(this.dialogRef);\n    }\n    const sub = this.dialogRef.afterClosed().subscribe(() => {\n      this.opDialogClosed.emit(true);\n      this.service.removeDialogRef(this.dialogRef!);\n      this.dialogRef = undefined;\n      sub.unsubscribe();\n    });\n  }\n\n  setDialogState(open: boolean) {\n    if (open) {\n      if (!this.dialogRef) {\n        this.initDialog();\n      } else {\n        this.componentWrapper!.data = this.opDialogConfig.data as T;\n      }\n    } else if (!open && this.dialogRef) {\n      this.dialogRef.close();\n    }\n  }\n\n  ngOnDestroy() {\n    if (this.subscription) {\n      this.subscription.unsubscribe();\n    }\n  }\n\n  static ngTemplateContextGuard<T>(dir: DialogDirective<T>, ctx: any): ctx is DialogViewContext<Exclude<T, false|0|''|null|undefined>> {\n    return true;\n  }\n\n}\n"]}
@@ -9,5 +9,6 @@ export * from './directives/mat-toggle-group-directive';
9
9
  export * from './pipes/function.pipe';
10
10
  export * from './pipes/phone.pipe';
11
11
  export * from './pipes/space-case.pipes';
12
+ export * from './directives/dialog-service';
12
13
  export * from './module';
13
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXV0aWxpdGllcy9zcmMvdXRpbGl0aWVzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyxvQ0FBb0MsQ0FBQztBQUNuRCxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyx5Q0FBeUMsQ0FBQztBQUV4RCxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYywwQkFBMEIsQ0FBQztBQUd6QyxjQUFjLFVBQVUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZGlyZWN0aXZlcy9wcmV2ZW50LWVudGVyLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2RpcmVjdGl2ZXMvc3RvcC1wcm9wYWdhdGlvbi5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9kaXJlY3RpdmVzL2F1dG8tZm9jdXMuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vZGlyZWN0aXZlcy9jbGlja1N1YmplY3QnO1xuZXhwb3J0ICogZnJvbSAnLi9kaXJlY3RpdmVzL2NsaWNrRW1pdHRlckRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2RpcmVjdGl2ZXMvZGlhbG9nJztcbmV4cG9ydCAqIGZyb20gJy4vZGlyZWN0aXZlcy9zdHlsZXInO1xuZXhwb3J0ICogZnJvbSAnLi9kaXJlY3RpdmVzL21hdC10b2dnbGUtZ3JvdXAtZGlyZWN0aXZlJztcblxuZXhwb3J0ICogZnJvbSAnLi9waXBlcy9mdW5jdGlvbi5waXBlJztcbmV4cG9ydCAqIGZyb20gJy4vcGlwZXMvcGhvbmUucGlwZSc7XG5leHBvcnQgKiBmcm9tICcuL3BpcGVzL3NwYWNlLWNhc2UucGlwZXMnO1xuXG5cbmV4cG9ydCAqIGZyb20gJy4vbW9kdWxlJztcblxuXG4iXX0=
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXV0aWxpdGllcy9zcmMvdXRpbGl0aWVzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyxvQ0FBb0MsQ0FBQztBQUNuRCxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyx5Q0FBeUMsQ0FBQztBQUV4RCxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYywwQkFBMEIsQ0FBQztBQUV6QyxjQUFjLDZCQUE2QixDQUFDO0FBRzVDLGNBQWMsVUFBVSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9kaXJlY3RpdmVzL3ByZXZlbnQtZW50ZXIuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vZGlyZWN0aXZlcy9zdG9wLXByb3BhZ2F0aW9uLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2RpcmVjdGl2ZXMvYXV0by1mb2N1cy5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9kaXJlY3RpdmVzL2NsaWNrU3ViamVjdCc7XG5leHBvcnQgKiBmcm9tICcuL2RpcmVjdGl2ZXMvY2xpY2tFbWl0dGVyRGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vZGlyZWN0aXZlcy9kaWFsb2cnO1xuZXhwb3J0ICogZnJvbSAnLi9kaXJlY3RpdmVzL3N0eWxlcic7XG5leHBvcnQgKiBmcm9tICcuL2RpcmVjdGl2ZXMvbWF0LXRvZ2dsZS1ncm91cC1kaXJlY3RpdmUnO1xuXG5leHBvcnQgKiBmcm9tICcuL3BpcGVzL2Z1bmN0aW9uLnBpcGUnO1xuZXhwb3J0ICogZnJvbSAnLi9waXBlcy9waG9uZS5waXBlJztcbmV4cG9ydCAqIGZyb20gJy4vcGlwZXMvc3BhY2UtY2FzZS5waXBlcyc7XG5cbmV4cG9ydCAqIGZyb20gJy4vZGlyZWN0aXZlcy9kaWFsb2ctc2VydmljZSc7XG5cblxuZXhwb3J0ICogZnJvbSAnLi9tb2R1bGUnO1xuXG5cbiJdfQ==
@@ -18,4 +18,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.2", ngImpor
18
18
  name: 'func'
19
19
  }]
20
20
  }] });
21
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnVuY3Rpb24ucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdXRpbGl0aWVzL3NyYy91dGlsaXRpZXMvcGlwZXMvZnVuY3Rpb24ucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQzs7QUFLcEQsTUFBTSxPQUFPLFlBQVk7SUFDdkIsU0FBUyxDQUFDLElBQXFDLEVBQUUsR0FBRyxJQUFXO1FBQzdELElBQUcsT0FBTyxJQUFJLEtBQUssUUFBUSxFQUFFO1lBQzNCLE1BQU0sQ0FBQyxRQUFRLEVBQUUsR0FBRyxJQUFJLENBQUMsR0FBRyxJQUFJLENBQUM7WUFDakMsTUFBTSxNQUFNLEdBQUcsUUFBUSxDQUFDLElBQUksQ0FBQyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztZQUM3QyxPQUFPLE1BQU0sQ0FBQyxHQUFHLElBQUksQ0FBQyxDQUFDO1NBQ3hCO1FBQ0MsT0FBTyxJQUFJLENBQUMsR0FBRyxJQUFJLENBQUMsQ0FBQztJQUN6QixDQUFDOzt5R0FSVSxZQUFZO3VHQUFaLFlBQVk7MkZBQVosWUFBWTtrQkFIeEIsSUFBSTttQkFBQztvQkFDSixJQUFJLEVBQUUsTUFBTTtpQkFDYiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQFBpcGUoe1xuICBuYW1lOiAnZnVuYydcbn0pXG5leHBvcnQgY2xhc3MgRnVuY3Rpb25QaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XG4gIHRyYW5zZm9ybShmdW5jOiAoLi4uYXJnczogYW55W10pPT4gYW55IHwgc3RyaW5nLCAuLi5hcmdzOiBhbnlbXSk6IGFueSB7XG4gICAgaWYodHlwZW9mIGZ1bmMgPT09ICdzdHJpbmcnKSB7XG4gICAgICBjb25zdCBbaW5zdGFuY2UsIC4uLnRhaWxdID0gYXJncztcbiAgICAgIGNvbnN0IG1ldGhvZCA9IGluc3RhbmNlW2Z1bmNdLmJpbmQoaW5zdGFuY2UpO1xuICAgICAgcmV0dXJuIG1ldGhvZCguLi50YWlsKTtcbiAgICB9XG4gICAgICByZXR1cm4gZnVuYyguLi5hcmdzKTtcbiAgfVxufVxuIl19
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnVuY3Rpb24ucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FuZ3VsYXItdXRpbGl0aWVzL3NyYy91dGlsaXRpZXMvcGlwZXMvZnVuY3Rpb24ucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQzs7QUFLcEQsTUFBTSxPQUFPLFlBQVk7SUFDdkIsU0FBUyxDQUFDLElBQXlDLEVBQUUsR0FBRyxJQUFXO1FBQ2pFLElBQUcsT0FBTyxJQUFJLEtBQUssUUFBUSxFQUFFO1lBQzNCLE1BQU0sQ0FBQyxRQUFRLEVBQUUsR0FBRyxJQUFJLENBQUMsR0FBRyxJQUFJLENBQUM7WUFDakMsTUFBTSxNQUFNLEdBQUcsUUFBUSxDQUFDLElBQUksQ0FBQyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztZQUM3QyxPQUFPLE1BQU0sQ0FBQyxHQUFHLElBQUksQ0FBQyxDQUFDO1NBQ3hCO1FBQ0MsT0FBTyxJQUFJLENBQUMsR0FBRyxJQUFJLENBQUMsQ0FBQztJQUN6QixDQUFDOzt5R0FSVSxZQUFZO3VHQUFaLFlBQVk7MkZBQVosWUFBWTtrQkFIeEIsSUFBSTttQkFBQztvQkFDSixJQUFJLEVBQUUsTUFBTTtpQkFDYiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQFBpcGUoe1xuICBuYW1lOiAnZnVuYydcbn0pXG5leHBvcnQgY2xhc3MgRnVuY3Rpb25QaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XG4gIHRyYW5zZm9ybShmdW5jOiAoICguLi5hcmdzOiBhbnlbXSk9PiBhbnkgKSB8IHN0cmluZywgLi4uYXJnczogYW55W10pOiBhbnkge1xuICAgIGlmKHR5cGVvZiBmdW5jID09PSAnc3RyaW5nJykge1xuICAgICAgY29uc3QgW2luc3RhbmNlLCAuLi50YWlsXSA9IGFyZ3M7XG4gICAgICBjb25zdCBtZXRob2QgPSBpbnN0YW5jZVtmdW5jXS5iaW5kKGluc3RhbmNlKTtcbiAgICAgIHJldHVybiBtZXRob2QoLi4udGFpbCk7XG4gICAgfVxuICAgICAgcmV0dXJuIGZ1bmMoLi4uYXJncyk7XG4gIH1cbn1cbiJdfQ==
@@ -50,7 +50,7 @@ import { MatNativeDateModule } from '@angular/material/core';
50
50
  import { MatAutocompleteModule } from '@angular/material/autocomplete';
51
51
  import { MatBadgeModule } from '@angular/material/badge';
52
52
  import * as i1$3 from '@angular/material/dialog';
53
- import { MatDialogModule, MatDialogConfig } from '@angular/material/dialog';
53
+ import { MatDialogModule } from '@angular/material/dialog';
54
54
  import { MatExpansionModule } from '@angular/material/expansion';
55
55
  import { MatGridListModule } from '@angular/material/grid-list';
56
56
  import { MatListModule } from '@angular/material/list';
@@ -1573,7 +1573,7 @@ class PaginatorComponent {
1573
1573
  }
1574
1574
  paginatorChange() {
1575
1575
  if (!this.ourPageEvent) {
1576
- //setTimeout(() => this.tableElRef?.nativeElement?.scrollIntoView(), 0);
1576
+ setTimeout(() => { var _a, _b; return (_b = (_a = this.tableElRef) === null || _a === void 0 ? void 0 : _a.nativeElement) === null || _b === void 0 ? void 0 : _b.scrollIntoView(); }, 0);
1577
1577
  }
1578
1578
  else {
1579
1579
  this.ourPageEvent = false;
@@ -2829,13 +2829,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.2", ngImpor
2829
2829
  template: ``
2830
2830
  }]
2831
2831
  }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }]; } });
2832
+ const defaultDialogConfig = {
2833
+ maxHeight: '95vh'
2834
+ };
2832
2835
  class DialogDirective {
2833
2836
  constructor(templateRef, dialog, service) {
2834
2837
  this.templateRef = templateRef;
2835
2838
  this.dialog = dialog;
2836
2839
  this.service = service;
2837
2840
  this.opDialogClosed = new EventEmitter();
2838
- this.opDialogConfig = new MatDialogConfig();
2841
+ this._dialogConfig = defaultDialogConfig;
2839
2842
  this._data = new Subject();
2840
2843
  this.subscription = this._data.pipe(switchAll()).subscribe(d => {
2841
2844
  if (d) {
@@ -2847,6 +2850,12 @@ class DialogDirective {
2847
2850
  }
2848
2851
  });
2849
2852
  }
2853
+ set opDialogConfig(config) {
2854
+ this._dialogConfig = Object.assign(Object.assign({}, defaultDialogConfig), config);
2855
+ }
2856
+ get opDialogConfig() {
2857
+ return this._dialogConfig;
2858
+ }
2850
2859
  set state(open_close) {
2851
2860
  this._data.next(open_close);
2852
2861
  }
@@ -2855,18 +2864,17 @@ class DialogDirective {
2855
2864
  (_a = this.dialogRef) === null || _a === void 0 ? void 0 : _a.close();
2856
2865
  }
2857
2866
  initDialog() {
2858
- var _a;
2859
2867
  if (this.nativeElement) {
2860
2868
  const rect = this.nativeElement.getBoundingClientRect();
2861
2869
  const position = { left: `${rect.left}px`, top: `${rect.bottom - 50}px` };
2862
- this.opDialogConfig = Object.assign(Object.assign({}, ((_a = this.opDialogConfig) !== null && _a !== void 0 ? _a : {})), { position });
2870
+ this.opDialogConfig = Object.assign(Object.assign({}, this.opDialogConfig), { position });
2863
2871
  }
2864
2872
  this.dialogRef = this.dialog.open(DialogWrapper, this.opDialogConfig);
2865
2873
  this.componentWrapper = this.dialogRef.componentInstance;
2866
2874
  this.componentWrapper.close = () => { var _a; return (_a = this.dialogRef) === null || _a === void 0 ? void 0 : _a.close(); };
2867
2875
  this.componentWrapper.data = this.opDialogConfig.data;
2868
2876
  this.componentWrapper.template = this.templateRef;
2869
- if (!this.opDialogConfig || !this.opDialogConfig.disableClose) {
2877
+ if (!this.opDialogConfig.disableClose) {
2870
2878
  this.service.addDialogRef(this.dialogRef);
2871
2879
  }
2872
2880
  const sub = this.dialogRef.afterClosed().subscribe(() => {
@@ -3491,5 +3499,5 @@ const CreateTableBuilder = (reportDef$) => {
3491
3499
  * Generated bundle index. Do not edit.
3492
3500
  */
3493
3501
 
3494
- export { ArrayStyle, AutoFocusDirective, ClickEmitterDirective, ClickSubjectDirective, CreateTableBuilder, CustomCellDirective, DateFilterComponent, DialogDirective, DialogWrapper, FieldType, FilterChipsComponent, FilterComponent, FilterType, FunctionPipe, GenColDisplayerComponent, GenFilterDisplayerComponent, GeneralTableSettings, GenericTableComponent, HttpErrorStateDirective, HttpInProgressStateDirective, HttpNotStartedStateDirective, HttpRequestModule, HttpRequestStateDirective, HttpRequestStateFactory, HttpRequestStateStore, HttpRequestStatus, HttpRequestStrategy, HttpSuccessStateDirective, MatSlideToggleGroupDirective, MatTableObservableDataSource, MultiSortDirective, NotPersisitedTableSettings, PaginatorComponent, PesrsistedTableSettings, PhoneNumberPipe, PreventEnterDirective, ResizeColumnDirective, SortDirection, SpaceCasePipe, StopPropagationDirective, StylerDirective, TableBuilder, TableBuilderModule, TableContainerComponent, TableWrapperFooterSettings, TableWrapperHeaderSettings, Target, UtilitiesModule, chainRequest, combineArrays, createFailure, createSuccess, defaultShareReplay, filterArray, getRequestorBody, getRequestorStatus, httpRequest, httpRequestor, inProgress, isErrorState, isSuccessState, mapArray, mapError, notNull, notStarted, onWait, previousAndCurrent, skipOneWhen, spaceCase, statusIsSuccessOrInProgress, switchOff, tapError, tapSuccess };
3502
+ export { ArrayStyle, AutoFocusDirective, ClickEmitterDirective, ClickSubjectDirective, CreateTableBuilder, CustomCellDirective, DateFilterComponent, DialogDirective, DialogService, DialogWrapper, FieldType, FilterChipsComponent, FilterComponent, FilterType, FunctionPipe, GenColDisplayerComponent, GenFilterDisplayerComponent, GeneralTableSettings, GenericTableComponent, HttpErrorStateDirective, HttpInProgressStateDirective, HttpNotStartedStateDirective, HttpRequestModule, HttpRequestStateDirective, HttpRequestStateFactory, HttpRequestStateStore, HttpRequestStatus, HttpRequestStrategy, HttpSuccessStateDirective, MatSlideToggleGroupDirective, MatTableObservableDataSource, MultiSortDirective, NotPersisitedTableSettings, PaginatorComponent, PesrsistedTableSettings, PhoneNumberPipe, PreventEnterDirective, ResizeColumnDirective, SortDirection, SpaceCasePipe, StopPropagationDirective, StylerDirective, TableBuilder, TableBuilderModule, TableContainerComponent, TableWrapperFooterSettings, TableWrapperHeaderSettings, Target, UtilitiesModule, chainRequest, combineArrays, createFailure, createSuccess, defaultShareReplay, filterArray, getRequestorBody, getRequestorStatus, httpRequest, httpRequestor, inProgress, isErrorState, isSuccessState, mapArray, mapError, notNull, notStarted, onWait, previousAndCurrent, skipOneWhen, spaceCase, statusIsSuccessOrInProgress, switchOff, tapError, tapSuccess };
3495
3503
  //# sourceMappingURL=one-paragon-angular-utilities.mjs.map