@acorex/components 18.12.39 → 18.12.41
Sign up to get free protection for your applications and to get access to all the features.
- package/dialog/lib/dialog.component.d.ts +11 -11
- package/dialog/lib/dialog.service.d.ts +2 -2
- package/esm2022/common/lib/types/placement.mjs +8 -2
- package/esm2022/datetime-picker/lib/datetime-picker.component.mjs +3 -3
- package/esm2022/dialog/lib/dialog.component.mjs +12 -12
- package/esm2022/dialog/lib/dialog.service.mjs +5 -5
- package/esm2022/form/lib/validation-rule.directive.mjs +1 -1
- package/esm2022/notification/lib/notification.component.mjs +4 -4
- package/esm2022/notification/lib/notification.config.mjs +2 -1
- package/esm2022/notification/lib/notification.service.mjs +137 -39
- package/esm2022/toast/lib/toast.component.mjs +2 -2
- package/esm2022/toast/lib/toast.config.mjs +2 -1
- package/esm2022/toast/lib/toast.service.mjs +140 -36
- package/fesm2022/acorex-components-common.mjs +7 -1
- package/fesm2022/acorex-components-common.mjs.map +1 -1
- package/fesm2022/acorex-components-datetime-picker.mjs +2 -2
- package/fesm2022/acorex-components-datetime-picker.mjs.map +1 -1
- package/fesm2022/acorex-components-dialog.mjs +15 -15
- package/fesm2022/acorex-components-dialog.mjs.map +1 -1
- package/fesm2022/acorex-components-form.mjs.map +1 -1
- package/fesm2022/acorex-components-notification.mjs +139 -40
- package/fesm2022/acorex-components-notification.mjs.map +1 -1
- package/fesm2022/acorex-components-toast.mjs +140 -35
- package/fesm2022/acorex-components-toast.mjs.map +1 -1
- package/form/lib/validation-rule.directive.d.ts +1 -1
- package/notification/lib/notification.component.d.ts +3 -3
- package/notification/lib/notification.config.d.ts +1 -0
- package/notification/lib/notification.service.d.ts +13 -0
- package/package.json +1 -1
- package/toast/lib/toast.component.d.ts +1 -1
- package/toast/lib/toast.config.d.ts +1 -0
- package/toast/lib/toast.service.d.ts +13 -0
@@ -33,4 +33,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
33
33
|
}], message: [{
|
34
34
|
type: Input
|
35
35
|
}] } });
|
36
|
-
//# sourceMappingURL=data:application/json;base64,
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdGlvbi1ydWxlLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9mb3JtL3NyYy9saWIvdmFsaWRhdGlvbi1ydWxlLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUVoRSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBcUIsTUFBTSxlQUFlLENBQUM7OztBQUtwRSxNQUFNLE9BQU8seUJBQXlCO0lBS3BDLFlBQW9CLElBQXlCO1FBQXpCLFNBQUksR0FBSixJQUFJLENBQXFCO0lBQUcsQ0FBQztJQUVqRCxRQUFRO1FBQ04sSUFBSSxDQUFDLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxFQUFFLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSSxFQUFFLE9BQU8sRUFBRSxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQztJQUM5RSxDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxJQUFJLENBQUMsb0JBQW9CLENBQUM7WUFDN0IsSUFBSSxFQUFFLElBQUksQ0FBQyxJQUFJO1lBQ2YsT0FBTyxFQUFFLElBQUksQ0FBQyxXQUFXO1NBQzFCLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCxJQUFZLFdBQVc7UUFDckIsT0FBTyxNQUFNLENBQUMsTUFBTSxDQUFDLEVBQUUsT0FBTyxFQUFFLElBQUksQ0FBQyxPQUFPLEVBQUUsSUFBSSxFQUFFLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLEVBQUUsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ3RGLENBQUM7OEdBcEJVLHlCQUF5QjtrR0FBekIseUJBQXlCOzsyRkFBekIseUJBQXlCO2tCQUhyQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxvQkFBb0I7aUJBQy9CO3dGQUVVLElBQUk7c0JBQVosS0FBSztnQkFDRyxPQUFPO3NCQUFmLEtBQUs7Z0JBQ0csT0FBTztzQkFBZixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQVhWYWx1YWJsZUNvbXBvbmVudCB9IGZyb20gJ0BhY29yZXgvY29tcG9uZW50cy9jb21tb24nO1xuaW1wb3J0IHsgQVhWYWxpZGF0aW9uUnVsZU9wdGlvbnMgfSBmcm9tICdAYWNvcmV4L2NvcmUvdmFsaWRhdGlvbic7XG5pbXBvcnQgeyBEaXJlY3RpdmUsIElucHV0LCBPbkRlc3Ryb3ksIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5ARGlyZWN0aXZlKHtcbiAgc2VsZWN0b3I6ICdheC12YWxpZGF0aW9uLXJ1bGUnLFxufSlcbmV4cG9ydCBjbGFzcyBBWFZhbGlkYXRpb25SdWxlRGlyZWN0aXZlIGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3kge1xuICBASW5wdXQoKSBydWxlOiBzdHJpbmc7XG4gIEBJbnB1dCgpIG9wdGlvbnM6IE9taXQ8QVhWYWxpZGF0aW9uUnVsZU9wdGlvbnMsICdtZXNzYWdlJz47XG4gIEBJbnB1dCgpIG1lc3NhZ2U6IHN0cmluZztcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGhvc3Q6IEFYVmFsdWFibGVDb21wb25lbnQpIHt9XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgdGhpcy5ob3N0LmFkZFZhbGlkYXRpb25SdWxlKHsgcnVsZTogdGhpcy5ydWxlLCBvcHRpb25zOiB0aGlzLnJ1bGVPcHRpb25zIH0pO1xuICB9XG5cbiAgbmdPbkRlc3Ryb3koKSB7XG4gICAgdGhpcy5ob3N0LnJlbW92ZVZhbGlkYXRpb25SdWxlKHtcbiAgICAgIHJ1bGU6IHRoaXMucnVsZSxcbiAgICAgIG9wdGlvbnM6IHRoaXMucnVsZU9wdGlvbnMsXG4gICAgfSk7XG4gIH1cblxuICBwcml2YXRlIGdldCBydWxlT3B0aW9ucygpOiBBWFZhbGlkYXRpb25SdWxlT3B0aW9ucyB7XG4gICAgcmV0dXJuIE9iamVjdC5hc3NpZ24oeyBtZXNzYWdlOiB0aGlzLm1lc3NhZ2UsIG5hbWU6IHRoaXMuaG9zdC5uYW1lIH0sIHRoaXMub3B0aW9ucyk7XG4gIH1cbn1cbiJdfQ==
|
@@ -1,7 +1,7 @@
|
|
1
1
|
import { AXClosbaleComponent, MXBaseComponent } from '@acorex/components/common';
|
2
2
|
import { DIALOG_DATA, DialogRef } from '@angular/cdk/dialog';
|
3
3
|
import { ComponentPortal, TemplatePortal } from '@angular/cdk/portal';
|
4
|
-
import { ChangeDetectionStrategy, Component, HostBinding, Inject, TemplateRef, ViewEncapsulation } from '@angular/core';
|
4
|
+
import { ChangeDetectionStrategy, Component, HostBinding, Inject, TemplateRef, ViewEncapsulation, } from '@angular/core';
|
5
5
|
import * as i0 from "@angular/core";
|
6
6
|
import * as i1 from "@angular/cdk/dialog";
|
7
7
|
import * as i2 from "@angular/cdk/portal";
|
@@ -86,8 +86,8 @@ export class AXNotificationComponent extends MXBaseComponent {
|
|
86
86
|
return `ax-${this.config.color}`;
|
87
87
|
}
|
88
88
|
/**
|
89
|
-
|
90
|
-
|
89
|
+
* Closes the dialog and provides the component and HTML element for reference.
|
90
|
+
*/
|
91
91
|
close() {
|
92
92
|
this.dialogRef.close({
|
93
93
|
component: this,
|
@@ -107,4 +107,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
107
107
|
type: HostBinding,
|
108
108
|
args: ['class']
|
109
109
|
}] } });
|
110
|
-
//# sourceMappingURL=data:application/json;base64,
|
110
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notification.component.js","sourceRoot":"","sources":["../../../../../../libs/components/notification/src/lib/notification.component.ts","../../../../../../libs/components/notification/src/lib/notification.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXClosbaleComponent, AXComponentCloseEvent, MXBaseComponent } from '@acorex/components/common';\nimport { DIALOG_DATA, DialogRef } from '@angular/cdk/dialog';\nimport { ComponentPortal, ComponentType, Portal, TemplatePortal } from '@angular/cdk/portal';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  HostBinding,\n  Inject,\n  TemplateRef,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { AXNotificationButtonItem, AXNotificationData } from './notification.class';\n\n/**\n * The Button is a component which detects user interaction and triggers a corresponding event\n *\n * @category Components\n */\n@Component({\n  selector: 'ax-notification',\n  templateUrl: './notification.component.html',\n  styleUrls: ['./notification.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  providers: [{ provide: AXClosbaleComponent, useExisting: AXNotificationComponent }],\n})\nexport class AXNotificationComponent extends MXBaseComponent {\n  /** @ignore */\n  _selectedPortal: Portal<unknown>;\n\n  /** @ignore */\n  _icon: string;\n\n  /**\n   *  @ignore\n   */\n  constructor(\n    @Inject(DIALOG_DATA)\n    public config: AXNotificationData,\n    public dialogRef: DialogRef<AXComponentCloseEvent>,\n  ) {\n    super();\n  }\n\n  /** @ignore */\n  override ngOnInit() {\n    super.ngOnInit();\n    this._initContent();\n    this._initIcon();\n    this._handleTimeOut();\n  }\n\n  /** @ignore */\n  private _handleTimeOut() {\n    if (this.config.timeOut) {\n      setTimeout(() => {\n        this.close();\n      }, this.config.timeOut);\n    }\n  }\n\n  /** @ignore */\n  private _initContent() {\n    if (this.config.content instanceof TemplateRef) {\n      this._selectedPortal = new TemplatePortal(\n        this.config.content as TemplateRef<unknown>,\n        this.getViewContainer(),\n      );\n      this.cdr.markForCheck();\n    } else if (typeof this.config.content === 'function') {\n      this._selectedPortal = new ComponentPortal(this.config.content as ComponentType<unknown>);\n      this.cdr.markForCheck();\n    }\n  }\n\n  /** @ignore */\n  private _initIcon() {\n    if (!this.config.icon) {\n      switch (this.config.color) {\n        case 'success':\n          this._icon = 'ax-icon ax-icon-check-circle';\n          break;\n        case 'danger':\n          this._icon = 'ax-icon ax-icon-error';\n          break;\n        case 'warning':\n          this._icon = 'ax-icon ax-icon-warning';\n          break;\n        case 'info':\n          this._icon = 'ax-icon ax-icon-info';\n          break;\n        default:\n          this._icon = this.config.icon || 'ax-icon ax-icon-check-circle';\n          break;\n      }\n    } else {\n      this._icon = this.config.icon;\n    }\n  }\n\n  /** @ignore */\n  protected _handleButtonClick(button: AXNotificationButtonItem) {\n    if (button.onClick) {\n      button.onClick({ source: button });\n    }\n  }\n\n  /** @ignore */\n  @HostBinding('class')\n  private get __hostClass(): string {\n    return `ax-${this.config.color}`;\n  }\n\n  /**\n   * Closes the dialog and provides the component and HTML element for reference.\n   */\n  close() {\n    this.dialogRef.close({\n      component: this,\n      htmlElement: this.getHostElement(),\n    });\n  }\n}\n","<span class=\"ax-notification-icon ax-icon-solid {{ _icon }}\"></span>\n<div class=\"ax-notification-content\">\n  <div class=\"ax-notification-title\">{{ config.title | translate | async }}</div>\n  @if(_selectedPortal){\n  <ng-template [cdkPortalOutlet]=\"_selectedPortal\"></ng-template>\n  } @else{\n  <div>{{ config.content }}</div>\n  }\n\n  @if(config.buttons?.length){\n  <div class=\"ax-notification-buttons\">\n    @for(button of config.buttons; track $index){\n    <ax-button class=\"ax-xs\" [text]=\"button.text | translate | async\" [color]=\"button.color\" [look]=\"button.look\"\n      [disabled]=\"button.disabled\" (onClick)=\"_handleButtonClick(button)\">\n      @if(button.loading){\n      <ax-loading></ax-loading>\n      }\n    </ax-button>\n    }\n  </div>\n  }\n\n</div>\n@if(config.closeButton){\n<ax-close-button></ax-close-button>\n}\n@if(config.timeOutProgress && config.timeOut){\n<div class=\"ax-notification-progress\" [style.animation-duration.ms]=\"config.timeOut\"></div>\n}"]}
|
@@ -9,6 +9,7 @@ export const AXNotificationDefaultConfig = {
|
|
9
9
|
timeOutProgress: true,
|
10
10
|
closeButton: true,
|
11
11
|
location: 'top-end',
|
12
|
+
limit: 3,
|
12
13
|
};
|
13
14
|
export function notificationConfig(config = {}) {
|
14
15
|
const result = {
|
@@ -17,4 +18,4 @@ export function notificationConfig(config = {}) {
|
|
17
18
|
};
|
18
19
|
return result;
|
19
20
|
}
|
20
|
-
//# sourceMappingURL=data:application/json;base64,
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm90aWZpY2F0aW9uLmNvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9ub3RpZmljYXRpb24vc3JjL2xpYi9ub3RpZmljYXRpb24uY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFXL0MsTUFBTSxDQUFDLE1BQU0sc0JBQXNCLEdBQUcsSUFBSSxjQUFjLENBQXVCLHdCQUF3QixFQUFFO0lBQ3ZHLFVBQVUsRUFBRSxNQUFNO0lBQ2xCLE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQywyQkFBMkI7Q0FDM0MsQ0FBQyxDQUFDO0FBRUgsTUFBTSxDQUFDLE1BQU0sMkJBQTJCLEdBQXlCO0lBQy9ELEdBQUcsRUFBRSxDQUFDO0lBQ04sT0FBTyxFQUFFLElBQUk7SUFDYixlQUFlLEVBQUUsSUFBSTtJQUNyQixXQUFXLEVBQUUsSUFBSTtJQUNqQixRQUFRLEVBQUUsU0FBUztJQUNuQixLQUFLLEVBQUUsQ0FBQztDQUNULENBQUM7QUFJRixNQUFNLFVBQVUsa0JBQWtCLENBQUMsU0FBb0MsRUFBRTtJQUN2RSxNQUFNLE1BQU0sR0FBRztRQUNiLEdBQUcsMkJBQTJCO1FBQzlCLEdBQUcsTUFBTTtLQUNWLENBQUM7SUFDRixPQUFPLE1BQU0sQ0FBQztBQUNoQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQVhMb2NhdGlvbiB9IGZyb20gJ0BhY29yZXgvY29tcG9uZW50cy9jb21tb24nO1xuaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuZXhwb3J0IGludGVyZmFjZSBBWE5vdGlmaWNhdGlvbkNvbmZpZyB7XG4gIGdhcDogbnVtYmVyO1xuICB0aW1lT3V0OiBudW1iZXI7XG4gIHRpbWVPdXRQcm9ncmVzczogYm9vbGVhbjtcbiAgbG9jYXRpb246IEFYTG9jYXRpb247XG4gIGNsb3NlQnV0dG9uOiBib29sZWFuO1xuICBsaW1pdDogbnVtYmVyO1xufVxuXG5leHBvcnQgY29uc3QgQVhfTk9USUZJQ0FUSU9OX0NPTkZJRyA9IG5ldyBJbmplY3Rpb25Ub2tlbjxBWE5vdGlmaWNhdGlvbkNvbmZpZz4oJ0FYX05PVElGSUNBVElPTl9DT05GSUcnLCB7XG4gIHByb3ZpZGVkSW46ICdyb290JyxcbiAgZmFjdG9yeTogKCkgPT4gQVhOb3RpZmljYXRpb25EZWZhdWx0Q29uZmlnLFxufSk7XG5cbmV4cG9ydCBjb25zdCBBWE5vdGlmaWNhdGlvbkRlZmF1bHRDb25maWc6IEFYTm90aWZpY2F0aW9uQ29uZmlnID0ge1xuICBnYXA6IDUsXG4gIHRpbWVPdXQ6IDI1MDAsXG4gIHRpbWVPdXRQcm9ncmVzczogdHJ1ZSxcbiAgY2xvc2VCdXR0b246IHRydWUsXG4gIGxvY2F0aW9uOiAndG9wLWVuZCcsXG4gIGxpbWl0OiAzLFxufTtcblxuZXhwb3J0IHR5cGUgUGFydGlhbE5vdGlmaWNhdGlvbkNvbmZpZyA9IFBhcnRpYWw8QVhOb3RpZmljYXRpb25Db25maWc+O1xuXG5leHBvcnQgZnVuY3Rpb24gbm90aWZpY2F0aW9uQ29uZmlnKGNvbmZpZzogUGFydGlhbE5vdGlmaWNhdGlvbkNvbmZpZyA9IHt9KTogQVhOb3RpZmljYXRpb25Db25maWcge1xuICBjb25zdCByZXN1bHQgPSB7XG4gICAgLi4uQVhOb3RpZmljYXRpb25EZWZhdWx0Q29uZmlnLFxuICAgIC4uLmNvbmZpZyxcbiAgfTtcbiAgcmV0dXJuIHJlc3VsdDtcbn1cbiJdfQ==
|
@@ -1,6 +1,6 @@
|
|
1
1
|
import { Dialog } from '@angular/cdk/dialog';
|
2
2
|
import { GlobalPositionStrategy } from '@angular/cdk/overlay';
|
3
|
-
import { Injectable, inject } from '@angular/core';
|
3
|
+
import { Injectable, effect, inject, signal } from '@angular/core';
|
4
4
|
import { AXNotificationComponent } from './notification.component';
|
5
5
|
import { AX_NOTIFICATION_CONFIG } from './notification.config';
|
6
6
|
import * as i0 from "@angular/core";
|
@@ -8,43 +8,41 @@ export class AXNotificationService {
|
|
8
8
|
constructor() {
|
9
9
|
this.dialog = inject(Dialog);
|
10
10
|
this.defaultConfig = inject(AX_NOTIFICATION_CONFIG);
|
11
|
+
this.activeNotifications = signal([]);
|
12
|
+
this.reservedNotifications = signal([]);
|
13
|
+
this.notificationCounterElement = signal(null);
|
14
|
+
this.moreNotificationsColor = signal('primary');
|
15
|
+
this.moreNotificationsLocation = signal('bottom-center');
|
16
|
+
this.reserveCounter = signal(0);
|
17
|
+
this.#effect = effect(() => {
|
18
|
+
if (this.defaultConfig.limit <= 0)
|
19
|
+
return;
|
20
|
+
this.handleShowReservedNotification();
|
21
|
+
this.handleShowReservedNotificationCounter();
|
22
|
+
this.handleReserveCounter();
|
23
|
+
}, { allowSignalWrites: true });
|
11
24
|
}
|
25
|
+
#effect;
|
12
26
|
show(config) {
|
13
27
|
config = Object.assign({
|
14
28
|
closeButton: true,
|
15
29
|
location: this.defaultConfig.location,
|
16
30
|
}, config);
|
31
|
+
this.moreNotificationsColor.set(config.color);
|
32
|
+
this.moreNotificationsLocation.set(config.location);
|
33
|
+
if (this.defaultConfig.limit > 0) {
|
34
|
+
if (this.activeNotifications().length >= this.defaultConfig.limit) {
|
35
|
+
this.reservedNotifications.update((value) => [...value, config]);
|
36
|
+
return {
|
37
|
+
close: () => {
|
38
|
+
//TODO close reserved notification
|
39
|
+
},
|
40
|
+
};
|
41
|
+
}
|
42
|
+
}
|
17
43
|
const gap = this.defaultConfig.gap;
|
18
|
-
let positionStrategy = new GlobalPositionStrategy();
|
19
44
|
const pos = this.getPosition(config.location) + gap + 'px';
|
20
|
-
|
21
|
-
case 'bottom-center':
|
22
|
-
positionStrategy = positionStrategy.bottom(pos).centerHorizontally();
|
23
|
-
break;
|
24
|
-
case 'bottom-end':
|
25
|
-
positionStrategy = positionStrategy.bottom(pos).right(gap + 'px');
|
26
|
-
break;
|
27
|
-
case 'bottom-start':
|
28
|
-
positionStrategy = positionStrategy.bottom(pos).left(gap + 'px');
|
29
|
-
break;
|
30
|
-
case 'top-center':
|
31
|
-
positionStrategy = positionStrategy.top(pos).centerHorizontally();
|
32
|
-
break;
|
33
|
-
case 'top-end':
|
34
|
-
positionStrategy = positionStrategy.top(pos).right(gap + 'px');
|
35
|
-
break;
|
36
|
-
case 'top-start':
|
37
|
-
positionStrategy = positionStrategy.top(pos).left(gap + 'px');
|
38
|
-
break;
|
39
|
-
case 'center-start':
|
40
|
-
positionStrategy = positionStrategy.centerVertically().left(gap + 'px');
|
41
|
-
break;
|
42
|
-
case 'center-end':
|
43
|
-
positionStrategy = positionStrategy.centerVertically().right(gap + 'px');
|
44
|
-
break;
|
45
|
-
default:
|
46
|
-
break;
|
47
|
-
}
|
45
|
+
const positionStrategy = this.getPositionStrategy(new GlobalPositionStrategy(), config.location, pos, gap);
|
48
46
|
const dialogRef = this.dialog.open(AXNotificationComponent, {
|
49
47
|
data: config,
|
50
48
|
autoFocus: '__no_element__',
|
@@ -55,23 +53,97 @@ export class AXNotificationService {
|
|
55
53
|
closeOnDestroy: true,
|
56
54
|
hasBackdrop: false,
|
57
55
|
panelClass: ['ax-animate-animated', 'ax-animate-fadeIn', 'ax-animate-faster'],
|
58
|
-
positionStrategy
|
56
|
+
positionStrategy,
|
59
57
|
});
|
60
|
-
|
58
|
+
this.activeNotifications.update((value) => [...value, dialogRef.id]);
|
59
|
+
const notificationRef = dialogRef.componentInstance;
|
61
60
|
dialogRef.closed.subscribe(() => {
|
62
|
-
this.
|
61
|
+
this.activeNotifications.update((value) => [...value].filter((dialogID) => dialogID !== dialogRef.id));
|
62
|
+
setTimeout(() => {
|
63
|
+
this.reposition(config.location, gap);
|
64
|
+
}, 0);
|
63
65
|
});
|
64
66
|
return {
|
65
67
|
close: () => {
|
66
|
-
|
68
|
+
notificationRef.close();
|
67
69
|
},
|
68
70
|
};
|
69
71
|
}
|
70
72
|
hideAll() {
|
71
73
|
this.dialog.closeAll();
|
72
74
|
}
|
73
|
-
|
74
|
-
|
75
|
+
handleShowReservedNotification() {
|
76
|
+
if (this.activeNotifications().length > this.defaultConfig.limit - 1)
|
77
|
+
return;
|
78
|
+
if (!this.reservedNotifications().length)
|
79
|
+
return;
|
80
|
+
this.show(this.reservedNotifications()[0]);
|
81
|
+
this.reservedNotifications.update((value) => {
|
82
|
+
const arr = [...value];
|
83
|
+
arr.shift();
|
84
|
+
return arr;
|
85
|
+
});
|
86
|
+
}
|
87
|
+
handleShowReservedNotificationCounter() {
|
88
|
+
if (this.reservedNotifications().length === this.reserveCounter())
|
89
|
+
return;
|
90
|
+
this.reserveCounter.set(this.reservedNotifications().length);
|
91
|
+
if (this.notificationCounterElement() !== null)
|
92
|
+
this.notificationCounterElement().close();
|
93
|
+
this.createReservedCounterToast();
|
94
|
+
}
|
95
|
+
handleReserveCounter() {
|
96
|
+
if (this.reserveCounter() !== 0)
|
97
|
+
return;
|
98
|
+
if (this.notificationCounterElement() === null)
|
99
|
+
return;
|
100
|
+
this.notificationCounterElement().close();
|
101
|
+
}
|
102
|
+
createReservedCounterToast() {
|
103
|
+
const opt = {
|
104
|
+
closeButton: false,
|
105
|
+
color: this.moreNotificationsColor(),
|
106
|
+
location: this.moreNotificationsLocation(),
|
107
|
+
title: `And ${this.reserveCounter()} more...`,
|
108
|
+
timeOutProgress: false,
|
109
|
+
};
|
110
|
+
const gap = this.defaultConfig.gap;
|
111
|
+
const pos = this.getPosition(opt.location) + gap + 'px';
|
112
|
+
const positionStrategy = this.getPositionStrategy(new GlobalPositionStrategy(), opt.location, pos, gap);
|
113
|
+
const dialogRef = this.dialog.open(AXNotificationComponent, {
|
114
|
+
data: opt,
|
115
|
+
autoFocus: '__no_element__',
|
116
|
+
restoreFocus: true,
|
117
|
+
role: 'dialog',
|
118
|
+
ariaModal: true,
|
119
|
+
closeOnNavigation: true,
|
120
|
+
closeOnDestroy: true,
|
121
|
+
hasBackdrop: false,
|
122
|
+
panelClass: ['ax-animate-animated', 'ax-animate-fadeIn', 'ax-animate-faster'],
|
123
|
+
positionStrategy,
|
124
|
+
});
|
125
|
+
this.notificationCounterElement.set(dialogRef.componentInstance);
|
126
|
+
}
|
127
|
+
reposition(notificationLocation, gap) {
|
128
|
+
const list = this.dialog.openDialogs
|
129
|
+
.map((c) => c.componentInstance)
|
130
|
+
.filter((c) => c.config?.location == notificationLocation);
|
131
|
+
list.forEach((element, index) => {
|
132
|
+
const pos = this.getRepositionPosition(index, gap, list, notificationLocation);
|
133
|
+
this.getPositionStrategy(element.dialogRef.config.positionStrategy, notificationLocation, pos, gap).apply();
|
134
|
+
});
|
135
|
+
}
|
136
|
+
getRepositionPosition(index, gap, list, notificationLocation) {
|
137
|
+
if (index === 0)
|
138
|
+
return gap + 'px';
|
139
|
+
const previouseElement = list[index - 1];
|
140
|
+
if (notificationLocation.split('-')[0] == 'bottom') {
|
141
|
+
return window.innerHeight - previouseElement.getHostElement().offsetTop + gap + 'px';
|
142
|
+
}
|
143
|
+
return (previouseElement.getHostElement().offsetTop +
|
144
|
+
previouseElement.getHostElement().offsetHeight +
|
145
|
+
gap +
|
146
|
+
'px');
|
75
147
|
}
|
76
148
|
getPosition(location) {
|
77
149
|
const list = this.dialog.openDialogs
|
@@ -82,8 +154,34 @@ export class AXNotificationService {
|
|
82
154
|
if (location.split('-')[0] == 'bottom') {
|
83
155
|
return window.innerHeight - list[list.length - 1].getHostElement().offsetTop;
|
84
156
|
}
|
85
|
-
|
86
|
-
|
157
|
+
return (list[list.length - 1].getHostElement().offsetTop + list[list.length - 1].getHostElement().offsetHeight);
|
158
|
+
}
|
159
|
+
getPositionStrategy(positionStrategy, location, pos, gap) {
|
160
|
+
switch (location) {
|
161
|
+
case 'bottom-center':
|
162
|
+
return positionStrategy.bottom(pos).centerHorizontally();
|
163
|
+
break;
|
164
|
+
case 'bottom-end':
|
165
|
+
return positionStrategy.bottom(pos).right(gap + 'px');
|
166
|
+
break;
|
167
|
+
case 'bottom-start':
|
168
|
+
return positionStrategy.bottom(pos).left(gap + 'px');
|
169
|
+
break;
|
170
|
+
case 'top-center':
|
171
|
+
return positionStrategy.top(pos).centerHorizontally();
|
172
|
+
break;
|
173
|
+
case 'top-end':
|
174
|
+
return positionStrategy.top(pos).right(gap + 'px');
|
175
|
+
break;
|
176
|
+
case 'top-start':
|
177
|
+
return positionStrategy.top(pos).left(gap + 'px');
|
178
|
+
break;
|
179
|
+
case 'center-start':
|
180
|
+
return positionStrategy.centerVertically().left(gap + 'px');
|
181
|
+
break;
|
182
|
+
case 'center-end':
|
183
|
+
return positionStrategy.centerVertically().right(gap + 'px');
|
184
|
+
break;
|
87
185
|
}
|
88
186
|
}
|
89
187
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXNotificationService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
@@ -92,4 +190,4 @@ export class AXNotificationService {
|
|
92
190
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXNotificationService, decorators: [{
|
93
191
|
type: Injectable
|
94
192
|
}] });
|
95
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notification.service.js","sourceRoot":"","sources":["../../../../../../libs/components/notification/src/lib/notification.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAC7C,OAAO,EAAE,sBAAsB,EAAE,MAAM,sBAAsB,CAAC;AAC9D,OAAO,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEnD,OAAO,EAAE,uBAAuB,EAAE,MAAM,0BAA0B,CAAC;AACnE,OAAO,EAAwB,sBAAsB,EAAE,MAAM,uBAAuB,CAAC;;AAGrF,MAAM,OAAO,qBAAqB;IADlC;QAEU,WAAM,GAAW,MAAM,CAAC,MAAM,CAAC,CAAC;QAChC,kBAAa,GAAyB,MAAM,CAAC,sBAAsB,CAAC,CAAC;KAuF9E;IArFC,IAAI,CAAC,MAAmC;QACtC,MAAM,GAAG,MAAM,CAAC,MAAM,CACpB;YACE,WAAW,EAAE,IAAI;YACjB,QAAQ,EAAE,IAAI,CAAC,aAAa,CAAC,QAAQ;SACtC,EACD,MAAM,CACP,CAAC;QACF,MAAM,GAAG,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC;QAEnC,IAAI,gBAAgB,GAAG,IAAI,sBAAsB,EAAE,CAAC;QACpD,MAAM,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,QAAQ,CAAC,GAAG,GAAG,GAAG,IAAI,CAAC;QAC3D,QAAQ,MAAM,CAAC,QAAQ,EAAE,CAAC;YACxB,KAAK,eAAe;gBAClB,gBAAgB,GAAG,gBAAgB,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,kBAAkB,EAAE,CAAC;gBACrE,MAAM;YACR,KAAK,YAAY;gBACf,gBAAgB,GAAG,gBAAgB,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,GAAG,GAAG,IAAI,CAAC,CAAC;gBAClE,MAAM;YACR,KAAK,cAAc;gBACjB,gBAAgB,GAAG,gBAAgB,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,CAAC;gBACjE,MAAM;YACR,KAAK,YAAY;gBACf,gBAAgB,GAAG,gBAAgB,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,kBAAkB,EAAE,CAAC;gBAClE,MAAM;YACR,KAAK,SAAS;gBACZ,gBAAgB,GAAG,gBAAgB,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,GAAG,GAAG,IAAI,CAAC,CAAC;gBAC/D,MAAM;YACR,KAAK,WAAW;gBACd,gBAAgB,GAAG,gBAAgB,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,CAAC;gBAC9D,MAAM;YACR,KAAK,cAAc;gBACjB,gBAAgB,GAAG,gBAAgB,CAAC,gBAAgB,EAAE,CAAC,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,CAAC;gBACxE,MAAM;YACR,KAAK,YAAY;gBACf,gBAAgB,GAAG,gBAAgB,CAAC,gBAAgB,EAAE,CAAC,KAAK,CAAC,GAAG,GAAG,IAAI,CAAC,CAAC;gBACzE,MAAM;YACR;gBACE,MAAM;QACV,CAAC;QAED,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,uBAAuB,EAAE;YAC1D,IAAI,EAAE,MAAM;YACZ,SAAS,EAAE,gBAAgB;YAC3B,YAAY,EAAE,KAAK;YACnB,IAAI,EAAE,QAAQ;YACd,SAAS,EAAE,IAAI;YACf,iBAAiB,EAAE,IAAI;YACvB,cAAc,EAAE,IAAI;YACpB,WAAW,EAAE,KAAK;YAClB,UAAU,EAAE,CAAC,qBAAqB,EAAE,mBAAmB,EAAE,mBAAmB,CAAC;YAC7E,gBAAgB,EAAE,gBAAgB;SACnC,CAAC,CAAC;QAEH,MAAM,QAAQ,GAAG,SAAS,CAAC,iBAA4C,CAAC;QACxE,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,EAAE;YAC9B,IAAI,CAAC,UAAU,EAAE,CAAC;QACpB,CAAC,CAAC,CAAC;QAEH,OAAO;YACL,KAAK,EAAE,GAAG,EAAE;gBACV,QAAQ,CAAC,KAAK,EAAE,CAAC;YACnB,CAAC;SACF,CAAC;IACJ,CAAC;IAEM,OAAO;QACZ,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;IACzB,CAAC;IAEO,UAAU;QAChB,8CAA8C;IAChD,CAAC;IAEO,WAAW,CAAC,QAAgB;QAClC,MAAM,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,WAAW;aACjC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,iBAA4C,CAAC;aAC1D,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,IAAI,QAAQ,CAAC,CAAC;QAChD,IAAI,IAAI,CAAC,MAAM,IAAI,CAAC;YAAE,OAAO,CAAC,CAAC;QAC/B,IAAI,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,QAAQ,EAAE,CAAC;YACvC,OAAO,MAAM,CAAC,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,cAAc,EAAE,CAAC,SAAS,CAAC;QAC/E,CAAC;aAAM,CAAC;YACN,OAAO,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,cAAc,EAAE,CAAC,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,cAAc,EAAE,CAAC,YAAY,CAAC;QAChH,CAAC;IACH,CAAC;8GAxFU,qBAAqB;kHAArB,qBAAqB;;2FAArB,qBAAqB;kBADjC,UAAU","sourcesContent":["import { Dialog } from '@angular/cdk/dialog';\nimport { GlobalPositionStrategy } from '@angular/cdk/overlay';\nimport { Injectable, inject } from '@angular/core';\nimport { AXNotificationOptions as AXNotificationDisplayConfig, AXNotificationRef } from './notification.class';\nimport { AXNotificationComponent } from './notification.component';\nimport { AXNotificationConfig, AX_NOTIFICATION_CONFIG } from './notification.config';\n\n@Injectable()\nexport class AXNotificationService {\n  private dialog: Dialog = inject(Dialog);\n  private defaultConfig: AXNotificationConfig = inject(AX_NOTIFICATION_CONFIG);\n\n  show(config: AXNotificationDisplayConfig): AXNotificationRef {\n    config = Object.assign(\n      {\n        closeButton: true,\n        location: this.defaultConfig.location,\n      },\n      config,\n    );\n    const gap = this.defaultConfig.gap;\n\n    let positionStrategy = new GlobalPositionStrategy();\n    const pos = this.getPosition(config.location) + gap + 'px';\n    switch (config.location) {\n      case 'bottom-center':\n        positionStrategy = positionStrategy.bottom(pos).centerHorizontally();\n        break;\n      case 'bottom-end':\n        positionStrategy = positionStrategy.bottom(pos).right(gap + 'px');\n        break;\n      case 'bottom-start':\n        positionStrategy = positionStrategy.bottom(pos).left(gap + 'px');\n        break;\n      case 'top-center':\n        positionStrategy = positionStrategy.top(pos).centerHorizontally();\n        break;\n      case 'top-end':\n        positionStrategy = positionStrategy.top(pos).right(gap + 'px');\n        break;\n      case 'top-start':\n        positionStrategy = positionStrategy.top(pos).left(gap + 'px');\n        break;\n      case 'center-start':\n        positionStrategy = positionStrategy.centerVertically().left(gap + 'px');\n        break;\n      case 'center-end':\n        positionStrategy = positionStrategy.centerVertically().right(gap + 'px');\n        break;\n      default:\n        break;\n    }\n\n    const dialogRef = this.dialog.open(AXNotificationComponent, {\n      data: config,\n      autoFocus: '__no_element__',\n      restoreFocus: false,\n      role: 'dialog',\n      ariaModal: true,\n      closeOnNavigation: true,\n      closeOnDestroy: true,\n      hasBackdrop: false,\n      panelClass: ['ax-animate-animated', 'ax-animate-fadeIn', 'ax-animate-faster'],\n      positionStrategy: positionStrategy,\n    });\n\n    const toastRef = dialogRef.componentInstance as AXNotificationComponent;\n    dialogRef.closed.subscribe(() => {\n      this.reposition();\n    });\n\n    return {\n      close: () => {\n        toastRef.close();\n      },\n    };\n  }\n\n  public hideAll() {\n    this.dialog.closeAll();\n  }\n\n  private reposition(): void {\n    //TODO: reposition vertically afer close toast\n  }\n\n  private getPosition(location: string) {\n    const list = this.dialog.openDialogs\n      .map((c) => c.componentInstance as AXNotificationComponent)\n      .filter((c) => c.config.location == location);\n    if (list.length == 0) return 0;\n    if (location.split('-')[0] == 'bottom') {\n      return window.innerHeight - list[list.length - 1].getHostElement().offsetTop;\n    } else {\n      return list[list.length - 1].getHostElement().offsetTop + list[list.length - 1].getHostElement().offsetHeight;\n    }\n  }\n}\n"]}
|
193
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notification.service.js","sourceRoot":"","sources":["../../../../../../libs/components/notification/src/lib/notification.service.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAC7C,OAAO,EAAE,sBAAsB,EAAE,MAAM,sBAAsB,CAAC;AAC9D,OAAO,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAKnE,OAAO,EAAE,uBAAuB,EAAE,MAAM,0BAA0B,CAAC;AACnE,OAAO,EAAwB,sBAAsB,EAAE,MAAM,uBAAuB,CAAC;;AAGrF,MAAM,OAAO,qBAAqB;IADlC;QAEU,WAAM,GAAW,MAAM,CAAC,MAAM,CAAC,CAAC;QAChC,kBAAa,GAAyB,MAAM,CAAC,sBAAsB,CAAC,CAAC;QACrE,wBAAmB,GAAG,MAAM,CAAW,EAAE,CAAC,CAAC;QAC3C,0BAAqB,GAAG,MAAM,CAAgC,EAAE,CAAC,CAAC;QAClE,+BAA0B,GAAG,MAAM,CAAiC,IAAI,CAAC,CAAC;QAC1E,2BAAsB,GAAG,MAAM,CAAmB,SAAS,CAAC,CAAC;QAC7D,8BAAyB,GAAG,MAAM,CAAa,eAAe,CAAC,CAAC;QAChE,mBAAc,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QAEnC,YAAO,GAAG,MAAM,CACd,GAAG,EAAE;YACH,IAAI,IAAI,CAAC,aAAa,CAAC,KAAK,IAAI,CAAC;gBAAE,OAAO;YAC1C,IAAI,CAAC,8BAA8B,EAAE,CAAC;YACtC,IAAI,CAAC,qCAAqC,EAAE,CAAC;YAC7C,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC9B,CAAC,EACD,EAAE,iBAAiB,EAAE,IAAI,EAAE,CAC5B,CAAC;KA2MH;IAnNC,OAAO,CAQL;IAEF,IAAI,CAAC,MAAmC;QACtC,MAAM,GAAG,MAAM,CAAC,MAAM,CACpB;YACE,WAAW,EAAE,IAAI;YACjB,QAAQ,EAAE,IAAI,CAAC,aAAa,CAAC,QAAQ;SACtC,EACD,MAAM,CACP,CAAC;QACF,IAAI,CAAC,sBAAsB,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QAC9C,IAAI,CAAC,yBAAyB,CAAC,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QAEpD,IAAI,IAAI,CAAC,aAAa,CAAC,KAAK,GAAG,CAAC,EAAE,CAAC;YACjC,IAAI,IAAI,CAAC,mBAAmB,EAAE,CAAC,MAAM,IAAI,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;gBAClE,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,GAAG,KAAK,EAAE,MAAM,CAAC,CAAC,CAAC;gBACjE,OAAO;oBACL,KAAK,EAAE,GAAG,EAAE;wBACV,kCAAkC;oBACpC,CAAC;iBACF,CAAC;YACJ,CAAC;QACH,CAAC;QAED,MAAM,GAAG,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC;QACnC,MAAM,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,QAAQ,CAAC,GAAG,GAAG,GAAG,IAAI,CAAC;QAC3D,MAAM,gBAAgB,GAAG,IAAI,CAAC,mBAAmB,CAC/C,IAAI,sBAAsB,EAAE,EAC5B,MAAM,CAAC,QAAQ,EACf,GAAG,EACH,GAAG,CACJ,CAAC;QACF,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,uBAAuB,EAAE;YAC1D,IAAI,EAAE,MAAM;YACZ,SAAS,EAAE,gBAAgB;YAC3B,YAAY,EAAE,KAAK;YACnB,IAAI,EAAE,QAAQ;YACd,SAAS,EAAE,IAAI;YACf,iBAAiB,EAAE,IAAI;YACvB,cAAc,EAAE,IAAI;YACpB,WAAW,EAAE,KAAK;YAClB,UAAU,EAAE,CAAC,qBAAqB,EAAE,mBAAmB,EAAE,mBAAmB,CAAC;YAC7E,gBAAgB;SACjB,CAAC,CAAC;QAEH,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,GAAG,KAAK,EAAE,SAAS,CAAC,EAAE,CAAC,CAAC,CAAC;QAErE,MAAM,eAAe,GAAG,SAAS,CAAC,iBAA4C,CAAC;QAC/E,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,EAAE;YAC9B,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,KAAK,SAAS,CAAC,EAAE,CAAC,CAAC,CAAC;YACvG,UAAU,CAAC,GAAG,EAAE;gBACd,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;YACxC,CAAC,EAAE,CAAC,CAAC,CAAC;QACR,CAAC,CAAC,CAAC;QAEH,OAAO;YACL,KAAK,EAAE,GAAG,EAAE;gBACV,eAAe,CAAC,KAAK,EAAE,CAAC;YAC1B,CAAC;SACF,CAAC;IACJ,CAAC;IAED,OAAO;QACL,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;IACzB,CAAC;IAEO,8BAA8B;QACpC,IAAI,IAAI,CAAC,mBAAmB,EAAE,CAAC,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC,KAAK,GAAG,CAAC;YAAE,OAAO;QAC7E,IAAI,CAAC,IAAI,CAAC,qBAAqB,EAAE,CAAC,MAAM;YAAE,OAAO;QAEjD,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,qBAAqB,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QAC3C,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE;YAC1C,MAAM,GAAG,GAAG,CAAC,GAAG,KAAK,CAAC,CAAC;YACvB,GAAG,CAAC,KAAK,EAAE,CAAC;YACZ,OAAO,GAAG,CAAC;QACb,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,qCAAqC;QAC3C,IAAI,IAAI,CAAC,qBAAqB,EAAE,CAAC,MAAM,KAAK,IAAI,CAAC,cAAc,EAAE;YAAE,OAAO;QAE1E,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,IAAI,CAAC,qBAAqB,EAAE,CAAC,MAAM,CAAC,CAAC;QAE7D,IAAI,IAAI,CAAC,0BAA0B,EAAE,KAAK,IAAI;YAAE,IAAI,CAAC,0BAA0B,EAAE,CAAC,KAAK,EAAE,CAAC;QAE1F,IAAI,CAAC,0BAA0B,EAAE,CAAC;IACpC,CAAC;IAEO,oBAAoB;QAC1B,IAAI,IAAI,CAAC,cAAc,EAAE,KAAK,CAAC;YAAE,OAAO;QAExC,IAAI,IAAI,CAAC,0BAA0B,EAAE,KAAK,IAAI;YAAE,OAAO;QAEvD,IAAI,CAAC,0BAA0B,EAAE,CAAC,KAAK,EAAE,CAAC;IAC5C,CAAC;IAEO,0BAA0B;QAChC,MAAM,GAAG,GAAgC;YACvC,WAAW,EAAE,KAAK;YAClB,KAAK,EAAE,IAAI,CAAC,sBAAsB,EAAE;YACpC,QAAQ,EAAE,IAAI,CAAC,yBAAyB,EAAE;YAC1C,KAAK,EAAE,OAAO,IAAI,CAAC,cAAc,EAAE,UAAU;YAC7C,eAAe,EAAE,KAAK;SACvB,CAAC;QACF,MAAM,GAAG,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC;QACnC,MAAM,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,GAAG,GAAG,IAAI,CAAC;QACxD,MAAM,gBAAgB,GAAG,IAAI,CAAC,mBAAmB,CAAC,IAAI,sBAAsB,EAAE,EAAE,GAAG,CAAC,QAAQ,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;QACxG,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,uBAAuB,EAAE;YAC1D,IAAI,EAAE,GAAG;YACT,SAAS,EAAE,gBAAgB;YAC3B,YAAY,EAAE,IAAI;YAClB,IAAI,EAAE,QAAQ;YACd,SAAS,EAAE,IAAI;YACf,iBAAiB,EAAE,IAAI;YACvB,cAAc,EAAE,IAAI;YACpB,WAAW,EAAE,KAAK;YAClB,UAAU,EAAE,CAAC,qBAAqB,EAAE,mBAAmB,EAAE,mBAAmB,CAAC;YAC7E,gBAAgB;SACjB,CAAC,CAAC;QACH,IAAI,CAAC,0BAA0B,CAAC,GAAG,CAAC,SAAS,CAAC,iBAA4C,CAAC,CAAC;IAC9F,CAAC;IAEO,UAAU,CAAC,oBAAgC,EAAE,GAAW;QAC9D,MAAM,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,WAAW;aACjC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,iBAA4C,CAAC;aAC1D,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE,QAAQ,IAAI,oBAAoB,CAAC,CAAC;QAC7D,IAAI,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,KAAK,EAAE,EAAE;YAC9B,MAAM,GAAG,GAAG,IAAI,CAAC,qBAAqB,CAAC,KAAK,EAAE,GAAG,EAAE,IAAI,EAAE,oBAAoB,CAAC,CAAC;YAE/E,IAAI,CAAC,mBAAmB,CACtB,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,gBAA0C,EACnE,oBAAoB,EACpB,GAAG,EACH,GAAG,CACJ,CAAC,KAAK,EAAE,CAAC;QACZ,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,qBAAqB,CAC3B,KAAa,EACb,GAAW,EACX,IAA+B,EAC/B,oBAA4B;QAE5B,IAAI,KAAK,KAAK,CAAC;YAAE,OAAO,GAAG,GAAG,IAAI,CAAC;QACnC,MAAM,gBAAgB,GAAG,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;QACzC,IAAI,oBAAoB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,QAAQ,EAAE,CAAC;YACnD,OAAO,MAAM,CAAC,WAAW,GAAG,gBAAgB,CAAC,cAAc,EAAE,CAAC,SAAS,GAAG,GAAG,GAAG,IAAI,CAAC;QACvF,CAAC;QACD,OAAO,CACL,gBAAgB,CAAC,cAAc,EAAE,CAAC,SAAS;YAC3C,gBAAgB,CAAC,cAAc,EAAE,CAAC,YAAY;YAC9C,GAAG;YACH,IAAI,CACL,CAAC;IACJ,CAAC;IAEO,WAAW,CAAC,QAAgB;QAClC,MAAM,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,WAAW;aACjC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,iBAA4C,CAAC;aAC1D,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,IAAI,QAAQ,CAAC,CAAC;QAChD,IAAI,IAAI,CAAC,MAAM,IAAI,CAAC;YAAE,OAAO,CAAC,CAAC;QAC/B,IAAI,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,QAAQ,EAAE,CAAC;YACvC,OAAO,MAAM,CAAC,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,cAAc,EAAE,CAAC,SAAS,CAAC;QAC/E,CAAC;QACD,OAAO,CACL,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,cAAc,EAAE,CAAC,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,cAAc,EAAE,CAAC,YAAY,CACvG,CAAC;IACJ,CAAC;IAEO,mBAAmB,CACzB,gBAAwC,EACxC,QAAoB,EACpB,GAAW,EACX,GAAW;QAEX,QAAQ,QAAQ,EAAE,CAAC;YACjB,KAAK,eAAe;gBAClB,OAAO,gBAAgB,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,kBAAkB,EAAE,CAAC;gBACzD,MAAM;YACR,KAAK,YAAY;gBACf,OAAO,gBAAgB,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,GAAG,GAAG,IAAI,CAAC,CAAC;gBACtD,MAAM;YACR,KAAK,cAAc;gBACjB,OAAO,gBAAgB,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,CAAC;gBACrD,MAAM;YACR,KAAK,YAAY;gBACf,OAAO,gBAAgB,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,kBAAkB,EAAE,CAAC;gBACtD,MAAM;YACR,KAAK,SAAS;gBACZ,OAAO,gBAAgB,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,GAAG,GAAG,IAAI,CAAC,CAAC;gBACnD,MAAM;YACR,KAAK,WAAW;gBACd,OAAO,gBAAgB,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,CAAC;gBAClD,MAAM;YACR,KAAK,cAAc;gBACjB,OAAO,gBAAgB,CAAC,gBAAgB,EAAE,CAAC,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,CAAC;gBAC5D,MAAM;YACR,KAAK,YAAY;gBACf,OAAO,gBAAgB,CAAC,gBAAgB,EAAE,CAAC,KAAK,CAAC,GAAG,GAAG,IAAI,CAAC,CAAC;gBAC7D,MAAM;QACV,CAAC;IACH,CAAC;8GA5NU,qBAAqB;kHAArB,qBAAqB;;2FAArB,qBAAqB;kBADjC,UAAU","sourcesContent":["import { AXLocation, AXStyleColorType } from '@acorex/components/common';\nimport { Dialog } from '@angular/cdk/dialog';\nimport { GlobalPositionStrategy } from '@angular/cdk/overlay';\nimport { Injectable, effect, inject, signal } from '@angular/core';\nimport {\n  AXNotificationOptions as AXNotificationDisplayConfig,\n  AXNotificationRef,\n} from './notification.class';\nimport { AXNotificationComponent } from './notification.component';\nimport { AXNotificationConfig, AX_NOTIFICATION_CONFIG } from './notification.config';\n\n@Injectable()\nexport class AXNotificationService {\n  private dialog: Dialog = inject(Dialog);\n  private defaultConfig: AXNotificationConfig = inject(AX_NOTIFICATION_CONFIG);\n  private activeNotifications = signal<string[]>([]);\n  private reservedNotifications = signal<AXNotificationDisplayConfig[]>([]);\n  private notificationCounterElement = signal<AXNotificationComponent | null>(null);\n  private moreNotificationsColor = signal<AXStyleColorType>('primary');\n  private moreNotificationsLocation = signal<AXLocation>('bottom-center');\n  private reserveCounter = signal(0);\n\n  #effect = effect(\n    () => {\n      if (this.defaultConfig.limit <= 0) return;\n      this.handleShowReservedNotification();\n      this.handleShowReservedNotificationCounter();\n      this.handleReserveCounter();\n    },\n    { allowSignalWrites: true },\n  );\n\n  show(config: AXNotificationDisplayConfig): AXNotificationRef {\n    config = Object.assign(\n      {\n        closeButton: true,\n        location: this.defaultConfig.location,\n      },\n      config,\n    );\n    this.moreNotificationsColor.set(config.color);\n    this.moreNotificationsLocation.set(config.location);\n\n    if (this.defaultConfig.limit > 0) {\n      if (this.activeNotifications().length >= this.defaultConfig.limit) {\n        this.reservedNotifications.update((value) => [...value, config]);\n        return {\n          close: () => {\n            //TODO close reserved notification\n          },\n        };\n      }\n    }\n\n    const gap = this.defaultConfig.gap;\n    const pos = this.getPosition(config.location) + gap + 'px';\n    const positionStrategy = this.getPositionStrategy(\n      new GlobalPositionStrategy(),\n      config.location,\n      pos,\n      gap,\n    );\n    const dialogRef = this.dialog.open(AXNotificationComponent, {\n      data: config,\n      autoFocus: '__no_element__',\n      restoreFocus: false,\n      role: 'dialog',\n      ariaModal: true,\n      closeOnNavigation: true,\n      closeOnDestroy: true,\n      hasBackdrop: false,\n      panelClass: ['ax-animate-animated', 'ax-animate-fadeIn', 'ax-animate-faster'],\n      positionStrategy,\n    });\n\n    this.activeNotifications.update((value) => [...value, dialogRef.id]);\n\n    const notificationRef = dialogRef.componentInstance as AXNotificationComponent;\n    dialogRef.closed.subscribe(() => {\n      this.activeNotifications.update((value) => [...value].filter((dialogID) => dialogID !== dialogRef.id));\n      setTimeout(() => {\n        this.reposition(config.location, gap);\n      }, 0);\n    });\n\n    return {\n      close: () => {\n        notificationRef.close();\n      },\n    };\n  }\n\n  hideAll() {\n    this.dialog.closeAll();\n  }\n\n  private handleShowReservedNotification() {\n    if (this.activeNotifications().length > this.defaultConfig.limit - 1) return;\n    if (!this.reservedNotifications().length) return;\n\n    this.show(this.reservedNotifications()[0]);\n    this.reservedNotifications.update((value) => {\n      const arr = [...value];\n      arr.shift();\n      return arr;\n    });\n  }\n\n  private handleShowReservedNotificationCounter() {\n    if (this.reservedNotifications().length === this.reserveCounter()) return;\n\n    this.reserveCounter.set(this.reservedNotifications().length);\n\n    if (this.notificationCounterElement() !== null) this.notificationCounterElement().close();\n\n    this.createReservedCounterToast();\n  }\n\n  private handleReserveCounter() {\n    if (this.reserveCounter() !== 0) return;\n\n    if (this.notificationCounterElement() === null) return;\n\n    this.notificationCounterElement().close();\n  }\n\n  private createReservedCounterToast() {\n    const opt: AXNotificationDisplayConfig = {\n      closeButton: false,\n      color: this.moreNotificationsColor(),\n      location: this.moreNotificationsLocation(),\n      title: `And ${this.reserveCounter()} more...`,\n      timeOutProgress: false,\n    };\n    const gap = this.defaultConfig.gap;\n    const pos = this.getPosition(opt.location) + gap + 'px';\n    const positionStrategy = this.getPositionStrategy(new GlobalPositionStrategy(), opt.location, pos, gap);\n    const dialogRef = this.dialog.open(AXNotificationComponent, {\n      data: opt,\n      autoFocus: '__no_element__',\n      restoreFocus: true,\n      role: 'dialog',\n      ariaModal: true,\n      closeOnNavigation: true,\n      closeOnDestroy: true,\n      hasBackdrop: false,\n      panelClass: ['ax-animate-animated', 'ax-animate-fadeIn', 'ax-animate-faster'],\n      positionStrategy,\n    });\n    this.notificationCounterElement.set(dialogRef.componentInstance as AXNotificationComponent);\n  }\n\n  private reposition(notificationLocation: AXLocation, gap: number): void {\n    const list = this.dialog.openDialogs\n      .map((c) => c.componentInstance as AXNotificationComponent)\n      .filter((c) => c.config?.location == notificationLocation);\n    list.forEach((element, index) => {\n      const pos = this.getRepositionPosition(index, gap, list, notificationLocation);\n\n      this.getPositionStrategy(\n        element.dialogRef.config.positionStrategy as GlobalPositionStrategy,\n        notificationLocation,\n        pos,\n        gap,\n      ).apply();\n    });\n  }\n\n  private getRepositionPosition(\n    index: number,\n    gap: number,\n    list: AXNotificationComponent[],\n    notificationLocation: string,\n  ) {\n    if (index === 0) return gap + 'px';\n    const previouseElement = list[index - 1];\n    if (notificationLocation.split('-')[0] == 'bottom') {\n      return window.innerHeight - previouseElement.getHostElement().offsetTop + gap + 'px';\n    }\n    return (\n      previouseElement.getHostElement().offsetTop +\n      previouseElement.getHostElement().offsetHeight +\n      gap +\n      'px'\n    );\n  }\n\n  private getPosition(location: string) {\n    const list = this.dialog.openDialogs\n      .map((c) => c.componentInstance as AXNotificationComponent)\n      .filter((c) => c.config.location == location);\n    if (list.length == 0) return 0;\n    if (location.split('-')[0] == 'bottom') {\n      return window.innerHeight - list[list.length - 1].getHostElement().offsetTop;\n    }\n    return (\n      list[list.length - 1].getHostElement().offsetTop + list[list.length - 1].getHostElement().offsetHeight\n    );\n  }\n\n  private getPositionStrategy(\n    positionStrategy: GlobalPositionStrategy,\n    location: AXLocation,\n    pos: string,\n    gap: number,\n  ) {\n    switch (location) {\n      case 'bottom-center':\n        return positionStrategy.bottom(pos).centerHorizontally();\n        break;\n      case 'bottom-end':\n        return positionStrategy.bottom(pos).right(gap + 'px');\n        break;\n      case 'bottom-start':\n        return positionStrategy.bottom(pos).left(gap + 'px');\n        break;\n      case 'top-center':\n        return positionStrategy.top(pos).centerHorizontally();\n        break;\n      case 'top-end':\n        return positionStrategy.top(pos).right(gap + 'px');\n        break;\n      case 'top-start':\n        return positionStrategy.top(pos).left(gap + 'px');\n        break;\n      case 'center-start':\n        return positionStrategy.centerVertically().left(gap + 'px');\n        break;\n      case 'center-end':\n        return positionStrategy.centerVertically().right(gap + 'px');\n        break;\n    }\n  }\n}\n"]}
|
@@ -1,6 +1,6 @@
|
|
1
1
|
import { AXClosbaleComponent, MXBaseComponent } from '@acorex/components/common';
|
2
2
|
import { DIALOG_DATA, DialogRef } from '@angular/cdk/dialog';
|
3
|
-
import { ChangeDetectionStrategy, Component, HostBinding, Inject, ViewEncapsulation } from '@angular/core';
|
3
|
+
import { ChangeDetectionStrategy, Component, HostBinding, Inject, ViewEncapsulation, } from '@angular/core';
|
4
4
|
import * as i0 from "@angular/core";
|
5
5
|
import * as i1 from "@angular/cdk/dialog";
|
6
6
|
import * as i2 from "@acorex/components/decorators";
|
@@ -83,4 +83,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
|
|
83
83
|
type: HostBinding,
|
84
84
|
args: ['class']
|
85
85
|
}] } });
|
86
|
-
//# sourceMappingURL=data:application/json;base64,
|
86
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9hc3QuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL3RvYXN0L3NyYy9saWIvdG9hc3QuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL3RvYXN0L3NyYy9saWIvdG9hc3QuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLG1CQUFtQixFQUF5QixlQUFlLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUN4RyxPQUFPLEVBQUUsV0FBVyxFQUFFLFNBQVMsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQzdELE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULFdBQVcsRUFDWCxNQUFNLEVBRU4saUJBQWlCLEdBQ2xCLE1BQU0sZUFBZSxDQUFDOzs7Ozs7QUFHdkI7Ozs7R0FJRztBQVNILE1BQU0sT0FBTyxnQkFBaUIsU0FBUSxlQUFlO0lBT25EOztPQUVHO0lBQ0gsWUFFUyxNQUFtQixFQUNuQixTQUEyQztRQUVsRCxLQUFLLEVBQUUsQ0FBQztRQUhELFdBQU0sR0FBTixNQUFNLENBQWE7UUFDbkIsY0FBUyxHQUFULFNBQVMsQ0FBa0M7UUFacEQsY0FBYztRQUNKLGdCQUFXLEdBQUcsR0FBRyxDQUFDO0lBYzVCLENBQUM7SUFFRCxjQUFjO0lBQ0wsUUFBUTtRQUNmLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUNqQixJQUFJLElBQUksQ0FBQyxNQUFNLENBQUMsT0FBTyxFQUFFLENBQUM7WUFDeEIsVUFBVSxDQUFDLEdBQUcsRUFBRTtnQkFDZCxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7WUFDZixDQUFDLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUMxQixDQUFDO1FBQ0QsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxFQUFFLENBQUM7WUFDdEIsUUFBUSxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssRUFBRSxDQUFDO2dCQUMxQixLQUFLLFNBQVM7b0JBQ1osSUFBSSxDQUFDLEtBQUssR0FBRyw4QkFBOEIsQ0FBQztvQkFDNUMsTUFBTTtnQkFDUixLQUFLLFNBQVM7b0JBQ1osSUFBSSxDQUFDLEtBQUssR0FBRyx5QkFBeUIsQ0FBQztvQkFDdkMsTUFBTTtnQkFDUixLQUFLLFFBQVE7b0JBQ1gsSUFBSSxDQUFDLEtBQUssR0FBRyx1QkFBdUIsQ0FBQztvQkFDckMsTUFBTTtnQkFDUixLQUFLLE1BQU07b0JBQ1QsSUFBSSxDQUFDLEtBQUssR0FBRyxzQkFBc0IsQ0FBQztvQkFDcEMsTUFBTTtnQkFDUjtvQkFDRSxJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxJQUFJLDhCQUE4QixDQUFDO29CQUNoRSxNQUFNO1lBQ1YsQ0FBQztRQUNILENBQUM7YUFBTSxDQUFDO1lBQ04sSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQztRQUNoQyxDQUFDO0lBQ0gsQ0FBQztJQUVELGNBQWM7SUFDZCxrQkFBa0IsQ0FBQyxNQUFvQjtRQUNyQyxJQUFJLE1BQU0sQ0FBQyxPQUFPLEVBQUUsQ0FBQztZQUNuQixNQUFNLENBQUMsT0FBTyxDQUFDLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxDQUFDLENBQUM7UUFDckMsQ0FBQztJQUNILENBQUM7SUFFRCxjQUFjO0lBQ2QsSUFDWSxXQUFXO1FBQ3JCLE9BQU8sTUFBTSxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQ25DLENBQUM7SUFFRCxjQUFjO0lBQ2QsS0FBSztRQUNILElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDO1lBQ25CLFNBQVMsRUFBRSxJQUFJO1lBQ2YsV0FBVyxFQUFFLElBQUksQ0FBQyxjQUFjLEVBQUU7U0FDbkMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs4R0FwRVUsZ0JBQWdCLGtCQVdqQixXQUFXO2tHQVhWLGdCQUFnQiwwRkFGaEIsQ0FBQyxFQUFFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxXQUFXLEVBQUUsZ0JBQWdCLEVBQUUsQ0FBQyxpREN4QjlFLHdnQkFXQzs7MkZEZVksZ0JBQWdCO2tCQVI1QixTQUFTOytCQUNFLFVBQVUsbUJBR0gsdUJBQXVCLENBQUMsTUFBTSxpQkFDaEMsaUJBQWlCLENBQUMsSUFBSSxhQUMxQixDQUFDLEVBQUUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLFdBQVcsa0JBQWtCLEVBQUUsQ0FBQzs7MEJBYXpFLE1BQU07MkJBQUMsV0FBVztpRUErQ1QsV0FBVztzQkFEdEIsV0FBVzt1QkFBQyxPQUFPIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQVhCdXR0b25JdGVtIH0gZnJvbSAnQGFjb3JleC9jb21wb25lbnRzL2J1dHRvbic7XG5pbXBvcnQgeyBBWENsb3NiYWxlQ29tcG9uZW50LCBBWENvbXBvbmVudENsb3NlRXZlbnQsIE1YQmFzZUNvbXBvbmVudCB9IGZyb20gJ0BhY29yZXgvY29tcG9uZW50cy9jb21tb24nO1xuaW1wb3J0IHsgRElBTE9HX0RBVEEsIERpYWxvZ1JlZiB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9kaWFsb2cnO1xuaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgSG9zdEJpbmRpbmcsXG4gIEluamVjdCxcbiAgT25Jbml0LFxuICBWaWV3RW5jYXBzdWxhdGlvbixcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBWFRvYXN0RGF0YSB9IGZyb20gJy4vdG9hc3QuY2xhc3MnO1xuXG4vKipcbiAqIFRoZSBCdXR0b24gaXMgYSBjb21wb25lbnQgd2hpY2ggZGV0ZWN0cyB1c2VyIGludGVyYWN0aW9uIGFuZCB0cmlnZ2VycyBhIGNvcnJlc3BvbmRpbmcgZXZlbnRcbiAqXG4gKiBAY2F0ZWdvcnkgQ29tcG9uZW50c1xuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdheC10b2FzdCcsXG4gIHRlbXBsYXRlVXJsOiAnLi90b2FzdC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL3RvYXN0LmNvbXBvbmVudC5zY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICBwcm92aWRlcnM6IFt7IHByb3ZpZGU6IEFYQ2xvc2JhbGVDb21wb25lbnQsIHVzZUV4aXN0aW5nOiBBWFRvYXN0Q29tcG9uZW50IH1dLFxufSlcbmV4cG9ydCBjbGFzcyBBWFRvYXN0Q29tcG9uZW50IGV4dGVuZHMgTVhCYXNlQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgLyoqIEBpZ25vcmUgKi9cbiAgcHJvdGVjdGVkIF90b2FzdFdpZHRoID0gMTAwO1xuXG4gIC8qKiBAaWdub3JlICovXG4gIHByb3RlY3RlZCBfaWNvbjogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiAgQGlnbm9yZVxuICAgKi9cbiAgY29uc3RydWN0b3IoXG4gICAgQEluamVjdChESUFMT0dfREFUQSlcbiAgICBwdWJsaWMgY29uZmlnOiBBWFRvYXN0RGF0YSxcbiAgICBwdWJsaWMgZGlhbG9nUmVmOiBEaWFsb2dSZWY8QVhDb21wb25lbnRDbG9zZUV2ZW50PixcbiAgKSB7XG4gICAgc3VwZXIoKTtcbiAgfVxuXG4gIC8qKiBAaWdub3JlICovXG4gIG92ZXJyaWRlIG5nT25Jbml0KCkge1xuICAgIHN1cGVyLm5nT25Jbml0KCk7XG4gICAgaWYgKHRoaXMuY29uZmlnLnRpbWVPdXQpIHtcbiAgICAgIHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgICB0aGlzLmNsb3NlKCk7XG4gICAgICB9LCB0aGlzLmNvbmZpZy50aW1lT3V0KTtcbiAgICB9XG4gICAgaWYgKCF0aGlzLmNvbmZpZy5pY29uKSB7XG4gICAgICBzd2l0Y2ggKHRoaXMuY29uZmlnLmNvbG9yKSB7XG4gICAgICAgIGNhc2UgJ3N1Y2Nlc3MnOlxuICAgICAgICAgIHRoaXMuX2ljb24gPSAnYXgtaWNvbiBheC1pY29uLWNoZWNrLWNpcmNsZSc7XG4gICAgICAgICAgYnJlYWs7XG4gICAgICAgIGNhc2UgJ3dhcm5pbmcnOlxuICAgICAgICAgIHRoaXMuX2ljb24gPSAnYXgtaWNvbiBheC1pY29uLXdhcm5pbmcnO1xuICAgICAgICAgIGJyZWFrO1xuICAgICAgICBjYXNlICdkYW5nZXInOlxuICAgICAgICAgIHRoaXMuX2ljb24gPSAnYXgtaWNvbiBheC1pY29uLWVycm9yJztcbiAgICAgICAgICBicmVhaztcbiAgICAgICAgY2FzZSAnaW5mbyc6XG4gICAgICAgICAgdGhpcy5faWNvbiA9ICdheC1pY29uIGF4LWljb24taW5mbyc7XG4gICAgICAgICAgYnJlYWs7XG4gICAgICAgIGRlZmF1bHQ6XG4gICAgICAgICAgdGhpcy5faWNvbiA9IHRoaXMuY29uZmlnLmljb24gfHwgJ2F4LWljb24gYXgtaWNvbi1jaGVjay1jaXJjbGUnO1xuICAgICAgICAgIGJyZWFrO1xuICAgICAgfVxuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLl9pY29uID0gdGhpcy5jb25maWcuaWNvbjtcbiAgICB9XG4gIH1cblxuICAvKiogQGlnbm9yZSAqL1xuICBfaGFuZGxlQnV0dG9uQ2xpY2soYnV0dG9uOiBBWEJ1dHRvbkl0ZW0pIHtcbiAgICBpZiAoYnV0dG9uLm9uQ2xpY2spIHtcbiAgICAgIGJ1dHRvbi5vbkNsaWNrKHsgc291cmNlOiBidXR0b24gfSk7XG4gICAgfVxuICB9XG5cbiAgLyoqIEBpZ25vcmUgKi9cbiAgQEhvc3RCaW5kaW5nKCdjbGFzcycpXG4gIHByaXZhdGUgZ2V0IF9faG9zdENsYXNzKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIGBheC0ke3RoaXMuY29uZmlnLmNvbG9yfWA7XG4gIH1cblxuICAvKiogQGlnbm9yZSAqL1xuICBjbG9zZSgpIHtcbiAgICB0aGlzLmRpYWxvZ1JlZi5jbG9zZSh7XG4gICAgICBjb21wb25lbnQ6IHRoaXMsXG4gICAgICBodG1sRWxlbWVudDogdGhpcy5nZXRIb3N0RWxlbWVudCgpLFxuICAgIH0pO1xuICB9XG59XG4iLCI8c3BhbiBjbGFzcz1cImF4LXRvYXN0LWljb24gYXgtaWNvbi1zb2xpZCB7eyBfaWNvbiB9fVwiPjwvc3Bhbj5cbjxkaXYgY2xhc3M9XCJheC10b2FzdC1jb250ZW50XCI+XG4gIDxkaXYgY2xhc3M9XCJheC10b2FzdC10aXRsZVwiIFtjbGFzcy5heC1tYi0yXT1cImNvbmZpZy50aXRsZSAmJiBjb25maWcuY29udGVudFwiPnt7IGNvbmZpZy50aXRsZSB8IHRyYW5zbGF0ZSB8IGFzeW5jIH19XG4gIDwvZGl2PlxuICA8ZGl2IGNsYXNzPVwiYXgtdG9hc3QtY29udGVudFwiIFtpbm5lckhUTUxdPVwiY29uZmlnLmNvbnRlbnRcIj48L2Rpdj5cbjwvZGl2PlxuQGlmKGNvbmZpZy5jbG9zZUJ1dHRvbil7XG48YXgtY2xvc2UtYnV0dG9uPjwvYXgtY2xvc2UtYnV0dG9uPlxufVxuQGlmKGNvbmZpZy50aW1lT3V0UHJvZ3Jlc3MgJiYgY29uZmlnLnRpbWVPdXQpe1xuPGRpdiBjbGFzcz1cImF4LXRvYXN0LXByb2dyZXNzXCIgW3N0eWxlLmFuaW1hdGlvbi1kdXJhdGlvbi5tc109XCJjb25maWcudGltZU91dFwiPjwvZGl2PlxufSJdfQ==
|
@@ -14,6 +14,7 @@ export const AXToastDefaultConfig = {
|
|
14
14
|
timeOut: 2500,
|
15
15
|
timeOutProgress: true,
|
16
16
|
location: 'bottom-center',
|
17
|
+
limit: 3,
|
17
18
|
};
|
18
19
|
export function toastConfig(config = {}) {
|
19
20
|
const result = {
|
@@ -22,4 +23,4 @@ export function toastConfig(config = {}) {
|
|
22
23
|
};
|
23
24
|
return result;
|
24
25
|
}
|
25
|
-
//# sourceMappingURL=data:application/json;base64,
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9hc3QuY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL3RvYXN0L3NyYy9saWIvdG9hc3QuY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3ZELE9BQU8sRUFBRSxHQUFHLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFVaEMsTUFBTSxDQUFDLE1BQU0sZUFBZSxHQUFHLElBQUksY0FBYyxDQUFnQixpQkFBaUIsRUFBRTtJQUNsRixVQUFVLEVBQUUsTUFBTTtJQUNsQixPQUFPLEVBQUUsR0FBRyxFQUFFO1FBQ1osTUFBTSxNQUFNLEdBQUcsTUFBTSxDQUFDLGdCQUFnQixDQUFDLENBQUM7UUFDeEMsR0FBRyxDQUFDLE1BQU0sRUFBRSxjQUFjLEVBQUUsZUFBZSxDQUFDLENBQUM7UUFDN0MsT0FBTyxvQkFBb0IsQ0FBQztJQUM5QixDQUFDO0NBQ0YsQ0FBQyxDQUFDO0FBRUgsTUFBTSxDQUFDLE1BQU0sb0JBQW9CLEdBQWtCO0lBQ2pELEdBQUcsRUFBRSxDQUFDO0lBQ04sT0FBTyxFQUFFLElBQUk7SUFDYixlQUFlLEVBQUUsSUFBSTtJQUNyQixRQUFRLEVBQUUsZUFBZTtJQUN6QixLQUFLLEVBQUUsQ0FBQztDQUNULENBQUM7QUFJRixNQUFNLFVBQVUsV0FBVyxDQUFDLFNBQTZCLEVBQUU7SUFDekQsTUFBTSxNQUFNLEdBQUc7UUFDYixHQUFHLG9CQUFvQjtRQUN2QixHQUFHLE1BQU07S0FDVixDQUFDO0lBQ0YsT0FBTyxNQUFNLENBQUM7QUFDaEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFYTG9jYXRpb24gfSBmcm9tICdAYWNvcmV4L2NvbXBvbmVudHMvY29tbW9uJztcbmltcG9ydCB7IEFYX0dMT0JBTF9DT05GSUcgfSBmcm9tICdAYWNvcmV4L2NvcmUvY29uZmlnJztcbmltcG9ydCB7IEluamVjdGlvblRva2VuLCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IHNldCB9IGZyb20gJ2xvZGFzaC1lcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQVhUb2FzdENvbmZpZyB7XG4gIGdhcDogbnVtYmVyO1xuICB0aW1lT3V0OiBudW1iZXI7XG4gIHRpbWVPdXRQcm9ncmVzczogYm9vbGVhbjtcbiAgbG9jYXRpb246IEFYTG9jYXRpb247XG4gIGxpbWl0OiBudW1iZXI7XG59XG5cbmV4cG9ydCBjb25zdCBBWF9UT0FTVF9DT05GSUcgPSBuZXcgSW5qZWN0aW9uVG9rZW48QVhUb2FzdENvbmZpZz4oJ0FYX1RPQVNUX0NPTkZJRycsIHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxuICBmYWN0b3J5OiAoKSA9PiB7XG4gICAgY29uc3QgZ2xvYmFsID0gaW5qZWN0KEFYX0dMT0JBTF9DT05GSUcpO1xuICAgIHNldChnbG9iYWwsICdsYXlvdXQudG9hc3QnLCBBWF9UT0FTVF9DT05GSUcpO1xuICAgIHJldHVybiBBWFRvYXN0RGVmYXVsdENvbmZpZztcbiAgfSxcbn0pO1xuXG5leHBvcnQgY29uc3QgQVhUb2FzdERlZmF1bHRDb25maWc6IEFYVG9hc3RDb25maWcgPSB7XG4gIGdhcDogNSxcbiAgdGltZU91dDogMjUwMCxcbiAgdGltZU91dFByb2dyZXNzOiB0cnVlLFxuICBsb2NhdGlvbjogJ2JvdHRvbS1jZW50ZXInLFxuICBsaW1pdDogMyxcbn07XG5cbmV4cG9ydCB0eXBlIFBhcnRpYWxUb2FzdENvbmZpZyA9IFBhcnRpYWw8QVhUb2FzdENvbmZpZz47XG5cbmV4cG9ydCBmdW5jdGlvbiB0b2FzdENvbmZpZyhjb25maWc6IFBhcnRpYWxUb2FzdENvbmZpZyA9IHt9KTogQVhUb2FzdENvbmZpZyB7XG4gIGNvbnN0IHJlc3VsdCA9IHtcbiAgICAuLi5BWFRvYXN0RGVmYXVsdENvbmZpZyxcbiAgICAuLi5jb25maWcsXG4gIH07XG4gIHJldHVybiByZXN1bHQ7XG59XG4iXX0=
|