@one-paragon/angular-utilities 0.0.12 → 0.0.16

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.
@@ -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(() => {
@@ -100,9 +108,6 @@ export class DialogDirective {
100
108
  this.subscription.unsubscribe();
101
109
  }
102
110
  }
103
- static ngTemplateContextGuard(dir, ctx) {
104
- return true;
105
- }
106
111
  }
107
112
  DialogDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.2", ngImport: i0, type: DialogDirective, deps: [{ token: i0.TemplateRef }, { token: i1.MatDialog }, { token: i2.DialogService }], target: i0.ɵɵFactoryTarget.Directive });
108
113
  DialogDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.0.2", type: DialogDirective, selector: "[opDialog]", inputs: { opDialogConfig: "opDialogConfig", state: ["opDialog", "state"], nativeElement: ["opDialogOrigin", "nativeElement"] }, outputs: { opDialogClosed: "opDialogClosed" }, ngImport: i0 });
@@ -120,4 +125,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.0.2", ngImpor
120
125
  type: Input,
121
126
  args: ['opDialogOrigin']
122
127
  }] } });
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"]}
128
+ //# 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 ngTemplateGuard_opDialog: 'binding';\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"]}
@@ -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';
@@ -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(() => {
@@ -2894,9 +2902,6 @@ class DialogDirective {
2894
2902
  this.subscription.unsubscribe();
2895
2903
  }
2896
2904
  }
2897
- static ngTemplateContextGuard(dir, ctx) {
2898
- return true;
2899
- }
2900
2905
  }
2901
2906
  DialogDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.0.2", ngImport: i0, type: DialogDirective, deps: [{ token: i0.TemplateRef }, { token: i1$3.MatDialog }, { token: DialogService }], target: i0.ɵɵFactoryTarget.Directive });
2902
2907
  DialogDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.0.2", type: DialogDirective, selector: "[opDialog]", inputs: { opDialogConfig: "opDialogConfig", state: ["opDialog", "state"], nativeElement: ["opDialogOrigin", "nativeElement"] }, outputs: { opDialogClosed: "opDialogClosed" }, ngImport: i0 });