@abp/ng.theme.shared 8.1.0-rc.3 → 8.1.0-rc.4
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/esm2022/lib/components/http-error-wrapper/http-error-wrapper.component.mjs +35 -22
- package/esm2022/lib/components/internet-connection-status/internet-connection-status.component.mjs +28 -14
- package/esm2022/lib/constants/default-errors.mjs +13 -1
- package/esm2022/lib/constants/index.mjs +5 -0
- package/esm2022/lib/constants/scripts.mjs +2 -0
- package/esm2022/lib/directives/ngx-datatable-list.directive.mjs +53 -38
- package/esm2022/lib/services/create-error-component.service.mjs +7 -8
- package/esm2022/public-api.mjs +2 -3
- package/fesm2022/abp-ng.theme.shared.mjs +205 -146
- package/fesm2022/abp-ng.theme.shared.mjs.map +1 -1
- package/lib/components/http-error-wrapper/http-error-wrapper.component.d.ts +8 -7
- package/lib/constants/default-errors.d.ts +12 -0
- package/lib/constants/index.d.ts +4 -0
- package/lib/constants/scripts.d.ts +2 -0
- package/lib/directives/ngx-datatable-list.directive.d.ts +18 -17
- package/lib/services/create-error-component.service.d.ts +2 -2
- package/package.json +2 -2
- package/public-api.d.ts +1 -2
|
@@ -1,20 +1,17 @@
|
|
|
1
|
-
import { Component, inject, ElementRef, ViewChild, } from '@angular/core';
|
|
1
|
+
import { Component, inject, ElementRef, ViewChild, createComponent, DestroyRef, } from '@angular/core';
|
|
2
|
+
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
2
3
|
import { DOCUMENT } from '@angular/common';
|
|
4
|
+
import { Router } from '@angular/router';
|
|
3
5
|
import { fromEvent } from 'rxjs';
|
|
4
6
|
import { debounceTime, filter } from 'rxjs/operators';
|
|
5
|
-
import { SubscriptionService } from '@abp/ng.core';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
import * as i1 from "@abp/ng.core";
|
|
8
|
-
import * as i2 from "@angular/common";
|
|
9
|
-
import * as i3 from "@angular/router";
|
|
10
9
|
export class HttpErrorWrapperComponent {
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
}
|
|
14
|
-
constructor(subscription) {
|
|
15
|
-
this.subscription = subscription;
|
|
10
|
+
constructor() {
|
|
11
|
+
this.destroyRef = inject(DestroyRef);
|
|
16
12
|
this.document = inject(DOCUMENT);
|
|
17
13
|
this.window = this.document.defaultView;
|
|
14
|
+
this.router = inject(Router);
|
|
18
15
|
this.status = 0;
|
|
19
16
|
this.title = 'Oops!';
|
|
20
17
|
this.details = 'Sorry, an error has occured.';
|
|
@@ -22,16 +19,27 @@ export class HttpErrorWrapperComponent {
|
|
|
22
19
|
this.hideCloseIcon = false;
|
|
23
20
|
this.isHomeShow = true;
|
|
24
21
|
}
|
|
22
|
+
get statusText() {
|
|
23
|
+
return this.status ? `[${this.status}]` : '';
|
|
24
|
+
}
|
|
25
25
|
ngOnInit() {
|
|
26
|
-
this.
|
|
27
|
-
|
|
26
|
+
const computedStyle = this.window.getComputedStyle(this.document.body);
|
|
27
|
+
const backgroundColor = computedStyle?.getPropertyValue('background-color');
|
|
28
|
+
this.backgroundColor = backgroundColor || '#fff';
|
|
28
29
|
}
|
|
29
30
|
ngAfterViewInit() {
|
|
30
31
|
if (this.customComponent) {
|
|
31
|
-
const customComponentRef = this.
|
|
32
|
-
|
|
33
|
-
|
|
32
|
+
const customComponentRef = createComponent(this.customComponent, {
|
|
33
|
+
environmentInjector: this.environmentInjector,
|
|
34
|
+
});
|
|
34
35
|
customComponentRef.instance.errorStatus = this.status;
|
|
36
|
+
//In our custom "HttpErrorComponent", we have a "status" property.
|
|
37
|
+
//We used to have "errorStatus", but it wasn't signal type. "status" variable is signal type.
|
|
38
|
+
//I've checked because of backward compatibility. Developers might have their own custom HttpErrorComponent.
|
|
39
|
+
//We need to deprecated and remove "errorStatus" in the future.
|
|
40
|
+
if (customComponentRef.instance.status) {
|
|
41
|
+
customComponentRef.instance.status.set(this.status);
|
|
42
|
+
}
|
|
35
43
|
customComponentRef.instance.destroy$ = this.destroy$;
|
|
36
44
|
this.appRef.attachView(customComponentRef.hostView);
|
|
37
45
|
if (this.containerRef) {
|
|
@@ -39,24 +47,29 @@ export class HttpErrorWrapperComponent {
|
|
|
39
47
|
}
|
|
40
48
|
customComponentRef.changeDetectorRef.detectChanges();
|
|
41
49
|
}
|
|
42
|
-
|
|
43
|
-
|
|
50
|
+
fromEvent(this.document, 'keyup')
|
|
51
|
+
.pipe(debounceTime(150), filter((key) => key && key.key === 'Escape'), takeUntilDestroyed(this.destroyRef))
|
|
52
|
+
.subscribe(() => this.destroy());
|
|
44
53
|
}
|
|
45
|
-
|
|
54
|
+
goHome() {
|
|
55
|
+
this.router.navigateByUrl('/', { onSameUrlNavigation: 'reload' });
|
|
46
56
|
this.destroy();
|
|
47
57
|
}
|
|
48
58
|
destroy() {
|
|
49
59
|
this.destroy$.next();
|
|
50
60
|
this.destroy$.complete();
|
|
51
61
|
}
|
|
52
|
-
|
|
53
|
-
|
|
62
|
+
ngOnDestroy() {
|
|
63
|
+
this.destroy();
|
|
64
|
+
}
|
|
65
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: HttpErrorWrapperComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
66
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.3", type: HttpErrorWrapperComponent, selector: "abp-http-error-wrapper", viewQueries: [{ propertyName: "containerRef", first: true, predicate: ["container"], descendants: true }], ngImport: i0, template: "<div\r\n #container\r\n id=\"abp-http-error-container\"\r\n class=\"error\"\r\n [style.backgroundColor]=\"backgroundColor\"\r\n>\r\n @if (!hideCloseIcon) {\r\n <button id=\"abp-close-button\" type=\"button\" class=\"btn-close me-2\" (click)=\"destroy()\"></button>\r\n }\r\n\r\n @if (!customComponent) {\r\n <div class=\"row centered\">\r\n <div class=\"col-md-12\">\r\n <div class=\"error-template\">\r\n <h1>{{ statusText }} {{ title | abpLocalization }}</h1>\r\n <div class=\"error-details\">\r\n {{ details | abpLocalization }}\r\n </div>\r\n <div class=\"error-actions\">\r\n @if (isHomeShow) {\r\n <a (click)=\"goHome()\" class=\"btn btn-primary btn-md mt-2\"\r\n ><span class=\"glyphicon glyphicon-home\"></span>\r\n {{ { key: '::Menu:Home', defaultValue: 'Home' } | abpLocalization }}\r\n </a>\r\n }\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n }\r\n</div>\r\n", styles: [".error{position:fixed;top:0;width:100vw;height:100vh;z-index:999999}.centered{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}\n"], dependencies: [{ kind: "pipe", type: i1.LocalizationPipe, name: "abpLocalization" }] }); }
|
|
54
67
|
}
|
|
55
68
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: HttpErrorWrapperComponent, decorators: [{
|
|
56
69
|
type: Component,
|
|
57
|
-
args: [{ selector: 'abp-http-error-wrapper',
|
|
58
|
-
}],
|
|
70
|
+
args: [{ selector: 'abp-http-error-wrapper', template: "<div\r\n #container\r\n id=\"abp-http-error-container\"\r\n class=\"error\"\r\n [style.backgroundColor]=\"backgroundColor\"\r\n>\r\n @if (!hideCloseIcon) {\r\n <button id=\"abp-close-button\" type=\"button\" class=\"btn-close me-2\" (click)=\"destroy()\"></button>\r\n }\r\n\r\n @if (!customComponent) {\r\n <div class=\"row centered\">\r\n <div class=\"col-md-12\">\r\n <div class=\"error-template\">\r\n <h1>{{ statusText }} {{ title | abpLocalization }}</h1>\r\n <div class=\"error-details\">\r\n {{ details | abpLocalization }}\r\n </div>\r\n <div class=\"error-actions\">\r\n @if (isHomeShow) {\r\n <a (click)=\"goHome()\" class=\"btn btn-primary btn-md mt-2\"\r\n ><span class=\"glyphicon glyphicon-home\"></span>\r\n {{ { key: '::Menu:Home', defaultValue: 'Home' } | abpLocalization }}\r\n </a>\r\n }\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n }\r\n</div>\r\n", styles: [".error{position:fixed;top:0;width:100vw;height:100vh;z-index:999999}.centered{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}\n"] }]
|
|
71
|
+
}], propDecorators: { containerRef: [{
|
|
59
72
|
type: ViewChild,
|
|
60
73
|
args: ['container', { static: false }]
|
|
61
74
|
}] } });
|
|
62
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"http-error-wrapper.component.js","sourceRoot":"","sources":["../../../../../../../packages/theme-shared/src/lib/components/http-error-wrapper/http-error-wrapper.component.ts","../../../../../../../packages/theme-shared/src/lib/components/http-error-wrapper/http-error-wrapper.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ApplicationRef,\r\n  Component,\r\n  Injector,\r\n  inject,\r\n  OnInit,\r\n  ComponentFactoryResolver,\r\n  ElementRef,\r\n  EmbeddedViewRef,\r\n  Type,\r\n  ViewChild,\r\n  AfterViewInit,\r\n  OnDestroy,\r\n} from '@angular/core';\r\nimport { DOCUMENT } from '@angular/common';\r\nimport { fromEvent, Subject } from 'rxjs';\r\nimport { debounceTime, filter } from 'rxjs/operators';\r\nimport { LocalizationParam, SubscriptionService } from '@abp/ng.core';\r\nimport { ErrorScreenErrorCodes } from '../../models';\r\n\r\n@Component({\r\n  selector: 'abp-http-error-wrapper',\r\n  templateUrl: './http-error-wrapper.component.html',\r\n  styleUrls: ['http-error-wrapper.component.scss'],\r\n  providers: [SubscriptionService],\r\n})\r\nexport class HttpErrorWrapperComponent implements OnInit, AfterViewInit, OnDestroy {\r\n  protected readonly document = inject(DOCUMENT);\r\n  protected readonly window = this.document.defaultView;\r\n\r\n  appRef!: ApplicationRef;\r\n\r\n  cfRes!: ComponentFactoryResolver;\r\n\r\n  injector!: Injector;\r\n\r\n  status: ErrorScreenErrorCodes = 0;\r\n\r\n  title: LocalizationParam = 'Oops!';\r\n\r\n  details: LocalizationParam = 'Sorry, an error has occured.';\r\n\r\n  customComponent: Type<any> | undefined = undefined;\r\n\r\n  destroy$!: Subject<void>;\r\n\r\n  hideCloseIcon = false;\r\n\r\n  backgroundColor!: string;\r\n\r\n  isHomeShow = true;\r\n\r\n  @ViewChild('container', { static: false })\r\n  containerRef?: ElementRef<HTMLDivElement>;\r\n\r\n  get statusText(): string {\r\n    return this.status ? `[${this.status}]` : '';\r\n  }\r\n\r\n  constructor(private subscription: SubscriptionService) {}\r\n\r\n  ngOnInit(): void {\r\n    this.backgroundColor =\r\n      this.window.getComputedStyle(this.document.body)?.getPropertyValue('background-color') || '#fff';\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    if (this.customComponent) {\r\n      const customComponentRef = this.cfRes\r\n        .resolveComponentFactory(this.customComponent)\r\n        .create(this.injector);\r\n      customComponentRef.instance.errorStatus = this.status;\r\n      customComponentRef.instance.destroy$ = this.destroy$;\r\n      this.appRef.attachView(customComponentRef.hostView);\r\n      if (this.containerRef) {\r\n        this.containerRef.nativeElement.appendChild(\r\n          (customComponentRef.hostView as EmbeddedViewRef<any>).rootNodes[0],\r\n        );\r\n      }\r\n      customComponentRef.changeDetectorRef.detectChanges();\r\n    }\r\n\r\n    const keyup$ = fromEvent<KeyboardEvent>(this.document, 'keyup').pipe(\r\n      debounceTime(150),\r\n      filter((key: KeyboardEvent) => key && key.key === 'Escape'),\r\n    );\r\n    this.subscription.addOne(keyup$, () => this.destroy());\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.destroy();\r\n  }\r\n\r\n  destroy(): void {\r\n    this.destroy$.next();\r\n    this.destroy$.complete();\r\n  }\r\n}\r\n","<div\r\n  #container\r\n  id=\"abp-http-error-container\"\r\n  class=\"error\"\r\n  [style.backgroundColor]=\"backgroundColor\"\r\n>\r\n  <button\r\n    *ngIf=\"!hideCloseIcon\"\r\n    id=\"abp-close-button\"\r\n    type=\"button\"\r\n    class=\"btn-close me-2\"\r\n    (click)=\"destroy()\"\r\n  ></button>\r\n\r\n  <div *ngIf=\"!customComponent\" class=\"row centered\">\r\n    <div class=\"col-md-12\">\r\n      <div class=\"error-template\">\r\n        <h1>{{ statusText }} {{ title | abpLocalization }}</h1>\r\n        <div class=\"error-details\">\r\n          {{ details | abpLocalization }}\r\n        </div>\r\n        <div class=\"error-actions\">\r\n          <a\r\n            *ngIf=\"isHomeShow\"\r\n            (click)=\"destroy()\"\r\n            routerLink=\"/\"\r\n            class=\"btn btn-primary btn-md mt-2\"\r\n            ><span class=\"glyphicon glyphicon-home\"></span>\r\n            {{ { key: '::Menu:Home', defaultValue: 'Home' } | abpLocalization }}\r\n          </a>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"http-error-wrapper.component.js","sourceRoot":"","sources":["../../../../../../../packages/theme-shared/src/lib/components/http-error-wrapper/http-error-wrapper.component.ts","../../../../../../../packages/theme-shared/src/lib/components/http-error-wrapper/http-error-wrapper.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ApplicationRef,\r\n  Component,\r\n  inject,\r\n  OnInit,\r\n  ElementRef,\r\n  EmbeddedViewRef,\r\n  Type,\r\n  ViewChild,\r\n  AfterViewInit,\r\n  OnDestroy,\r\n  createComponent,\r\n  EnvironmentInjector,\r\n  DestroyRef,\r\n} from '@angular/core';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\nimport { DOCUMENT } from '@angular/common';\r\nimport { Router } from '@angular/router';\r\nimport { fromEvent, Subject } from 'rxjs';\r\nimport { debounceTime, filter } from 'rxjs/operators';\r\nimport { LocalizationParam } from '@abp/ng.core';\r\nimport { ErrorScreenErrorCodes } from '../../models';\r\n\r\n@Component({\r\n  selector: 'abp-http-error-wrapper',\r\n  templateUrl: './http-error-wrapper.component.html',\r\n  styleUrls: ['http-error-wrapper.component.scss'],\r\n})\r\nexport class HttpErrorWrapperComponent implements OnInit, AfterViewInit, OnDestroy {\r\n  protected readonly destroyRef = inject(DestroyRef);\r\n  protected readonly document = inject(DOCUMENT);\r\n  protected readonly window = this.document.defaultView;\r\n  protected readonly router = inject(Router);\r\n\r\n  appRef!: ApplicationRef;\r\n\r\n  environmentInjector!: EnvironmentInjector;\r\n\r\n  status: ErrorScreenErrorCodes = 0;\r\n\r\n  title: LocalizationParam = 'Oops!';\r\n\r\n  details: LocalizationParam = 'Sorry, an error has occured.';\r\n\r\n  customComponent: Type<any> | undefined = undefined;\r\n\r\n  destroy$!: Subject<void>;\r\n\r\n  hideCloseIcon = false;\r\n\r\n  backgroundColor!: string;\r\n\r\n  isHomeShow = true;\r\n\r\n  @ViewChild('container', { static: false })\r\n  containerRef?: ElementRef<HTMLDivElement>;\r\n\r\n  get statusText(): string {\r\n    return this.status ? `[${this.status}]` : '';\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    const computedStyle = this.window.getComputedStyle(this.document.body);\r\n    const backgroundColor = computedStyle?.getPropertyValue('background-color');\r\n    this.backgroundColor = backgroundColor || '#fff';\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    if (this.customComponent) {\r\n      const customComponentRef = createComponent(this.customComponent, {\r\n        environmentInjector: this.environmentInjector,\r\n      });\r\n\r\n      customComponentRef.instance.errorStatus = this.status;\r\n      \r\n      //In our custom \"HttpErrorComponent\", we have a \"status\" property.\r\n      //We used to have \"errorStatus\", but it wasn't signal type. \"status\" variable is signal type.\r\n      //I've checked because of backward compatibility. Developers might have their own custom HttpErrorComponent.\r\n      //We need to deprecated and remove \"errorStatus\" in the future.\r\n      if (customComponentRef.instance.status) {\r\n        customComponentRef.instance.status.set(this.status);\r\n      }\r\n      \r\n      customComponentRef.instance.destroy$ = this.destroy$;\r\n\r\n      this.appRef.attachView(customComponentRef.hostView);\r\n\r\n      if (this.containerRef) {\r\n        this.containerRef.nativeElement.appendChild(\r\n          (customComponentRef.hostView as EmbeddedViewRef<any>).rootNodes[0],\r\n        );\r\n      }\r\n      customComponentRef.changeDetectorRef.detectChanges();\r\n    }\r\n\r\n    fromEvent<KeyboardEvent>(this.document, 'keyup')\r\n      .pipe(\r\n        debounceTime(150),\r\n        filter((key: KeyboardEvent) => key && key.key === 'Escape'),\r\n        takeUntilDestroyed(this.destroyRef),\r\n      )\r\n      .subscribe(() => this.destroy());\r\n  }\r\n\r\n  goHome(): void {\r\n    this.router.navigateByUrl('/', { onSameUrlNavigation: 'reload' });\r\n    this.destroy();\r\n  }\r\n\r\n  destroy(): void {\r\n    this.destroy$.next();\r\n    this.destroy$.complete();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.destroy();\r\n  }\r\n}\r\n","<div\r\n  #container\r\n  id=\"abp-http-error-container\"\r\n  class=\"error\"\r\n  [style.backgroundColor]=\"backgroundColor\"\r\n>\r\n  @if (!hideCloseIcon) {\r\n    <button id=\"abp-close-button\" type=\"button\" class=\"btn-close me-2\" (click)=\"destroy()\"></button>\r\n  }\r\n\r\n  @if (!customComponent) {\r\n    <div class=\"row centered\">\r\n      <div class=\"col-md-12\">\r\n        <div class=\"error-template\">\r\n          <h1>{{ statusText }} {{ title | abpLocalization }}</h1>\r\n          <div class=\"error-details\">\r\n            {{ details | abpLocalization }}\r\n          </div>\r\n          <div class=\"error-actions\">\r\n            @if (isHomeShow) {\r\n              <a (click)=\"goHome()\" class=\"btn btn-primary btn-md mt-2\"\r\n                ><span class=\"glyphicon glyphicon-home\"></span>\r\n                {{ { key: '::Menu:Home', defaultValue: 'Home' } | abpLocalization }}\r\n              </a>\r\n            }\r\n          </div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  }\r\n</div>\r\n"]}
|
package/esm2022/lib/components/internet-connection-status/internet-connection-status.component.mjs
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Component, inject } from '@angular/core';
|
|
2
|
-
import { NgIf } from '@angular/common';
|
|
3
2
|
import { InternetConnectionService, LocalizationModule } from '@abp/ng.core';
|
|
3
|
+
import { NgbTooltip } from '@ng-bootstrap/ng-bootstrap';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
import * as i1 from "@abp/ng.core";
|
|
6
6
|
export class InternetConnectionStatusComponent {
|
|
@@ -9,20 +9,34 @@ export class InternetConnectionStatusComponent {
|
|
|
9
9
|
this.isOnline = this.internetConnectionService.networkStatus;
|
|
10
10
|
}
|
|
11
11
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: InternetConnectionStatusComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
12
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
13
|
-
|
|
14
|
-
<
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
12
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.1.3", type: InternetConnectionStatusComponent, isStandalone: true, selector: "abp-internet-status", ngImport: i0, template: `
|
|
13
|
+
@if (!isOnline()) {
|
|
14
|
+
<div class="status-icon">
|
|
15
|
+
<i
|
|
16
|
+
ngbTooltip="{{ 'AbpUi::InternetConnectionInfo' | abpLocalization }}"
|
|
17
|
+
container="body"
|
|
18
|
+
placement="left-top"
|
|
19
|
+
class="fa fa-wifi text-blinking blink"
|
|
20
|
+
>
|
|
21
|
+
</i>
|
|
22
|
+
</div>
|
|
23
|
+
}
|
|
24
|
+
`, isInline: true, styles: [".blink{animation:blinker .9s cubic-bezier(.5,0,1,1) infinite alternate}@keyframes blinker{0%{color:#c1c1c1}70%{color:#fa2379}to{color:#fa2379}}.text-blinking{font-size:30px}.status-icon{position:fixed;z-index:999999;top:50%;left:50%;width:30px;text-align:center;margin-left:-15px;margin-top:-15px;translate:transform(-50%,-50%)}\n"], dependencies: [{ kind: "ngmodule", type: LocalizationModule }, { kind: "pipe", type: i1.LocalizationPipe, name: "abpLocalization" }, { kind: "directive", type: NgbTooltip, selector: "[ngbTooltip]", inputs: ["animation", "autoClose", "placement", "popperOptions", "triggers", "positionTarget", "container", "disableTooltip", "tooltipClass", "tooltipContext", "openDelay", "closeDelay", "ngbTooltip"], outputs: ["shown", "hidden"], exportAs: ["ngbTooltip"] }] }); }
|
|
18
25
|
}
|
|
19
26
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: InternetConnectionStatusComponent, decorators: [{
|
|
20
27
|
type: Component,
|
|
21
|
-
args: [{ selector: 'abp-internet-status', standalone: true, imports: [
|
|
22
|
-
|
|
23
|
-
<
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
28
|
+
args: [{ selector: 'abp-internet-status', standalone: true, imports: [LocalizationModule, NgbTooltip], template: `
|
|
29
|
+
@if (!isOnline()) {
|
|
30
|
+
<div class="status-icon">
|
|
31
|
+
<i
|
|
32
|
+
ngbTooltip="{{ 'AbpUi::InternetConnectionInfo' | abpLocalization }}"
|
|
33
|
+
container="body"
|
|
34
|
+
placement="left-top"
|
|
35
|
+
class="fa fa-wifi text-blinking blink"
|
|
36
|
+
>
|
|
37
|
+
</i>
|
|
38
|
+
</div>
|
|
39
|
+
}
|
|
40
|
+
`, styles: [".blink{animation:blinker .9s cubic-bezier(.5,0,1,1) infinite alternate}@keyframes blinker{0%{color:#c1c1c1}70%{color:#fa2379}to{color:#fa2379}}.text-blinking{font-size:30px}.status-icon{position:fixed;z-index:999999;top:50%;left:50%;width:30px;text-align:center;margin-left:-15px;margin-top:-15px;translate:transform(-50%,-50%)}\n"] }]
|
|
27
41
|
}] });
|
|
28
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
42
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJuZXQtY29ubmVjdGlvbi1zdGF0dXMuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvdGhlbWUtc2hhcmVkL3NyYy9saWIvY29tcG9uZW50cy9pbnRlcm5ldC1jb25uZWN0aW9uLXN0YXR1cy9pbnRlcm5ldC1jb25uZWN0aW9uLXN0YXR1cy5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbEQsT0FBTyxFQUFFLHlCQUF5QixFQUFFLGtCQUFrQixFQUFFLE1BQU0sY0FBYyxDQUFDO0FBQzdFLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQzs7O0FBc0R4RCxNQUFNLE9BQU8saUNBQWlDO0lBcEQ5QztRQXFERSw4QkFBeUIsR0FBRyxNQUFNLENBQUMseUJBQXlCLENBQUMsQ0FBQztRQUM5RCxhQUFRLEdBQUcsSUFBSSxDQUFDLHlCQUF5QixDQUFDLGFBQWEsQ0FBQztLQUN6RDs4R0FIWSxpQ0FBaUM7a0dBQWpDLGlDQUFpQywrRUFoRGxDOzs7Ozs7Ozs7Ozs7R0FZVCxtWkFiUyxrQkFBa0IscUdBQUUsVUFBVTs7MkZBaUQ3QixpQ0FBaUM7a0JBcEQ3QyxTQUFTOytCQUNFLHFCQUFxQixjQUNuQixJQUFJLFdBQ1AsQ0FBQyxrQkFBa0IsRUFBRSxVQUFVLENBQUMsWUFDL0I7Ozs7Ozs7Ozs7OztHQVlUIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgSW50ZXJuZXRDb25uZWN0aW9uU2VydmljZSwgTG9jYWxpemF0aW9uTW9kdWxlIH0gZnJvbSAnQGFicC9uZy5jb3JlJztcclxuaW1wb3J0IHsgTmdiVG9vbHRpcCB9IGZyb20gJ0BuZy1ib290c3RyYXAvbmctYm9vdHN0cmFwJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnYWJwLWludGVybmV0LXN0YXR1cycsXHJcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcclxuICBpbXBvcnRzOiBbTG9jYWxpemF0aW9uTW9kdWxlLCBOZ2JUb29sdGlwXSxcclxuICB0ZW1wbGF0ZTogYFxyXG4gICAgQGlmICghaXNPbmxpbmUoKSkge1xyXG4gICAgICA8ZGl2IGNsYXNzPVwic3RhdHVzLWljb25cIj5cclxuICAgICAgICA8aVxyXG4gICAgICAgICAgbmdiVG9vbHRpcD1cInt7ICdBYnBVaTo6SW50ZXJuZXRDb25uZWN0aW9uSW5mbycgfCBhYnBMb2NhbGl6YXRpb24gfX1cIlxyXG4gICAgICAgICAgY29udGFpbmVyPVwiYm9keVwiXHJcbiAgICAgICAgICBwbGFjZW1lbnQ9XCJsZWZ0LXRvcFwiIFxyXG4gICAgICAgICAgY2xhc3M9XCJmYSBmYS13aWZpIHRleHQtYmxpbmtpbmcgYmxpbmtcIlxyXG4gICAgICAgID5cclxuICAgICAgICA8L2k+XHJcbiAgICAgIDwvZGl2PlxyXG4gICAgfVxyXG4gIGAsXHJcbiAgc3R5bGVzOiBbXHJcbiAgICBgXHJcbiAgICAgIC5ibGluayB7XHJcbiAgICAgICAgYW5pbWF0aW9uOiBibGlua2VyIDAuOXMgY3ViaWMtYmV6aWVyKDAuNSwgMCwgMSwgMSkgaW5maW5pdGUgYWx0ZXJuYXRlO1xyXG4gICAgICB9XHJcbiAgICAgIEBrZXlmcmFtZXMgYmxpbmtlciB7XHJcbiAgICAgICAgMCUge1xyXG4gICAgICAgICAgY29sb3I6ICNjMWMxYzE7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIDcwJSB7XHJcbiAgICAgICAgICBjb2xvcjogI2ZhMjM3OTtcclxuICAgICAgICB9XHJcbiAgICAgICAgMTAwJSB7XHJcbiAgICAgICAgICBjb2xvcjogI2ZhMjM3OTtcclxuICAgICAgICB9XHJcbiAgICAgIH1cclxuXHJcbiAgICAgIC50ZXh0LWJsaW5raW5nIHtcclxuICAgICAgICBmb250LXNpemU6IDMwcHg7XHJcbiAgICAgIH1cclxuXHJcbiAgICAgIC5zdGF0dXMtaWNvbiB7XHJcbiAgICAgICAgcG9zaXRpb246IGZpeGVkO1xyXG4gICAgICAgIHotaW5kZXg6IDk5OTk5OTtcclxuICAgICAgICB0b3A6IDUwJTtcclxuICAgICAgICBsZWZ0OiA1MCU7XHJcbiAgICAgICAgd2lkdGg6IDMwcHg7XHJcbiAgICAgICAgdGV4dC1hbGlnbjogY2VudGVyO1xyXG4gICAgICAgIG1hcmdpbi1sZWZ0OiAtMTVweDtcclxuICAgICAgICBtYXJnaW4tdG9wOiAtMTVweDtcclxuICAgICAgICB0cmFuc2xhdGU6IHRyYW5zZm9ybSgtNTAlLCAtNTAlKTtcclxuICAgICAgfVxyXG4gICAgYCxcclxuICBdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgSW50ZXJuZXRDb25uZWN0aW9uU3RhdHVzQ29tcG9uZW50IHtcclxuICBpbnRlcm5ldENvbm5lY3Rpb25TZXJ2aWNlID0gaW5qZWN0KEludGVybmV0Q29ubmVjdGlvblNlcnZpY2UpO1xyXG4gIGlzT25saW5lID0gdGhpcy5pbnRlcm5ldENvbm5lY3Rpb25TZXJ2aWNlLm5ldHdvcmtTdGF0dXM7XHJcbn1cclxuIl19
|
|
@@ -49,4 +49,16 @@ export const CUSTOM_HTTP_ERROR_HANDLER_PRIORITY = Object.freeze({
|
|
|
49
49
|
high: 9,
|
|
50
50
|
veryHigh: 99,
|
|
51
51
|
});
|
|
52
|
-
|
|
52
|
+
export const HTTP_ERROR_STATUS = {
|
|
53
|
+
'401': 'AbpUi::401Message',
|
|
54
|
+
'403': 'AbpUi::403Message',
|
|
55
|
+
'404': 'AbpUi::404Message',
|
|
56
|
+
'500': 'AbpUi::500Message',
|
|
57
|
+
};
|
|
58
|
+
export const HTTP_ERROR_DETAIL = {
|
|
59
|
+
'401': 'AbpUi::DefaultErrorMessage401Detail',
|
|
60
|
+
'403': 'AbpUi::DefaultErrorMessage403Detail',
|
|
61
|
+
'404': 'AbpUi::DefaultErrorMessage404Detail',
|
|
62
|
+
'500': 'AbpUi::DefaultErrorMessage',
|
|
63
|
+
};
|
|
64
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVmYXVsdC1lcnJvcnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy90aGVtZS1zaGFyZWQvc3JjL2xpYi9jb25zdGFudHMvZGVmYXVsdC1lcnJvcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFDLE1BQU0sc0JBQXNCLEdBQUc7SUFDcEMsWUFBWSxFQUFFO1FBQ1osS0FBSyxFQUFFLHdCQUF3QjtRQUMvQixPQUFPLEVBQUUsa0NBQWtDO0tBQzVDO0lBQ0QsZUFBZSxFQUFFO1FBQ2YsS0FBSyxFQUFFLDRCQUE0QjtRQUNuQyxPQUFPLEVBQUUsMkVBQTJFO0tBQ3JGO0lBQ0QsZUFBZSxFQUFFO1FBQ2YsS0FBSyxFQUFFLHlCQUF5QjtRQUNoQyxPQUFPLEVBQUUsZ0RBQWdEO0tBQzFEO0lBQ0QsZUFBZSxFQUFFO1FBQ2YsS0FBSyxFQUFFLHFCQUFxQjtRQUM1QixPQUFPLEVBQUUsdURBQXVEO0tBQ2pFO0lBQ0QsZUFBZSxFQUFFO1FBQ2YsS0FBSyxFQUFFLHVCQUF1QjtRQUM5QixPQUFPLEVBQUUsa0NBQWtDO0tBQzVDO0NBQ0YsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLDJCQUEyQixHQUFHO0lBQ3pDLFlBQVksRUFBRTtRQUNaLEtBQUssRUFBRSw0QkFBNEI7UUFDbkMsT0FBTyxFQUFFLGtDQUFrQztLQUM1QztJQUNELGVBQWUsRUFBRTtRQUNmLEtBQUssRUFBRSwrQkFBK0I7UUFDdEMsT0FBTyxFQUFFLHFDQUFxQztLQUMvQztJQUNELGVBQWUsRUFBRTtRQUNmLEtBQUssRUFBRSwrQkFBK0I7UUFDdEMsT0FBTyxFQUFFLHFDQUFxQztLQUMvQztJQUNELGVBQWUsRUFBRTtRQUNmLEtBQUssRUFBRSwrQkFBK0I7UUFDdEMsT0FBTyxFQUFFLHFDQUFxQztLQUMvQztJQUNELGVBQWUsRUFBRTtRQUNmLEtBQUssRUFBRSxtQkFBbUI7UUFDMUIsT0FBTyxFQUFFLDRCQUE0QjtLQUN0QztDQUNGLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxrQ0FBa0MsR0FBRyxNQUFNLENBQUMsTUFBTSxDQUFDO0lBQzlELE9BQU8sRUFBRSxDQUFDLEVBQUU7SUFDWixHQUFHLEVBQUUsQ0FBQyxDQUFDO0lBQ1AsTUFBTSxFQUFFLENBQUM7SUFDVCxJQUFJLEVBQUUsQ0FBQztJQUNQLFFBQVEsRUFBRSxFQUFFO0NBQ2IsQ0FBQyxDQUFDO0FBRUgsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUc7SUFDL0IsS0FBSyxFQUFFLG1CQUFtQjtJQUMxQixLQUFLLEVBQUUsbUJBQW1CO0lBQzFCLEtBQUssRUFBRSxtQkFBbUI7SUFDMUIsS0FBSyxFQUFFLG1CQUFtQjtDQUMzQixDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUc7SUFDL0IsS0FBSyxFQUFFLHFDQUFxQztJQUM1QyxLQUFLLEVBQUUscUNBQXFDO0lBQzVDLEtBQUssRUFBRSxxQ0FBcUM7SUFDNUMsS0FBSyxFQUFFLDRCQUE0QjtDQUNwQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IERFRkFVTFRfRVJST1JfTUVTU0FHRVMgPSB7XHJcbiAgZGVmYXVsdEVycm9yOiB7XHJcbiAgICB0aXRsZTogJ0FuIGVycm9yIGhhcyBvY2N1cnJlZCEnLFxyXG4gICAgZGV0YWlsczogJ0Vycm9yIGRldGFpbCBub3Qgc2VudCBieSBzZXJ2ZXIuJyxcclxuICB9LFxyXG4gIGRlZmF1bHRFcnJvcjQwMToge1xyXG4gICAgdGl0bGU6ICdZb3UgYXJlIG5vdCBhdXRoZW50aWNhdGVkIScsXHJcbiAgICBkZXRhaWxzOiAnWW91IHNob3VsZCBiZSBhdXRoZW50aWNhdGVkIChzaWduIGluKSBpbiBvcmRlciB0byBwZXJmb3JtIHRoaXMgb3BlcmF0aW9uLicsXHJcbiAgfSxcclxuICBkZWZhdWx0RXJyb3I0MDM6IHtcclxuICAgIHRpdGxlOiAnWW91IGFyZSBub3QgYXV0aG9yaXplZCEnLFxyXG4gICAgZGV0YWlsczogJ1lvdSBhcmUgbm90IGFsbG93ZWQgdG8gcGVyZm9ybSB0aGlzIG9wZXJhdGlvbi4nLFxyXG4gIH0sXHJcbiAgZGVmYXVsdEVycm9yNDA0OiB7XHJcbiAgICB0aXRsZTogJ1Jlc291cmNlIG5vdCBmb3VuZCEnLFxyXG4gICAgZGV0YWlsczogJ1RoZSByZXNvdXJjZSByZXF1ZXN0ZWQgY291bGQgbm90IGZvdW5kIG9uIHRoZSBzZXJ2ZXIuJyxcclxuICB9LFxyXG4gIGRlZmF1bHRFcnJvcjUwMDoge1xyXG4gICAgdGl0bGU6ICdJbnRlcm5hbCBzZXJ2ZXIgZXJyb3InLFxyXG4gICAgZGV0YWlsczogJ0Vycm9yIGRldGFpbCBub3Qgc2VudCBieSBzZXJ2ZXIuJyxcclxuICB9LFxyXG59O1xyXG5cclxuZXhwb3J0IGNvbnN0IERFRkFVTFRfRVJST1JfTE9DQUxJWkFUSU9OUyA9IHtcclxuICBkZWZhdWx0RXJyb3I6IHtcclxuICAgIHRpdGxlOiAnQWJwVWk6OkRlZmF1bHRFcnJvck1lc3NhZ2UnLFxyXG4gICAgZGV0YWlsczogJ0FicFVpOjpEZWZhdWx0RXJyb3JNZXNzYWdlRGV0YWlsJyxcclxuICB9LFxyXG4gIGRlZmF1bHRFcnJvcjQwMToge1xyXG4gICAgdGl0bGU6ICdBYnBVaTo6RGVmYXVsdEVycm9yTWVzc2FnZTQwMScsXHJcbiAgICBkZXRhaWxzOiAnQWJwVWk6OkRlZmF1bHRFcnJvck1lc3NhZ2U0MDFEZXRhaWwnLFxyXG4gIH0sXHJcbiAgZGVmYXVsdEVycm9yNDAzOiB7XHJcbiAgICB0aXRsZTogJ0FicFVpOjpEZWZhdWx0RXJyb3JNZXNzYWdlNDAzJyxcclxuICAgIGRldGFpbHM6ICdBYnBVaTo6RGVmYXVsdEVycm9yTWVzc2FnZTQwM0RldGFpbCcsXHJcbiAgfSxcclxuICBkZWZhdWx0RXJyb3I0MDQ6IHtcclxuICAgIHRpdGxlOiAnQWJwVWk6OkRlZmF1bHRFcnJvck1lc3NhZ2U0MDQnLFxyXG4gICAgZGV0YWlsczogJ0FicFVpOjpEZWZhdWx0RXJyb3JNZXNzYWdlNDA0RGV0YWlsJyxcclxuICB9LFxyXG4gIGRlZmF1bHRFcnJvcjUwMDoge1xyXG4gICAgdGl0bGU6ICdBYnBVaTo6NTAwTWVzc2FnZScsXHJcbiAgICBkZXRhaWxzOiAnQWJwVWk6OkRlZmF1bHRFcnJvck1lc3NhZ2UnLFxyXG4gIH0sXHJcbn07XHJcblxyXG5leHBvcnQgY29uc3QgQ1VTVE9NX0hUVFBfRVJST1JfSEFORExFUl9QUklPUklUWSA9IE9iamVjdC5mcmVlemUoe1xyXG4gIHZlcnlMb3c6IC05OSxcclxuICBsb3c6IC05LFxyXG4gIG5vcm1hbDogMCxcclxuICBoaWdoOiA5LFxyXG4gIHZlcnlIaWdoOiA5OSxcclxufSk7XHJcblxyXG5leHBvcnQgY29uc3QgSFRUUF9FUlJPUl9TVEFUVVMgPSB7XHJcbiAgJzQwMSc6ICdBYnBVaTo6NDAxTWVzc2FnZScsXHJcbiAgJzQwMyc6ICdBYnBVaTo6NDAzTWVzc2FnZScsXHJcbiAgJzQwNCc6ICdBYnBVaTo6NDA0TWVzc2FnZScsXHJcbiAgJzUwMCc6ICdBYnBVaTo6NTAwTWVzc2FnZScsXHJcbn07XHJcblxyXG5leHBvcnQgY29uc3QgSFRUUF9FUlJPUl9ERVRBSUwgPSB7XHJcbiAgJzQwMSc6ICdBYnBVaTo6RGVmYXVsdEVycm9yTWVzc2FnZTQwMURldGFpbCcsXHJcbiAgJzQwMyc6ICdBYnBVaTo6RGVmYXVsdEVycm9yTWVzc2FnZTQwM0RldGFpbCcsXHJcbiAgJzQwNCc6ICdBYnBVaTo6RGVmYXVsdEVycm9yTWVzc2FnZTQwNERldGFpbCcsXHJcbiAgJzUwMCc6ICdBYnBVaTo6RGVmYXVsdEVycm9yTWVzc2FnZScsXHJcbn07XHJcbiJdfQ==
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export * from './validation';
|
|
2
|
+
export * from './default-errors';
|
|
3
|
+
export * from './styles';
|
|
4
|
+
export * from './scripts';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy90aGVtZS1zaGFyZWQvc3JjL2xpYi9jb25zdGFudHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLFVBQVUsQ0FBQztBQUN6QixjQUFjLFdBQVcsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vdmFsaWRhdGlvbic7XHJcbmV4cG9ydCAqIGZyb20gJy4vZGVmYXVsdC1lcnJvcnMnO1xyXG5leHBvcnQgKiBmcm9tICcuL3N0eWxlcyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vc2NyaXB0cyc7XHJcbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export default '';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2NyaXB0cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3RoZW1lLXNoYXJlZC9zcmMvbGliL2NvbnN0YW50cy9zY3JpcHRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGVBQWUsRUFBRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGRlZmF1bHQgJyc7XHJcbiJdfQ==
|
|
@@ -1,21 +1,33 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
1
|
+
import { ChangeDetectorRef, Directive, Input, inject, DestroyRef } from '@angular/core';
|
|
2
|
+
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
3
3
|
import { DatatableComponent } from '@swimlane/ngx-datatable';
|
|
4
|
-
import {
|
|
4
|
+
import { ListService, LocalizationService } from '@abp/ng.core';
|
|
5
5
|
import { defaultNgxDatatableMessages, NGX_DATATABLE_MESSAGES, } from '../tokens/ngx-datatable-messages.token';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
|
-
import * as i1 from "@swimlane/ngx-datatable";
|
|
8
|
-
import * as i2 from "@abp/ng.core";
|
|
9
7
|
export class NgxDatatableListDirective {
|
|
10
|
-
constructor(
|
|
11
|
-
this.table =
|
|
12
|
-
this.cdRef =
|
|
13
|
-
this.
|
|
14
|
-
this.
|
|
15
|
-
this.
|
|
16
|
-
this.querySubscription = new Subscription();
|
|
8
|
+
constructor() {
|
|
9
|
+
this.table = inject(DatatableComponent);
|
|
10
|
+
this.cdRef = inject(ChangeDetectorRef);
|
|
11
|
+
this.destroyRef = inject(DestroyRef);
|
|
12
|
+
this.localizationService = inject(LocalizationService);
|
|
13
|
+
this.ngxDatatableMessages = inject(NGX_DATATABLE_MESSAGES, { optional: true });
|
|
17
14
|
this.setInitialValues();
|
|
18
15
|
}
|
|
16
|
+
ngDoCheck() {
|
|
17
|
+
this.refreshPageIfDataExist();
|
|
18
|
+
}
|
|
19
|
+
ngOnInit() {
|
|
20
|
+
this.subscribeToPage();
|
|
21
|
+
this.subscribeToSort();
|
|
22
|
+
}
|
|
23
|
+
ngOnChanges({ list }) {
|
|
24
|
+
this.subscribeToQuery();
|
|
25
|
+
if (!list.firstChange)
|
|
26
|
+
return;
|
|
27
|
+
const { maxResultCount, page } = list.currentValue;
|
|
28
|
+
this.table.limit = maxResultCount;
|
|
29
|
+
this.table.offset = page;
|
|
30
|
+
}
|
|
19
31
|
setInitialValues() {
|
|
20
32
|
this.table.externalPaging = true;
|
|
21
33
|
this.table.externalSorting = true;
|
|
@@ -27,7 +39,7 @@ export class NgxDatatableListDirective {
|
|
|
27
39
|
};
|
|
28
40
|
}
|
|
29
41
|
subscribeToSort() {
|
|
30
|
-
|
|
42
|
+
this.table.sort.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(({ sorts: [{ prop, dir }] }) => {
|
|
31
43
|
if (prop === this.list.sortKey && this.list.sortOrder === 'desc') {
|
|
32
44
|
this.list.sortKey = '';
|
|
33
45
|
this.list.sortOrder = '';
|
|
@@ -39,33 +51,41 @@ export class NgxDatatableListDirective {
|
|
|
39
51
|
this.list.sortOrder = dir;
|
|
40
52
|
}
|
|
41
53
|
});
|
|
42
|
-
|
|
54
|
+
}
|
|
55
|
+
subscribeToPage() {
|
|
56
|
+
this.table.page.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(({ offset }) => {
|
|
57
|
+
this.setTablePage(offset);
|
|
58
|
+
});
|
|
43
59
|
}
|
|
44
60
|
subscribeToQuery() {
|
|
45
|
-
|
|
46
|
-
this.querySubscription.unsubscribe();
|
|
47
|
-
this.querySubscription = this.list.query$.subscribe(() => {
|
|
61
|
+
this.list.query$.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(() => {
|
|
48
62
|
const offset = this.list.page;
|
|
49
63
|
if (this.table.offset !== offset)
|
|
50
64
|
this.table.offset = offset;
|
|
51
65
|
});
|
|
52
66
|
}
|
|
53
|
-
|
|
54
|
-
this.
|
|
55
|
-
|
|
56
|
-
return;
|
|
57
|
-
const { maxResultCount, page } = list.currentValue;
|
|
58
|
-
this.table.limit = maxResultCount;
|
|
59
|
-
this.table.offset = page;
|
|
60
|
-
}
|
|
61
|
-
ngOnDestroy() {
|
|
62
|
-
this.subscription.unsubscribe();
|
|
63
|
-
this.querySubscription.unsubscribe();
|
|
67
|
+
setTablePage(pageNum) {
|
|
68
|
+
this.list.page = pageNum;
|
|
69
|
+
this.table.offset = pageNum;
|
|
64
70
|
}
|
|
65
|
-
|
|
66
|
-
this.
|
|
71
|
+
refreshPageIfDataExist() {
|
|
72
|
+
if (this.table.rows?.length < 1 && this.table.count > 0) {
|
|
73
|
+
let maxPage = Math.floor(Number(this.table.count / this.list.maxResultCount));
|
|
74
|
+
if (this.table.count < this.list.maxResultCount) {
|
|
75
|
+
this.setTablePage(0);
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
if (this.table.count % this.list.maxResultCount === 0) {
|
|
79
|
+
maxPage -= 1;
|
|
80
|
+
}
|
|
81
|
+
if (this.list.page < maxPage) {
|
|
82
|
+
this.setTablePage(this.list.page);
|
|
83
|
+
return;
|
|
84
|
+
}
|
|
85
|
+
this.setTablePage(maxPage);
|
|
86
|
+
}
|
|
67
87
|
}
|
|
68
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: NgxDatatableListDirective, deps: [
|
|
88
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: NgxDatatableListDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
69
89
|
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.1.3", type: NgxDatatableListDirective, isStandalone: true, selector: "ngx-datatable[list]", inputs: { list: "list" }, exportAs: ["ngxDatatableList"], usesOnChanges: true, ngImport: i0 }); }
|
|
70
90
|
}
|
|
71
91
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: NgxDatatableListDirective, decorators: [{
|
|
@@ -76,12 +96,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImpor
|
|
|
76
96
|
standalone: true,
|
|
77
97
|
exportAs: 'ngxDatatableList',
|
|
78
98
|
}]
|
|
79
|
-
}], ctorParameters: () => [
|
|
80
|
-
type: Optional
|
|
81
|
-
}, {
|
|
82
|
-
type: Inject,
|
|
83
|
-
args: [NGX_DATATABLE_MESSAGES]
|
|
84
|
-
}] }], propDecorators: { list: [{
|
|
99
|
+
}], ctorParameters: () => [], propDecorators: { list: [{
|
|
85
100
|
type: Input
|
|
86
101
|
}] } });
|
|
87
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWRhdGF0YWJsZS1saXN0LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3RoZW1lLXNoYXJlZC9zcmMvbGliL2RpcmVjdGl2ZXMvbmd4LWRhdGF0YWJsZS1saXN0LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsV0FBVyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sY0FBYyxDQUFDO0FBQ2hFLE9BQU8sRUFDTCxpQkFBaUIsRUFDakIsU0FBUyxFQUNULE1BQU0sRUFDTixLQUFLLEVBSUwsUUFBUSxHQUVULE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQzdELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDcEMsT0FBTyxFQUNMLDJCQUEyQixFQUUzQixzQkFBc0IsR0FDdkIsTUFBTSx3Q0FBd0MsQ0FBQzs7OztBQVFoRCxNQUFNLE9BQU8seUJBQXlCO0lBTXBDLFlBQ1UsS0FBeUIsRUFDekIsS0FBd0IsRUFDeEIsbUJBQXdDLEVBQ0ksb0JBQTBDO1FBSHRGLFVBQUssR0FBTCxLQUFLLENBQW9CO1FBQ3pCLFVBQUssR0FBTCxLQUFLLENBQW1CO1FBQ3hCLHdCQUFtQixHQUFuQixtQkFBbUIsQ0FBcUI7UUFDSSx5QkFBb0IsR0FBcEIsb0JBQW9CLENBQXNCO1FBVHhGLGlCQUFZLEdBQUcsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUNsQyxzQkFBaUIsR0FBRyxJQUFJLFlBQVksRUFBRSxDQUFDO1FBVTdDLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDO0lBQzFCLENBQUM7SUFFTyxnQkFBZ0I7UUFDdEIsSUFBSSxDQUFDLEtBQUssQ0FBQyxjQUFjLEdBQUcsSUFBSSxDQUFDO1FBQ2pDLElBQUksQ0FBQyxLQUFLLENBQUMsZUFBZSxHQUFHLElBQUksQ0FBQztR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OEQ7b0JBQzlELFFBQVEsRUFBRSxxQkFBcUI7b0JBQy9CLFVBQVUsRUFBRSxJQUFJO29CQUNoQixRQUFRLEVBQUUsa0JBQWtCO2lCQUM3Qjs7MEJBV0ksUUFBUTs7MEJBQUksTUFBTTsyQkFBQyxzQkFBc0I7eUNBTm5DLElBQUk7c0JBQVosS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IExpc3RTZXJ2aWNlLCBMb2NhbGl6YXRpb25TZXJ2aWNlIH0gZnJvbSAnQGFicC9uZy5jb3JlJztcclxuaW1wb3J0IHtcclxuICBDaGFuZ2VEZXRlY3RvclJlZixcclxuICBEaXJlY3RpdmUsXHJcbiAgSW5qZWN0LFxyXG4gIElucHV0LFxyXG4gIE9uQ2hhbmdlcyxcclxuICBPbkRlc3Ryb3ksXHJcbiAgT25Jbml0LFxyXG4gIE9wdGlvbmFsLFxyXG4gIFNpbXBsZUNoYW5nZXMsXHJcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IERhdGF0YWJsZUNvbXBvbmVudCB9IGZyb20gJ0Bzd2ltbGFuZS9uZ3gtZGF0YXRhYmxlJztcclxuaW1wb3J0IHsgU3Vic2NyaXB0aW9uIH0gZnJvbSAncnhqcyc7XHJcbmltcG9ydCB7XHJcbiAgZGVmYXVsdE5neERhdGF0YWJsZU1lc3NhZ2VzLFxyXG4gIE5neERhdGF0YWJsZU1lc3NhZ2VzLFxyXG4gIE5HWF9EQVRBVEFCTEVfTUVTU0FHRVMsXHJcbn0gZnJvbSAnLi4vdG9rZW5zL25neC1kYXRhdGFibGUtbWVzc2FnZXMudG9rZW4nO1xyXG5cclxuQERpcmVjdGl2ZSh7XHJcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEBhbmd1bGFyLWVzbGludC9kaXJlY3RpdmUtc2VsZWN0b3JcclxuICBzZWxlY3RvcjogJ25neC1kYXRhdGFibGVbbGlzdF0nLFxyXG4gIHN0YW5kYWxvbmU6IHRydWUsXHJcbiAgZXhwb3J0QXM6ICduZ3hEYXRhdGFibGVMaXN0JyxcclxufSlcclxuZXhwb3J0IGNsYXNzIE5neERhdGF0YWJsZUxpc3REaXJlY3RpdmUgaW1wbGVtZW50cyBPbkNoYW5nZXMsIE9uRGVzdHJveSwgT25Jbml0IHtcclxuICBwcml2YXRlIHN1YnNjcmlwdGlvbiA9IG5ldyBTdWJzY3JpcHRpb24oKTtcclxuICBwcml2YXRlIHF1ZXJ5U3Vic2NyaXB0aW9uID0gbmV3IFN1YnNjcmlwdGlvbigpO1xyXG5cclxuICBASW5wdXQoKSBsaXN0ITogTGlzdFNlcnZpY2U7XHJcblxyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgcHJpdmF0ZSB0YWJsZTogRGF0YXRhYmxlQ29tcG9uZW50LFxyXG4gICAgcHJpdmF0ZSBjZFJlZjogQ2hhbmdlRGV0ZWN0b3JSZWYsXHJcbiAgICBwcml2YXRlIGxvY2FsaXphdGlvblNlcnZpY2U6IExvY2FsaXphdGlvblNlcnZpY2UsXHJcbiAgICBAT3B0aW9uYWwoKSBASW5qZWN0KE5HWF9EQVRBVEFCTEVfTUVTU0FHRVMpIHByaXZhdGUgbmd4RGF0YXRhYmxlTWVzc2FnZXM6IE5neERhdGF0YWJsZU1lc3NhZ2VzLFxyXG4gICkge1xyXG4gICAgdGhpcy5zZXRJbml0aWFsVmFsdWVzKCk7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIHNldEluaXRpYWxWYWx1ZXMoKSB7XHJcbiAgICB0aGlzLnRhYmxlLmV4dGVybmFsUGFnaW5nID0gdHJ1ZTtcclxuICAgIHRoaXMudGFibGUuZXh0ZXJuYWxTb3J0aW5nID0gdHJ1ZTtcclxuXHJcbiAgICBjb25zdCB7IGVtcHR5TWVzc2FnZSwgc2VsZWN0ZWRNZXNzYWdlLCB0b3RhbE1lc3NhZ2UgfSA9XHJcbiAgICAgIHRoaXMubmd4RGF0YXRhYmxlTWVzc2FnZXMgfHwgZGVmYXVsdE5neERhdGF0YWJsZU1lc3NhZ2VzO1xyXG5cclxuICAgIHRoaXMudGFibGUubWVzc2FnZXMgPSB7XHJcbiAgICAgIGVtcHR5TWVzc2FnZTogdGhpcy5sb2NhbGl6YXRpb25TZXJ2aWNlLmluc3RhbnQoZW1wdHlNZXNzYWdlKSxcclxuICAgICAgdG90YWxNZXNzYWdlOiB0aGlzLmxvY2FsaXphdGlvblNlcnZpY2UuaW5zdGFudCh0b3RhbE1lc3NhZ2UpLFxyXG4gICAgICBzZWxlY3RlZE1lc3NhZ2U6IHRoaXMubG9jYWxpemF0aW9uU2VydmljZS5pbnN0YW50KHNlbGVjdGVkTWVzc2FnZSksXHJcbiAgICB9O1xyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSBzdWJzY3JpYmVUb1NvcnQoKSB7XHJcbiAgICBjb25zdCBzdWIgPSB0aGlzLnRhYmxlLnNvcnQuc3Vic2NyaWJlKCh7IHNvcnRzOiBbeyBwcm9wLCBkaXIgfV0gfSkgPT4ge1xyXG4gICAgICBpZiAocHJvcCA9PT0gdGhpcy5saXN0LnNvcnRLZXkgJiYgdGhpcy5saXN0LnNvcnRPcmRlciA9PT0gJ2Rlc2MnKSB7XHJcbiAgICAgICAgdGhpcy5saXN0LnNvcnRLZXkgPSAnJztcclxuICAgICAgICB0aGlzLmxpc3Quc29ydE9yZGVyID0gJyc7XHJcbiAgICAgICAgdGhpcy50YWJsZS5zb3J0cyA9IFtdO1xyXG4gICAgICAgIHRoaXMuY2RSZWYuZGV0ZWN0Q2hhbmdlcygpO1xyXG4gICAgICB9IGVsc2Uge1xyXG4gICAgICAgIHRoaXMubGlzdC5zb3J0S2V5ID0gcHJvcDtcclxuICAgICAgICB0aGlzLmxpc3Quc29ydE9yZGVyID0gZGlyO1xyXG4gICAgICB9XHJcbiAgICB9KTtcclxuICAgIHRoaXMuc3Vic2NyaXB0aW9uLmFkZChzdWIpO1xyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSBzdWJzY3JpYmVUb1F1ZXJ5KCkge1xyXG4gICAgaWYgKCF0aGlzLnF1ZXJ5U3Vic2NyaXB0aW9uLmNsb3NlZCkgdGhpcy5xdWVyeVN1YnNjcmlwdGlvbi51bnN1YnNjcmliZSgpO1xyXG5cclxuICAgIHRoaXMucXVlcnlTdWJzY3JpcHRpb24gPSB0aGlzLmxpc3QucXVlcnkkLnN1YnNjcmliZSgoKSA9PiB7XHJcbiAgICAgIGNvbnN0IG9mZnNldCA9IHRoaXMubGlzdC5wYWdlO1xyXG4gICAgICBpZiAodGhpcy50YWJsZS5vZmZzZXQgIT09IG9mZnNldCkgdGhpcy50YWJsZS5vZmZzZXQgPSBvZmZzZXQ7XHJcbiAgICB9KTtcclxuICB9XHJcblxyXG4gIG5nT25DaGFuZ2VzKHsgbGlzdCB9OiBTaW1wbGVDaGFuZ2VzKSB7XHJcbiAgICB0aGlzLnN1YnNjcmliZVRvUXVlcnkoKTtcclxuXHJcbiAgICBpZiAoIWxpc3QuZmlyc3RDaGFuZ2UpIHJldHVybjtcclxuXHJcbiAgICBjb25zdCB7IG1heFJlc3VsdENvdW50LCBwYWdlIH0gPSBsaXN0LmN1cnJlbnRWYWx1ZTtcclxuICAgIHRoaXMudGFibGUubGltaXQgPSBtYXhSZXN1bHRDb3VudDtcclxuICAgIHRoaXMudGFibGUub2Zmc2V0ID0gcGFnZTtcclxuICB9XHJcblxyXG4gIG5nT25EZXN0cm95KCkge1xyXG4gICAgdGhpcy5zdWJzY3JpcHRpb24udW5zdWJzY3JpYmUoKTtcclxuICAgIHRoaXMucXVlcnlTdWJzY3JpcHRpb24udW5zdWJzY3JpYmUoKTtcclxuICB9XHJcblxyXG4gIG5nT25Jbml0KCkge1xyXG4gICAgdGhpcy5zdWJzY3JpYmVUb1NvcnQoKTtcclxuICB9XHJcbn1cclxuIl19
|
|
102
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-datatable-list.directive.js","sourceRoot":"","sources":["../../../../../../packages/theme-shared/src/lib/directives/ngx-datatable-list.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectorRef,\r\n  Directive,\r\n  Input,\r\n  OnChanges,\r\n  OnInit,\r\n  DoCheck,\r\n  SimpleChanges,\r\n  inject,\r\n  DestroyRef\r\n} from '@angular/core';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\nimport { DatatableComponent } from '@swimlane/ngx-datatable';\r\nimport { ListService, LocalizationService } from '@abp/ng.core';\r\nimport {\r\n  defaultNgxDatatableMessages,\r\n  NGX_DATATABLE_MESSAGES,\r\n} from '../tokens/ngx-datatable-messages.token';\r\n\r\n@Directive({\r\n  // eslint-disable-next-line @angular-eslint/directive-selector\r\n  selector: 'ngx-datatable[list]',\r\n  standalone: true,\r\n  exportAs: 'ngxDatatableList',\r\n})\r\nexport class NgxDatatableListDirective implements OnChanges, OnInit, DoCheck {\r\n  @Input() list!: ListService;\r\n\r\n  protected readonly table = inject(DatatableComponent);\r\n  protected readonly cdRef = inject(ChangeDetectorRef);\r\n  protected readonly destroyRef = inject(DestroyRef);\r\n  protected readonly localizationService = inject(LocalizationService);\r\n  protected readonly ngxDatatableMessages = inject(NGX_DATATABLE_MESSAGES, { optional: true });\r\n\r\n  constructor() {\r\n    this.setInitialValues();\r\n  }\r\n\r\n  ngDoCheck(): void {\r\n    this.refreshPageIfDataExist();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.subscribeToPage();\r\n    this.subscribeToSort();\r\n  }\r\n\r\n  ngOnChanges({ list }: SimpleChanges) {\r\n    this.subscribeToQuery();\r\n\r\n    if (!list.firstChange) return;\r\n\r\n    const { maxResultCount, page } = list.currentValue;\r\n    this.table.limit = maxResultCount;\r\n    this.table.offset = page;\r\n  }\r\n\r\n  protected setInitialValues() {\r\n    this.table.externalPaging = true;\r\n    this.table.externalSorting = true;\r\n\r\n    const { emptyMessage, selectedMessage, totalMessage } =\r\n      this.ngxDatatableMessages || defaultNgxDatatableMessages;\r\n\r\n    this.table.messages = {\r\n      emptyMessage: this.localizationService.instant(emptyMessage),\r\n      totalMessage: this.localizationService.instant(totalMessage),\r\n      selectedMessage: this.localizationService.instant(selectedMessage),\r\n    };\r\n  }\r\n\r\n  protected subscribeToSort() {\r\n    this.table.sort.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(({ sorts: [{ prop, dir }] }) => {\r\n      if (prop === this.list.sortKey && this.list.sortOrder === 'desc') {\r\n        this.list.sortKey = '';\r\n        this.list.sortOrder = '';\r\n        this.table.sorts = [];\r\n        this.cdRef.detectChanges();\r\n      } else {\r\n        this.list.sortKey = prop;\r\n        this.list.sortOrder = dir;\r\n      }\r\n    });\r\n  }\r\n\r\n  protected subscribeToPage() {\r\n    this.table.page.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(({ offset }) => {\r\n      this.setTablePage(offset);\r\n    });\r\n  }\r\n\r\n  protected subscribeToQuery() {\r\n    this.list.query$.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(() => {\r\n      const offset = this.list.page;\r\n      if (this.table.offset !== offset) this.table.offset = offset;\r\n    });\r\n  }\r\n\r\n  protected setTablePage(pageNum: number) {\r\n    this.list.page = pageNum;\r\n    this.table.offset = pageNum;\r\n  }\r\n\r\n  protected refreshPageIfDataExist() {\r\n    if (this.table.rows?.length < 1 && this.table.count > 0) {\r\n      let maxPage = Math.floor(Number(this.table.count / this.list.maxResultCount));\r\n\r\n      if (this.table.count < this.list.maxResultCount) {\r\n        this.setTablePage(0);\r\n        return;\r\n      }\r\n\r\n      if (this.table.count % this.list.maxResultCount === 0) {\r\n        maxPage -= 1;\r\n      }\r\n\r\n      if (this.list.page < maxPage) {\r\n        this.setTablePage(this.list.page);\r\n        return;\r\n      }\r\n\r\n      this.setTablePage(maxPage);\r\n    }\r\n  }\r\n}\r\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ApplicationRef,
|
|
1
|
+
import { ApplicationRef, createComponent, EnvironmentInjector, inject, Injectable, Injector, RendererFactory2, } from '@angular/core';
|
|
2
2
|
import { DOCUMENT } from '@angular/common';
|
|
3
3
|
import { ResolveEnd } from '@angular/router';
|
|
4
4
|
import { Subject } from 'rxjs';
|
|
@@ -11,9 +11,9 @@ export class CreateErrorComponentService {
|
|
|
11
11
|
constructor() {
|
|
12
12
|
this.document = inject(DOCUMENT);
|
|
13
13
|
this.rendererFactory = inject(RendererFactory2);
|
|
14
|
-
this.cfRes = inject(ComponentFactoryResolver);
|
|
15
14
|
this.routerEvents = inject(RouterEvents);
|
|
16
15
|
this.injector = inject(Injector);
|
|
16
|
+
this.envInjector = inject(EnvironmentInjector);
|
|
17
17
|
this.httpErrorConfig = inject(HTTP_ERROR_CONFIG);
|
|
18
18
|
this.componentRef = null;
|
|
19
19
|
this.listenToRouterDataResolved();
|
|
@@ -44,9 +44,9 @@ export class CreateErrorComponentService {
|
|
|
44
44
|
const renderer = this.rendererFactory.createRenderer(null, null);
|
|
45
45
|
const hostElement = this.getErrorHostElement();
|
|
46
46
|
const host = renderer.selectRootElement(hostElement, true);
|
|
47
|
-
this.componentRef =
|
|
48
|
-
.
|
|
49
|
-
|
|
47
|
+
this.componentRef = createComponent(HttpErrorWrapperComponent, {
|
|
48
|
+
environmentInjector: this.envInjector,
|
|
49
|
+
});
|
|
50
50
|
for (const key in instance) {
|
|
51
51
|
/* istanbul ignore else */
|
|
52
52
|
if (Object.prototype.hasOwnProperty.call(this.componentRef.instance, key)) {
|
|
@@ -56,9 +56,8 @@ export class CreateErrorComponentService {
|
|
|
56
56
|
this.componentRef.instance.hideCloseIcon = this.isCloseIconHidden();
|
|
57
57
|
const appRef = this.injector.get(ApplicationRef);
|
|
58
58
|
if (this.canCreateCustomError(instance.status)) {
|
|
59
|
-
this.componentRef.instance.cfRes = this.cfRes;
|
|
60
59
|
this.componentRef.instance.appRef = appRef;
|
|
61
|
-
this.componentRef.instance.
|
|
60
|
+
this.componentRef.instance.environmentInjector = this.envInjector;
|
|
62
61
|
this.componentRef.instance.customComponent = this.httpErrorConfig.errorScreen?.component;
|
|
63
62
|
}
|
|
64
63
|
appRef.attachView(this.componentRef.hostView);
|
|
@@ -77,4 +76,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImpor
|
|
|
77
76
|
type: Injectable,
|
|
78
77
|
args: [{ providedIn: 'root' }]
|
|
79
78
|
}], ctorParameters: () => [] });
|
|
80
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-error-component.service.js","sourceRoot":"","sources":["../../../../../../packages/theme-shared/src/lib/services/create-error-component.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ApplicationRef,\r\n  ComponentRef,\r\n  createComponent,\r\n  EmbeddedViewRef,\r\n  EnvironmentInjector,\r\n  inject,\r\n  Injectable,\r\n  Injector,\r\n  RendererFactory2,\r\n} from '@angular/core';\r\nimport { DOCUMENT } from '@angular/common';\r\nimport { ResolveEnd } from '@angular/router';\r\nimport { Subject } from 'rxjs';\r\nimport { filter } from 'rxjs/operators';\r\nimport { RouterEvents } from '@abp/ng.core';\r\nimport { HTTP_ERROR_CONFIG } from '../tokens/http-error.token';\r\nimport { HttpErrorWrapperComponent } from '../components/http-error-wrapper/http-error-wrapper.component';\r\nimport { ErrorScreenErrorCodes } from '../models/common';\r\n\r\n@Injectable({ providedIn: 'root' })\r\nexport class CreateErrorComponentService {\r\n  protected readonly document = inject(DOCUMENT);\r\n  protected readonly rendererFactory = inject(RendererFactory2);\r\n  protected readonly routerEvents = inject(RouterEvents);\r\n  protected readonly injector = inject(Injector);\r\n  protected readonly envInjector = inject(EnvironmentInjector);\r\n  protected readonly httpErrorConfig = inject(HTTP_ERROR_CONFIG);\r\n\r\n  componentRef: ComponentRef<HttpErrorWrapperComponent> | null = null;\r\n\r\n  constructor() {\r\n    this.listenToRouterDataResolved();\r\n  }\r\n\r\n  protected listenToRouterDataResolved(): void {\r\n    this.routerEvents\r\n      .getEvents(ResolveEnd)\r\n      .pipe(filter(() => !!this.componentRef))\r\n      .subscribe(() => {\r\n        this.componentRef?.destroy();\r\n        this.componentRef = null;\r\n      });\r\n  }\r\n\r\n  protected getErrorHostElement(): HTMLElement {\r\n    return this.document.body;\r\n  }\r\n\r\n  protected isCloseIconHidden(): boolean {\r\n    return !!this.httpErrorConfig?.errorScreen?.hideCloseIcon;\r\n  }\r\n\r\n  canCreateCustomError(status: ErrorScreenErrorCodes) {\r\n    const { component, forWhichErrors } = this.httpErrorConfig?.errorScreen || {};\r\n\r\n    if (!component || !forWhichErrors) {\r\n      return false;\r\n    }\r\n\r\n    return forWhichErrors.indexOf(status) > -1;\r\n  }\r\n\r\n  execute(instance: Partial<HttpErrorWrapperComponent>): void {\r\n    const renderer = this.rendererFactory.createRenderer(null, null);\r\n    const hostElement = this.getErrorHostElement();\r\n    const host = renderer.selectRootElement(hostElement, true);\r\n\r\n    this.componentRef = createComponent(HttpErrorWrapperComponent, {\r\n      environmentInjector: this.envInjector,\r\n    });\r\n\r\n    for (const key in instance) {\r\n      /* istanbul ignore else */\r\n      if (Object.prototype.hasOwnProperty.call(this.componentRef.instance, key)) {\r\n        (this.componentRef.instance as any)[key] = (instance as any)[key];\r\n      }\r\n    }\r\n\r\n    this.componentRef.instance.hideCloseIcon = this.isCloseIconHidden();\r\n    const appRef = this.injector.get(ApplicationRef);\r\n\r\n    if (this.canCreateCustomError(instance.status as ErrorScreenErrorCodes)) {\r\n      this.componentRef.instance.appRef = appRef;\r\n      this.componentRef.instance.environmentInjector = this.envInjector;\r\n      this.componentRef.instance.customComponent = this.httpErrorConfig.errorScreen?.component;\r\n    }\r\n\r\n    appRef.attachView(this.componentRef.hostView);\r\n    renderer.appendChild(host, (this.componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0]);\r\n\r\n    const destroy$ = new Subject<void>();\r\n    this.componentRef.instance.destroy$ = destroy$;\r\n\r\n    destroy$.subscribe(() => {\r\n      this.componentRef?.destroy();\r\n      this.componentRef = null;\r\n    });\r\n  }\r\n}\r\n"]}
|
package/esm2022/public-api.mjs
CHANGED
|
@@ -4,8 +4,6 @@
|
|
|
4
4
|
export * from './lib/adapters';
|
|
5
5
|
export * from './lib/animations';
|
|
6
6
|
export * from './lib/components';
|
|
7
|
-
export * from './lib/constants/validation';
|
|
8
|
-
export * from './lib/constants/default-errors';
|
|
9
7
|
export * from './lib/directives';
|
|
10
8
|
export * from './lib/enums';
|
|
11
9
|
export * from './lib/handlers';
|
|
@@ -15,4 +13,5 @@ export * from './lib/services';
|
|
|
15
13
|
export * from './lib/theme-shared.module';
|
|
16
14
|
export * from './lib/tokens';
|
|
17
15
|
export * from './lib/utils';
|
|
18
|
-
|
|
16
|
+
export * from './lib/constants';
|
|
17
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL3RoZW1lLXNoYXJlZC9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGlCQUFpQixDQUFDO0FBQ2hDLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGFBQWEsQ0FBQztBQUM1QixjQUFjLGlCQUFpQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcclxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIHRoZW1lLXNoYXJlZFxyXG4gKi9cclxuXHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2FkYXB0ZXJzJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvYW5pbWF0aW9ucyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kaXJlY3RpdmVzJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvZW51bXMnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9oYW5kbGVycyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGVscyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3Byb3ZpZGVycyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NlcnZpY2VzJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvdGhlbWUtc2hhcmVkLm1vZHVsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3Rva2Vucyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3V0aWxzJztcclxuZXhwb3J0ICogZnJvbSAnLi9saWIvY29uc3RhbnRzJztcclxuIl19
|