@acorex/components 18.12.40 → 18.12.42

Sign up to get free protection for your applications and to get access to all the features.
@@ -111,35 +111,37 @@ export class AXDialogService {
111
111
  */
112
112
  show(options) {
113
113
  return new Promise((resolve) => {
114
- const popup = this.open(options);
115
114
  options.orientation = options.orientation || 'horizontal';
116
- (options.icon = options.icon ?? this.detectIcon(options.type)),
117
- options.buttons?.forEach((b) => {
118
- const orginalClick = b.onClick;
119
- b.onClick = () => {
120
- const e = { source: b, handled: false };
121
- if (orginalClick) {
122
- orginalClick(e);
123
- if (e.handled) {
124
- resolve({ name: b.name ?? b.text });
125
- }
126
- else {
127
- popup.close();
128
- resolve({ name: b.name ?? b.text });
129
- }
130
- }
131
- else if (resolve) {
132
- popup.close();
115
+ options.icon = options.icon ?? this.detectIcon(options.type);
116
+ const popup = this.open(options);
117
+ options.buttons?.forEach((b) => {
118
+ const orginalClick = b.onClick;
119
+ b.onClick = () => {
120
+ const e = { source: b, handled: false };
121
+ if (orginalClick) {
122
+ orginalClick(e);
123
+ if (e.handled) {
133
124
  resolve({ name: b.name ?? b.text });
134
125
  }
135
126
  else {
136
127
  popup.close();
128
+ resolve({ name: b.name ?? b.text });
137
129
  }
138
- };
139
- });
130
+ }
131
+ else if (resolve) {
132
+ popup.close();
133
+ resolve({ name: b.name ?? b.text });
134
+ }
135
+ else {
136
+ popup.close();
137
+ }
138
+ };
139
+ });
140
140
  });
141
141
  }
142
142
  open(config) {
143
+ config.orientation = config.orientation || 'horizontal';
144
+ config.icon = config.icon ?? this.detectIcon(config.type);
143
145
  const dialogRef = this.dialog.open(AXDialogComponent, {
144
146
  data: config,
145
147
  role: 'alertdialog',
@@ -163,4 +165,4 @@ export class AXDialogService {
163
165
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXDialogService, decorators: [{
164
166
  type: Injectable
165
167
  }] });
166
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.service.js","sourceRoot":"","sources":["../../../../../../libs/components/dialog/src/lib/dialog.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { AXStyleColorType } from '@acorex/components/common';\nimport { Dialog } from '@angular/cdk/dialog';\nimport { Injectable, inject } from '@angular/core';\nimport { AXDialogConfig, AXDialogRef } from './dialog.class';\nimport { AXDialogComponent } from './dialog.component';\n\n/**\n * The Button is a component which detects user interaction and triggers a corresponding event\n *\n * @category Components\n */\n@Injectable()\nexport class AXDialogService {\n  private dialog: Dialog = inject(Dialog);\n\n  private detectIcon(type) {\n    let icon: string;\n    switch (type) {\n      case 'success':\n        icon = 'ax-icon ax-icon-check';\n        break;\n      case 'danger':\n        icon = 'ax-icon ax-icon-error';\n        break;\n      case 'warning':\n        icon = 'ax-icon ax-icon-warning';\n        break;\n      default:\n        icon = 'ax-icon ax-icon-info';\n        break;\n    }\n    return icon;\n  }\n  /**\n   *  Show an alert box with 'Okay' button.\n   */\n  alert(\n    title: string,\n    content: string,\n    type: AXStyleColorType = 'primary',\n    orientation: 'horizontal' | 'vertical' = 'horizontal',\n    draggable?: boolean,\n  ): Promise<void> {\n    return new Promise((resolve) => {\n      const popup = this.open({\n        title,\n        type: type,\n        content,\n        icon: this.detectIcon(type),\n        orientation,\n        draggable,\n        buttons: [\n          {\n            name: 'confirm',\n            text: 'okay',\n            color: type,\n            autofocus: true,\n            onClick: () => {\n              popup.close();\n              if (resolve) {\n                resolve();\n              }\n            },\n          },\n        ],\n      });\n    });\n  }\n\n  /**\n   *  Show a confirm box with 'Okay' & 'Cancel' buttons.\n   */\n\n  confirm(\n    title: string,\n    content: string,\n    type: AXStyleColorType = 'primary',\n    orientation: 'horizontal' | 'vertical' = 'horizontal',\n    draggable?: boolean,\n  ): Promise<{ result: boolean }> {\n    return new Promise<{ result: boolean }>((resolve) => {\n      const popup = this.open({\n        title,\n        content,\n        type,\n        icon: this.detectIcon(type),\n        orientation,\n        draggable,\n        buttons: [\n          {\n            name: 'confirm',\n            text: 'okay',\n            color: type,\n            autofocus: true,\n            onClick: () => {\n              popup.close();\n              if (resolve) {\n                resolve({ result: true });\n              }\n            },\n          },\n          {\n            name: 'cancel',\n            text: 'cancel',\n            color: `ghost`,\n            onClick: () => {\n              popup.close();\n              if (resolve) {\n                resolve({ result: false });\n              }\n            },\n            hotkey: {\n              Escape: () => {\n                popup.close();\n                if (resolve) {\n                  resolve({ result: false });\n                }\n              },\n            },\n          },\n        ],\n      });\n    });\n  }\n\n  /**\n   *  Show a custom dialog box.\n   */\n  show(options: AXDialogConfig): Promise<{ name: string }> {\n    return new Promise((resolve) => {\n      const popup = this.open(options);\n      options.orientation = options.orientation || 'horizontal';\n      (options.icon = options.icon ?? this.detectIcon(options.type)),\n        options.buttons?.forEach((b) => {\n          const orginalClick = b.onClick;\n          b.onClick = () => {\n            const e = { source: b, handled: false };\n            if (orginalClick) {\n              orginalClick(e);\n              if (e.handled) {\n                resolve({ name: b.name ?? b.text });\n              } else {\n                popup.close();\n                resolve({ name: b.name ?? b.text });\n              }\n            } else if (resolve) {\n              popup.close();\n              resolve({ name: b.name ?? b.text });\n            } else {\n              popup.close();\n            }\n          };\n        });\n    });\n  }\n\n  open(config: AXDialogConfig): AXDialogRef {\n    const dialogRef = this.dialog.open(AXDialogComponent, {\n      data: config,\n      role: 'alertdialog',\n      ariaModal: true,\n      restoreFocus: true,\n      closeOnNavigation: true,\n      closeOnDestroy: true,\n      hasBackdrop: true,\n      disableClose: true,\n      panelClass: ['ax-animate-bounceIn', 'ax-animate-faster'],\n    });\n    return {\n      close: () => {\n        dialogRef.componentInstance?.close();\n      },\n    };\n  }\n}\n"]}
168
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog.service.js","sourceRoot":"","sources":["../../../../../../libs/components/dialog/src/lib/dialog.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { AXStyleColorType } from '@acorex/components/common';\nimport { Dialog } from '@angular/cdk/dialog';\nimport { Injectable, inject } from '@angular/core';\nimport { AXDialogConfig, AXDialogRef } from './dialog.class';\nimport { AXDialogComponent } from './dialog.component';\n\n/**\n * The Button is a component which detects user interaction and triggers a corresponding event\n *\n * @category Components\n */\n@Injectable()\nexport class AXDialogService {\n  private dialog: Dialog = inject(Dialog);\n\n  private detectIcon(type) {\n    let icon: string;\n    switch (type) {\n      case 'success':\n        icon = 'ax-icon ax-icon-check';\n        break;\n      case 'danger':\n        icon = 'ax-icon ax-icon-error';\n        break;\n      case 'warning':\n        icon = 'ax-icon ax-icon-warning';\n        break;\n      default:\n        icon = 'ax-icon ax-icon-info';\n        break;\n    }\n    return icon;\n  }\n  /**\n   *  Show an alert box with 'Okay' button.\n   */\n  alert(\n    title: string,\n    content: string,\n    type: AXStyleColorType = 'primary',\n    orientation: 'horizontal' | 'vertical' = 'horizontal',\n    draggable?: boolean,\n  ): Promise<void> {\n    return new Promise((resolve) => {\n      const popup = this.open({\n        title,\n        type: type,\n        content,\n        icon: this.detectIcon(type),\n        orientation,\n        draggable,\n        buttons: [\n          {\n            name: 'confirm',\n            text: 'okay',\n            color: type,\n            autofocus: true,\n            onClick: () => {\n              popup.close();\n              if (resolve) {\n                resolve();\n              }\n            },\n          },\n        ],\n      });\n    });\n  }\n\n  /**\n   *  Show a confirm box with 'Okay' & 'Cancel' buttons.\n   */\n\n  confirm(\n    title: string,\n    content: string,\n    type: AXStyleColorType = 'primary',\n    orientation: 'horizontal' | 'vertical' = 'horizontal',\n    draggable?: boolean,\n  ): Promise<{ result: boolean }> {\n    return new Promise<{ result: boolean }>((resolve) => {\n      const popup = this.open({\n        title,\n        content,\n        type,\n        icon: this.detectIcon(type),\n        orientation,\n        draggable,\n        buttons: [\n          {\n            name: 'confirm',\n            text: 'okay',\n            color: type,\n            autofocus: true,\n            onClick: () => {\n              popup.close();\n              if (resolve) {\n                resolve({ result: true });\n              }\n            },\n          },\n          {\n            name: 'cancel',\n            text: 'cancel',\n            color: `ghost`,\n            onClick: () => {\n              popup.close();\n              if (resolve) {\n                resolve({ result: false });\n              }\n            },\n            hotkey: {\n              Escape: () => {\n                popup.close();\n                if (resolve) {\n                  resolve({ result: false });\n                }\n              },\n            },\n          },\n        ],\n      });\n    });\n  }\n\n  /**\n   *  Show a custom dialog box.\n   */\n  show(options: AXDialogConfig): Promise<{ name: string }> {\n    return new Promise((resolve) => {\n      options.orientation = options.orientation || 'horizontal';\n      options.icon = options.icon ?? this.detectIcon(options.type);\n\n      const popup = this.open(options);\n\n      options.buttons?.forEach((b) => {\n        const orginalClick = b.onClick;\n        b.onClick = () => {\n          const e = { source: b, handled: false };\n          if (orginalClick) {\n            orginalClick(e);\n            if (e.handled) {\n              resolve({ name: b.name ?? b.text });\n            } else {\n              popup.close();\n              resolve({ name: b.name ?? b.text });\n            }\n          } else if (resolve) {\n            popup.close();\n            resolve({ name: b.name ?? b.text });\n          } else {\n            popup.close();\n          }\n        };\n      });\n    });\n  }\n\n  open(config: AXDialogConfig): AXDialogRef {\n    config.orientation = config.orientation || 'horizontal';\n    config.icon = config.icon ?? this.detectIcon(config.type);\n\n    const dialogRef = this.dialog.open(AXDialogComponent, {\n      data: config,\n      role: 'alertdialog',\n      ariaModal: true,\n      restoreFocus: true,\n      closeOnNavigation: true,\n      closeOnDestroy: true,\n      hasBackdrop: true,\n      disableClose: true,\n      panelClass: ['ax-animate-bounceIn', 'ax-animate-faster'],\n    });\n    return {\n      close: () => {\n        dialogRef.componentInstance?.close();\n      },\n    };\n  }\n}\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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm90aWZpY2F0aW9uLmNvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9ub3RpZmljYXRpb24vc3JjL2xpYi9ub3RpZmljYXRpb24uY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFVL0MsTUFBTSxDQUFDLE1BQU0sc0JBQXNCLEdBQUcsSUFBSSxjQUFjLENBQXVCLHdCQUF3QixFQUFFO0lBQ3ZHLFVBQVUsRUFBRSxNQUFNO0lBQ2xCLE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQywyQkFBMkI7Q0FDM0MsQ0FBQyxDQUFDO0FBRUgsTUFBTSxDQUFDLE1BQU0sMkJBQTJCLEdBQXlCO0lBQy9ELEdBQUcsRUFBRSxDQUFDO0lBQ04sT0FBTyxFQUFFLElBQUk7SUFDYixlQUFlLEVBQUUsSUFBSTtJQUNyQixXQUFXLEVBQUUsSUFBSTtJQUNqQixRQUFRLEVBQUUsU0FBUztDQUNwQixDQUFDO0FBSUYsTUFBTSxVQUFVLGtCQUFrQixDQUFDLFNBQW9DLEVBQUU7SUFDdkUsTUFBTSxNQUFNLEdBQUc7UUFDYixHQUFHLDJCQUEyQjtRQUM5QixHQUFHLE1BQU07S0FDVixDQUFDO0lBQ0YsT0FBTyxNQUFNLENBQUM7QUFDaEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFYTG9jYXRpb24gfSBmcm9tICdAYWNvcmV4L2NvbXBvbmVudHMvY29tbW9uJztcbmltcG9ydCB7IEluamVjdGlvblRva2VuIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQVhOb3RpZmljYXRpb25Db25maWcge1xuICBnYXA6IG51bWJlcjtcbiAgdGltZU91dDogbnVtYmVyO1xuICB0aW1lT3V0UHJvZ3Jlc3M6IGJvb2xlYW47XG4gIGxvY2F0aW9uOiBBWExvY2F0aW9uO1xuICBjbG9zZUJ1dHRvbjogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGNvbnN0IEFYX05PVElGSUNBVElPTl9DT05GSUcgPSBuZXcgSW5qZWN0aW9uVG9rZW48QVhOb3RpZmljYXRpb25Db25maWc+KCdBWF9OT1RJRklDQVRJT05fQ09ORklHJywge1xuICBwcm92aWRlZEluOiAncm9vdCcsXG4gIGZhY3Rvcnk6ICgpID0+IEFYTm90aWZpY2F0aW9uRGVmYXVsdENvbmZpZyxcbn0pO1xuXG5leHBvcnQgY29uc3QgQVhOb3RpZmljYXRpb25EZWZhdWx0Q29uZmlnOiBBWE5vdGlmaWNhdGlvbkNvbmZpZyA9IHtcbiAgZ2FwOiA1LFxuICB0aW1lT3V0OiAyNTAwLFxuICB0aW1lT3V0UHJvZ3Jlc3M6IHRydWUsXG4gIGNsb3NlQnV0dG9uOiB0cnVlLFxuICBsb2NhdGlvbjogJ3RvcC1lbmQnLFxufTtcblxuZXhwb3J0IHR5cGUgUGFydGlhbE5vdGlmaWNhdGlvbkNvbmZpZyA9IFBhcnRpYWw8QVhOb3RpZmljYXRpb25Db25maWc+O1xuXG5leHBvcnQgZnVuY3Rpb24gbm90aWZpY2F0aW9uQ29uZmlnKGNvbmZpZzogUGFydGlhbE5vdGlmaWNhdGlvbkNvbmZpZyA9IHt9KTogQVhOb3RpZmljYXRpb25Db25maWcge1xuICBjb25zdCByZXN1bHQgPSB7XG4gICAgLi4uQVhOb3RpZmljYXRpb25EZWZhdWx0Q29uZmlnLFxuICAgIC4uLmNvbmZpZyxcbiAgfTtcbiAgcmV0dXJuIHJlc3VsdDtcbn1cbiJdfQ==
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,12 +8,38 @@ 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
44
  const pos = this.getPosition(config.location) + gap + 'px';
19
45
  const positionStrategy = this.getPositionStrategy(new GlobalPositionStrategy(), config.location, pos, gap);
@@ -29,34 +55,89 @@ export class AXNotificationService {
29
55
  panelClass: ['ax-animate-animated', 'ax-animate-fadeIn', 'ax-animate-faster'],
30
56
  positionStrategy,
31
57
  });
32
- const toastRef = dialogRef.componentInstance;
58
+ this.activeNotifications.update((value) => [...value, dialogRef.id]);
59
+ const notificationRef = dialogRef.componentInstance;
33
60
  dialogRef.closed.subscribe(() => {
34
- this.reposition(toastRef.config.location, gap);
61
+ this.activeNotifications.update((value) => [...value].filter((dialogID) => dialogID !== dialogRef.id));
62
+ setTimeout(() => {
63
+ this.reposition(config.location, gap);
64
+ }, 0);
35
65
  });
36
66
  return {
37
67
  close: () => {
38
- toastRef.close();
68
+ notificationRef.close();
39
69
  },
40
70
  };
41
71
  }
42
72
  hideAll() {
43
73
  this.dialog.closeAll();
44
74
  }
45
- reposition(toastLocation, gap) {
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) {
46
128
  const list = this.dialog.openDialogs
47
129
  .map((c) => c.componentInstance)
48
- .filter((c) => c.config?.location == toastLocation);
130
+ .filter((c) => c.config?.location == notificationLocation);
49
131
  list.forEach((element, index) => {
50
- const pos = this.getRepositionPosition(index, gap, list, toastLocation);
51
- this.getPositionStrategy(element.dialogRef.config.positionStrategy, toastLocation, pos, gap).apply();
132
+ const pos = this.getRepositionPosition(index, gap, list, notificationLocation);
133
+ this.getPositionStrategy(element.dialogRef.config.positionStrategy, notificationLocation, pos, gap).apply();
52
134
  });
53
135
  }
54
- getRepositionPosition(index, gap, list, toastLocation) {
55
- if (index === 0) {
136
+ getRepositionPosition(index, gap, list, notificationLocation) {
137
+ if (index === 0)
56
138
  return gap + 'px';
57
- }
58
139
  const previouseElement = list[index - 1];
59
- if (toastLocation.split('-')[0] == 'bottom') {
140
+ if (notificationLocation.split('-')[0] == 'bottom') {
60
141
  return window.innerHeight - previouseElement.getHostElement().offsetTop + gap + 'px';
61
142
  }
62
143
  return (previouseElement.getHostElement().offsetTop +
@@ -109,4 +190,4 @@ export class AXNotificationService {
109
190
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXNotificationService, decorators: [{
110
191
  type: Injectable
111
192
  }] });
112
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notification.service.js","sourceRoot":"","sources":["../../../../../../libs/components/notification/src/lib/notification.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { AXLocation } from '@acorex/components/common';\nimport { Dialog } from '@angular/cdk/dialog';\nimport { GlobalPositionStrategy } from '@angular/cdk/overlay';\nimport { Injectable, inject } 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\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    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\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    const toastRef = dialogRef.componentInstance as AXNotificationComponent;\n    dialogRef.closed.subscribe(() => {\n      this.reposition(toastRef.config.location, gap);\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(toastLocation: AXLocation, gap: number): void {\n    const list = this.dialog.openDialogs\n      .map((c) => c.componentInstance as AXNotificationComponent)\n      .filter((c) => c.config?.location == toastLocation);\n    list.forEach((element, index) => {\n      const pos = this.getRepositionPosition(index, gap, list, toastLocation);\n\n      this.getPositionStrategy(\n        element.dialogRef.config.positionStrategy as GlobalPositionStrategy,\n        toastLocation,\n        pos,\n        gap,\n      ).apply();\n    });\n  }\n\n  private getRepositionPosition(\n    index: number,\n    gap: number,\n    list: AXNotificationComponent[],\n    toastLocation: string,\n  ) {\n    if (index === 0) {\n      return gap + 'px';\n    }\n    const previouseElement = list[index - 1];\n    if (toastLocation.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"]}
193
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"notification.service.js","sourceRoot":"","sources":["../../../../../../libs/components/notification/src/lib/notification.service.ts"],"names":[],"mappings":"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","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"]}
@@ -23,4 +23,4 @@ export function toastConfig(config = {}) {
23
23
  };
24
24
  return result;
25
25
  }
26
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9hc3QuY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL3RvYXN0L3NyYy9saWIvdG9hc3QuY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3ZELE9BQU8sRUFBRSxHQUFHLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFVaEMsTUFBTSxDQUFDLE1BQU0sZUFBZSxHQUFHLElBQUksY0FBYyxDQUFnQixpQkFBaUIsRUFBRTtJQUNsRixVQUFVLEVBQUUsTUFBTTtJQUNsQixPQUFPLEVBQUUsR0FBRyxFQUFFO1FBQ1osTUFBTSxNQUFNLEdBQUcsTUFBTSxDQUFDLGdCQUFnQixDQUFDLENBQUM7UUFDeEMsR0FBRyxDQUFDLE1BQU0sRUFBRSxjQUFjLEVBQUUsZUFBZSxDQUFDLENBQUM7UUFDN0MsT0FBTyxvQkFBb0IsQ0FBQztJQUM5QixDQUFDO0NBQ0YsQ0FBQyxDQUFDO0FBRUgsTUFBTSxDQUFDLE1BQU0sb0JBQW9CLEdBQWtCO0lBQ2pELEdBQUcsRUFBRSxDQUFDO0lBQ04sT0FBTyxFQUFFLElBQUk7SUFDYixlQUFlLEVBQUUsSUFBSTtJQUNyQixRQUFRLEVBQUUsZUFBZTtJQUN6QixLQUFLLEVBQUUsQ0FBQztDQUNULENBQUM7QUFJRixNQUFNLFVBQVUsV0FBVyxDQUFDLFNBQTZCLEVBQUU7SUFDekQsTUFBTSxNQUFNLEdBQUc7UUFDYixHQUFHLG9CQUFvQjtRQUN2QixHQUFHLE1BQU07S0FDVixDQUFDO0lBQ0YsT0FBTyxNQUFNLENBQUM7QUFDaEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFYTG9jYXRpb24gfSBmcm9tICdAYWNvcmV4L2NvbXBvbmVudHMvY29tbW9uJztcbmltcG9ydCB7IEFYX0dMT0JBTF9DT05GSUcgfSBmcm9tICdAYWNvcmV4L2NvcmUvY29uZmlnJztcbmltcG9ydCB7IEluamVjdGlvblRva2VuLCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IHNldCB9IGZyb20gJ2xvZGFzaC1lcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQVhUb2FzdENvbmZpZyB7XG4gIGdhcDogbnVtYmVyO1xuICB0aW1lT3V0OiBudW1iZXI7XG4gIHRpbWVPdXRQcm9ncmVzczogYm9vbGVhbjtcbiAgbG9jYXRpb246IEFYTG9jYXRpb247XG4gIGxpbWl0PzogbnVtYmVyO1xufVxuXG5leHBvcnQgY29uc3QgQVhfVE9BU1RfQ09ORklHID0gbmV3IEluamVjdGlvblRva2VuPEFYVG9hc3RDb25maWc+KCdBWF9UT0FTVF9DT05GSUcnLCB7XG4gIHByb3ZpZGVkSW46ICdyb290JyxcbiAgZmFjdG9yeTogKCkgPT4ge1xuICAgIGNvbnN0IGdsb2JhbCA9IGluamVjdChBWF9HTE9CQUxfQ09ORklHKTtcbiAgICBzZXQoZ2xvYmFsLCAnbGF5b3V0LnRvYXN0JywgQVhfVE9BU1RfQ09ORklHKTtcbiAgICByZXR1cm4gQVhUb2FzdERlZmF1bHRDb25maWc7XG4gIH0sXG59KTtcblxuZXhwb3J0IGNvbnN0IEFYVG9hc3REZWZhdWx0Q29uZmlnOiBBWFRvYXN0Q29uZmlnID0ge1xuICBnYXA6IDUsXG4gIHRpbWVPdXQ6IDI1MDAsXG4gIHRpbWVPdXRQcm9ncmVzczogdHJ1ZSxcbiAgbG9jYXRpb246ICdib3R0b20tY2VudGVyJyxcbiAgbGltaXQ6IDMsXG59O1xuXG5leHBvcnQgdHlwZSBQYXJ0aWFsVG9hc3RDb25maWcgPSBQYXJ0aWFsPEFYVG9hc3RDb25maWc+O1xuXG5leHBvcnQgZnVuY3Rpb24gdG9hc3RDb25maWcoY29uZmlnOiBQYXJ0aWFsVG9hc3RDb25maWcgPSB7fSk6IEFYVG9hc3RDb25maWcge1xuICBjb25zdCByZXN1bHQgPSB7XG4gICAgLi4uQVhUb2FzdERlZmF1bHRDb25maWcsXG4gICAgLi4uY29uZmlnLFxuICB9O1xuICByZXR1cm4gcmVzdWx0O1xufVxuIl19
26
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9hc3QuY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21wb25lbnRzL3RvYXN0L3NyYy9saWIvdG9hc3QuY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3ZELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3ZELE9BQU8sRUFBRSxHQUFHLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFVaEMsTUFBTSxDQUFDLE1BQU0sZUFBZSxHQUFHLElBQUksY0FBYyxDQUFnQixpQkFBaUIsRUFBRTtJQUNsRixVQUFVLEVBQUUsTUFBTTtJQUNsQixPQUFPLEVBQUUsR0FBRyxFQUFFO1FBQ1osTUFBTSxNQUFNLEdBQUcsTUFBTSxDQUFDLGdCQUFnQixDQUFDLENBQUM7UUFDeEMsR0FBRyxDQUFDLE1BQU0sRUFBRSxjQUFjLEVBQUUsZUFBZSxDQUFDLENBQUM7UUFDN0MsT0FBTyxvQkFBb0IsQ0FBQztJQUM5QixDQUFDO0NBQ0YsQ0FBQyxDQUFDO0FBRUgsTUFBTSxDQUFDLE1BQU0sb0JBQW9CLEdBQWtCO0lBQ2pELEdBQUcsRUFBRSxDQUFDO0lBQ04sT0FBTyxFQUFFLElBQUk7SUFDYixlQUFlLEVBQUUsSUFBSTtJQUNyQixRQUFRLEVBQUUsZUFBZTtJQUN6QixLQUFLLEVBQUUsQ0FBQztDQUNULENBQUM7QUFJRixNQUFNLFVBQVUsV0FBVyxDQUFDLFNBQTZCLEVBQUU7SUFDekQsTUFBTSxNQUFNLEdBQUc7UUFDYixHQUFHLG9CQUFvQjtRQUN2QixHQUFHLE1BQU07S0FDVixDQUFDO0lBQ0YsT0FBTyxNQUFNLENBQUM7QUFDaEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFYTG9jYXRpb24gfSBmcm9tICdAYWNvcmV4L2NvbXBvbmVudHMvY29tbW9uJztcbmltcG9ydCB7IEFYX0dMT0JBTF9DT05GSUcgfSBmcm9tICdAYWNvcmV4L2NvcmUvY29uZmlnJztcbmltcG9ydCB7IEluamVjdGlvblRva2VuLCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IHNldCB9IGZyb20gJ2xvZGFzaC1lcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQVhUb2FzdENvbmZpZyB7XG4gIGdhcDogbnVtYmVyO1xuICB0aW1lT3V0OiBudW1iZXI7XG4gIHRpbWVPdXRQcm9ncmVzczogYm9vbGVhbjtcbiAgbG9jYXRpb246IEFYTG9jYXRpb247XG4gIGxpbWl0OiBudW1iZXI7XG59XG5cbmV4cG9ydCBjb25zdCBBWF9UT0FTVF9DT05GSUcgPSBuZXcgSW5qZWN0aW9uVG9rZW48QVhUb2FzdENvbmZpZz4oJ0FYX1RPQVNUX0NPTkZJRycsIHtcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxuICBmYWN0b3J5OiAoKSA9PiB7XG4gICAgY29uc3QgZ2xvYmFsID0gaW5qZWN0KEFYX0dMT0JBTF9DT05GSUcpO1xuICAgIHNldChnbG9iYWwsICdsYXlvdXQudG9hc3QnLCBBWF9UT0FTVF9DT05GSUcpO1xuICAgIHJldHVybiBBWFRvYXN0RGVmYXVsdENvbmZpZztcbiAgfSxcbn0pO1xuXG5leHBvcnQgY29uc3QgQVhUb2FzdERlZmF1bHRDb25maWc6IEFYVG9hc3RDb25maWcgPSB7XG4gIGdhcDogNSxcbiAgdGltZU91dDogMjUwMCxcbiAgdGltZU91dFByb2dyZXNzOiB0cnVlLFxuICBsb2NhdGlvbjogJ2JvdHRvbS1jZW50ZXInLFxuICBsaW1pdDogMyxcbn07XG5cbmV4cG9ydCB0eXBlIFBhcnRpYWxUb2FzdENvbmZpZyA9IFBhcnRpYWw8QVhUb2FzdENvbmZpZz47XG5cbmV4cG9ydCBmdW5jdGlvbiB0b2FzdENvbmZpZyhjb25maWc6IFBhcnRpYWxUb2FzdENvbmZpZyA9IHt9KTogQVhUb2FzdENvbmZpZyB7XG4gIGNvbnN0IHJlc3VsdCA9IHtcbiAgICAuLi5BWFRvYXN0RGVmYXVsdENvbmZpZyxcbiAgICAuLi5jb25maWcsXG4gIH07XG4gIHJldHVybiByZXN1bHQ7XG59XG4iXX0=
@@ -13,34 +13,19 @@ export class AXToastService {
13
13
  this.activeToasts = signal([]);
14
14
  this.reservedToasts = signal([]);
15
15
  this.toastCounterElement = signal(null);
16
- this.reserveCounter = signal(0);
17
16
  this.moreToastsColor = signal('primary');
17
+ this.moreToastsLocation = signal('bottom-center');
18
+ this.reserveCounter = signal(0);
19
+ this.#effect = effect(() => {
20
+ if (this.defaultConfig.limit <= 0)
21
+ return;
22
+ this.handleShowReservedToast();
23
+ this.handleShowReservedToastCounter();
24
+ this.handleReserveCounter();
25
+ }, { allowSignalWrites: true });
18
26
  this.scrollStrategy = this.scrollStrategyOptions.noop();
19
- if (this.defaultConfig.limit) {
20
- effect(() => {
21
- if (this.activeToasts().length <= this.defaultConfig.limit - 1 && this.reservedToasts().length) {
22
- this.show(this.reservedToasts()[0]);
23
- this.reservedToasts.update((value) => {
24
- const arr = [...value];
25
- arr.shift();
26
- return arr;
27
- });
28
- }
29
- if (this.reservedToasts().length !== this.reserveCounter()) {
30
- this.reserveCounter.set(this.reservedToasts().length);
31
- if (this.toastCounterElement() !== null) {
32
- this.toastCounterElement().close();
33
- }
34
- this.createReservedCounterToast();
35
- }
36
- if (this.reserveCounter() === 0) {
37
- if (this.toastCounterElement() !== null) {
38
- this.toastCounterElement().close();
39
- }
40
- }
41
- }, { allowSignalWrites: true });
42
- }
43
27
  }
28
+ #effect;
44
29
  primary(content) {
45
30
  this.show({
46
31
  timeOut: this.defaultConfig.timeOut,
@@ -82,12 +67,15 @@ export class AXToastService {
82
67
  location: this.defaultConfig.location ?? 'bottom-center',
83
68
  }, config);
84
69
  this.moreToastsColor.set(opt.color);
85
- if (this.defaultConfig.limit) {
70
+ this.moreToastsLocation.set(opt.location);
71
+ if (this.defaultConfig.limit > 0) {
86
72
  if (this.activeToasts().length >= this.defaultConfig.limit) {
87
- this.reservedToasts.update((value) => {
88
- return [...value, opt];
89
- });
90
- return;
73
+ this.reservedToasts.update((value) => [...value, opt]);
74
+ return {
75
+ close: () => {
76
+ //TODO close reserved toast
77
+ },
78
+ };
91
79
  }
92
80
  }
93
81
  const gap = this.defaultConfig.gap;
@@ -106,14 +94,10 @@ export class AXToastService {
106
94
  positionStrategy,
107
95
  scrollStrategy: this.scrollStrategy,
108
96
  });
109
- this.activeToasts.update((value) => {
110
- return [...value, dialogRef.id];
111
- });
97
+ this.activeToasts.update((value) => [...value, dialogRef.id]);
112
98
  const toastRef = dialogRef.componentInstance;
113
99
  dialogRef.closed.subscribe(() => {
114
- this.activeToasts.update((value) => {
115
- return [...value].filter((dialogID) => dialogID !== dialogRef.id);
116
- });
100
+ this.activeToasts.update((value) => [...value].filter((dialogID) => dialogID !== dialogRef.id));
117
101
  setTimeout(() => {
118
102
  this.reposition(opt.location, gap);
119
103
  }, 0);
@@ -127,11 +111,38 @@ export class AXToastService {
127
111
  hideAll() {
128
112
  this.dialog.closeAll();
129
113
  }
114
+ handleShowReservedToast() {
115
+ if (this.activeToasts().length > this.defaultConfig.limit - 1)
116
+ return;
117
+ if (!this.reservedToasts().length)
118
+ return;
119
+ this.show(this.reservedToasts()[0]);
120
+ this.reservedToasts.update((value) => {
121
+ const toasts = [...value];
122
+ toasts.shift();
123
+ return toasts;
124
+ });
125
+ }
126
+ handleShowReservedToastCounter() {
127
+ if (this.reservedToasts().length === this.reserveCounter())
128
+ return;
129
+ this.reserveCounter.set(this.reservedToasts().length);
130
+ if (this.toastCounterElement() !== null)
131
+ this.toastCounterElement().close();
132
+ this.createReservedCounterToast();
133
+ }
134
+ handleReserveCounter() {
135
+ if (this.reserveCounter() !== 0)
136
+ return;
137
+ if (this.toastCounterElement() === null)
138
+ return;
139
+ this.toastCounterElement().close();
140
+ }
130
141
  createReservedCounterToast() {
131
142
  const opt = {
132
143
  closeButton: false,
133
144
  color: this.moreToastsColor(),
134
- location: 'bottom-center',
145
+ location: this.moreToastsLocation(),
135
146
  title: `And ${this.reserveCounter()} more...`,
136
147
  timeOutProgress: false,
137
148
  };
@@ -164,9 +175,8 @@ export class AXToastService {
164
175
  });
165
176
  }
166
177
  getRepositionPosition(index, gap, list, toastLocation) {
167
- if (index === 0) {
178
+ if (index === 0)
168
179
  return gap + 'px';
169
- }
170
180
  const previouseElement = list[index - 1];
171
181
  if (toastLocation.split('-')[0] == 'bottom') {
172
182
  return window.innerHeight - previouseElement.getHostElement().offsetTop + gap + 'px';
@@ -221,4 +231,4 @@ export class AXToastService {
221
231
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXToastService, decorators: [{
222
232
  type: Injectable
223
233
  }], ctorParameters: () => [{ type: i1.ScrollStrategyOptions }] });
224
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toast.service.js","sourceRoot":"","sources":["../../../../../../libs/components/toast/src/lib/toast.service.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,qBAAqB,CAAC;AAC7C,OAAO,EAAE,sBAAsB,EAAkB,qBAAqB,EAAE,MAAM,sBAAsB,CAAC;AACrG,OAAO,EAAE,UAAU,EAAkB,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEnF,OAAO,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AACrD,OAAO,EAAiB,eAAe,EAAE,MAAM,gBAAgB,CAAC;;;AAGhE,MAAM,OAAO,cAAc;IAWzB,YAA6B,qBAA4C;QAA5C,0BAAqB,GAArB,qBAAqB,CAAuB;QAVjE,WAAM,GAAW,MAAM,CAAC,MAAM,CAAC,CAAC;QAChC,kBAAa,GAAkB,MAAM,CAAC,eAAe,CAAC,CAAC;QACvD,iBAAY,GAA6B,MAAM,CAAC,EAAE,CAAC,CAAC;QACpD,mBAAc,GAA2C,MAAM,CAAC,EAAE,CAAC,CAAC;QACpE,wBAAmB,GAA4C,MAAM,CAAC,IAAI,CAAC,CAAC;QAC5E,mBAAc,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QAC3B,oBAAe,GAAqC,MAAM,CAAC,SAAS,CAAC,CAAC;QAK5E,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,qBAAqB,CAAC,IAAI,EAAE,CAAC;QACxD,IAAI,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;YAC7B,MAAM,CACJ,GAAG,EAAE;gBACH,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC,MAAM,IAAI,IAAI,CAAC,aAAa,CAAC,KAAK,GAAG,CAAC,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC,MAAM,EAAE,CAAC;oBAC/F,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;oBACpC,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE;wBACnC,MAAM,GAAG,GAAG,CAAC,GAAG,KAAK,CAAC,CAAC;wBACvB,GAAG,CAAC,KAAK,EAAE,CAAC;wBACZ,OAAO,GAAG,CAAC;oBACb,CAAC,CAAC,CAAC;gBACL,CAAC;gBACD,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC,MAAM,KAAK,IAAI,CAAC,cAAc,EAAE,EAAE,CAAC;oBAC3D,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,MAAM,CAAC,CAAC;oBACtD,IAAI,IAAI,CAAC,mBAAmB,EAAE,KAAK,IAAI,EAAE,CAAC;wBACxC,IAAI,CAAC,mBAAmB,EAAE,CAAC,KAAK,EAAE,CAAC;oBACrC,CAAC;oBACD,IAAI,CAAC,0BAA0B,EAAE,CAAC;gBACpC,CAAC;gBACD,IAAI,IAAI,CAAC,cAAc,EAAE,KAAK,CAAC,EAAE,CAAC;oBAChC,IAAI,IAAI,CAAC,mBAAmB,EAAE,KAAK,IAAI,EAAE,CAAC;wBACxC,IAAI,CAAC,mBAAmB,EAAE,CAAC,KAAK,EAAE,CAAC;oBACrC,CAAC;gBACH,CAAC;YACH,CAAC,EACD,EAAE,iBAAiB,EAAE,IAAI,EAAE,CAC5B,CAAC;QACJ,CAAC;IACH,CAAC;IAED,OAAO,CAAC,OAAe;QACrB,IAAI,CAAC,IAAI,CAAC;YACR,OAAO,EAAE,IAAI,CAAC,aAAa,CAAC,OAAO;YACnC,KAAK,EAAE,SAAS;YAChB,OAAO,EAAE,OAAO;SACjB,CAAC,CAAC;IACL,CAAC;IACD,SAAS,CAAC,OAAe;QACvB,IAAI,CAAC,IAAI,CAAC;YACR,OAAO,EAAE,IAAI,CAAC,aAAa,CAAC,OAAO;YACnC,KAAK,EAAE,WAAW;YAClB,OAAO,EAAE,OAAO;SACjB,CAAC,CAAC;IACL,CAAC;IACD,OAAO,CAAC,OAAe;QACrB,IAAI,CAAC,IAAI,CAAC;YACR,OAAO,EAAE,IAAI,CAAC,aAAa,CAAC,OAAO;YACnC,KAAK,EAAE,SAAS;YAChB,OAAO,EAAE,OAAO;SACjB,CAAC,CAAC;IACL,CAAC;IACD,OAAO,CAAC,OAAe;QACrB,IAAI,CAAC,IAAI,CAAC;YACR,OAAO,EAAE,IAAI,CAAC,aAAa,CAAC,OAAO;YACnC,KAAK,EAAE,SAAS;YAChB,OAAO,EAAE,OAAO;SACjB,CAAC,CAAC;IACL,CAAC;IACD,MAAM,CAAC,OAAe;QACpB,IAAI,CAAC,IAAI,CAAC;YACR,OAAO,EAAE,IAAI,CAAC,aAAa,CAAC,OAAO;YACnC,KAAK,EAAE,QAAQ;YACf,OAAO,EAAE,OAAO;SACjB,CAAC,CAAC;IACL,CAAC;IAED,IAAI,CAAC,MAA4B;QAC/B,MAAM,GAAG,GAAG,MAAM,CAAC,MAAM,CACvB;YACE,WAAW,EAAE,IAAI;YACjB,QAAQ,EAAE,IAAI,CAAC,aAAa,CAAC,QAAQ,IAAI,eAAe;SACzD,EACD,MAAM,CACP,CAAC;QACF,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAEpC,IAAI,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;YAC7B,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC,MAAM,IAAI,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;gBAC3D,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE;oBACnC,OAAO,CAAC,GAAG,KAAK,EAAE,GAAG,CAAC,CAAC;gBACzB,CAAC,CAAC,CAAC;gBACH,OAAO;YACT,CAAC;QACH,CAAC;QAED,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,gBAAgB,EAAE;YACnD,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;YAChB,cAAc,EAAE,IAAI,CAAC,cAAc;SACpC,CAAC,CAAC;QAEH,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE;YACjC,OAAO,CAAC,GAAG,KAAK,EAAE,SAAS,CAAC,EAAE,CAAC,CAAC;QAClC,CAAC,CAAC,CAAC;QAEH,MAAM,QAAQ,GAAG,SAAS,CAAC,iBAAqC,CAAC;QACjE,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,EAAE;YAC9B,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE;gBACjC,OAAO,CAAC,GAAG,KAAK,CAAC,CAAC,MAAM,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,KAAK,SAAS,CAAC,EAAE,CAAC,CAAC;YACpE,CAAC,CAAC,CAAC;YACH,UAAU,CAAC,GAAG,EAAE;gBACd,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;YACrC,CAAC,EAAE,CAAC,CAAC,CAAC;QACR,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,0BAA0B;QAChC,MAAM,GAAG,GAAgB;YACvB,WAAW,EAAE,KAAK;YAClB,KAAK,EAAE,IAAI,CAAC,eAAe,EAAE;YAC7B,QAAQ,EAAE,eAAe;YACzB,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,gBAAgB,EAAE;YACnD,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;YAChB,cAAc,EAAE,IAAI,CAAC,cAAc;SACpC,CAAC,CAAC;QACH,IAAI,CAAC,mBAAmB,CAAC,GAAG,CAAC,SAAS,CAAC,iBAAqC,CAAC,CAAC;IAChF,CAAC;IAEO,UAAU,CAAC,aAAyB,EAAE,GAAW;QACvD,MAAM,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,WAAW;aACjC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,iBAAqC,CAAC;aACnD,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE,QAAQ,IAAI,aAAa,CAAC,CAAC;QAEtD,IAAI,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,KAAK,EAAE,EAAE;YAC9B,MAAM,GAAG,GAAG,IAAI,CAAC,qBAAqB,CAAC,KAAK,EAAE,GAAG,EAAE,IAAI,EAAE,aAAa,CAAC,CAAC;YACxE,OAAO,CAAC,GAAG,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;YAE5B,IAAI,CAAC,mBAAmB,CACtB,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,gBAA0C,EACnE,aAAa,EACb,GAAG,EACH,GAAG,CACJ,CAAC,KAAK,EAAE,CAAC;QACZ,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,qBAAqB,CAAC,KAAa,EAAE,GAAW,EAAE,IAAwB,EAAE,aAAqB;QACvG,IAAI,KAAK,KAAK,CAAC,EAAE,CAAC;YAChB,OAAO,GAAG,GAAG,IAAI,CAAC;QACpB,CAAC;QACD,MAAM,gBAAgB,GAAG,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC;QACzC,IAAI,aAAa,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,QAAQ,EAAE,CAAC;YAC5C,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,iBAAqC,CAAC;aACnD,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,EAAE,QAAQ,IAAI,QAAQ,CAAC,CAAC;QACjD,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;8GArPU,cAAc;kHAAd,cAAc;;2FAAd,cAAc;kBAD1B,UAAU","sourcesContent":["import { AXLocation, AXStyleColorType } from '@acorex/components/common';\nimport { Dialog } from '@angular/cdk/dialog';\nimport { GlobalPositionStrategy, ScrollStrategy, ScrollStrategyOptions } from '@angular/cdk/overlay';\nimport { Injectable, WritableSignal, effect, inject, signal } from '@angular/core';\nimport { AXToastData, AXToastDisplayConfig, AXToastRef } from './toast.class';\nimport { AXToastComponent } from './toast.component';\nimport { AXToastConfig, AX_TOAST_CONFIG } from './toast.config';\n\n@Injectable()\nexport class AXToastService {\n  private dialog: Dialog = inject(Dialog);\n  private defaultConfig: AXToastConfig = inject(AX_TOAST_CONFIG);\n  private activeToasts: WritableSignal<string[]> = signal([]);\n  private reservedToasts: WritableSignal<AXToastDisplayConfig[]> = signal([]);\n  private toastCounterElement: WritableSignal<AXToastComponent | null> = signal(null);\n  private reserveCounter = signal(0);\n  private moreToastsColor: WritableSignal<AXStyleColorType> = signal('primary');\n\n  scrollStrategy: ScrollStrategy;\n\n  constructor(private readonly scrollStrategyOptions: ScrollStrategyOptions) {\n    this.scrollStrategy = this.scrollStrategyOptions.noop();\n    if (this.defaultConfig.limit) {\n      effect(\n        () => {\n          if (this.activeToasts().length <= this.defaultConfig.limit - 1 && this.reservedToasts().length) {\n            this.show(this.reservedToasts()[0]);\n            this.reservedToasts.update((value) => {\n              const arr = [...value];\n              arr.shift();\n              return arr;\n            });\n          }\n          if (this.reservedToasts().length !== this.reserveCounter()) {\n            this.reserveCounter.set(this.reservedToasts().length);\n            if (this.toastCounterElement() !== null) {\n              this.toastCounterElement().close();\n            }\n            this.createReservedCounterToast();\n          }\n          if (this.reserveCounter() === 0) {\n            if (this.toastCounterElement() !== null) {\n              this.toastCounterElement().close();\n            }\n          }\n        },\n        { allowSignalWrites: true },\n      );\n    }\n  }\n\n  primary(content: string) {\n    this.show({\n      timeOut: this.defaultConfig.timeOut,\n      color: 'primary',\n      content: content,\n    });\n  }\n  secondary(content: string) {\n    this.show({\n      timeOut: this.defaultConfig.timeOut,\n      color: 'secondary',\n      content: content,\n    });\n  }\n  success(content: string) {\n    this.show({\n      timeOut: this.defaultConfig.timeOut,\n      color: 'success',\n      content: content,\n    });\n  }\n  warning(content: string) {\n    this.show({\n      timeOut: this.defaultConfig.timeOut,\n      color: 'warning',\n      content: content,\n    });\n  }\n  danger(content: string) {\n    this.show({\n      timeOut: this.defaultConfig.timeOut,\n      color: 'danger',\n      content: content,\n    });\n  }\n\n  show(config: AXToastDisplayConfig): AXToastRef | void {\n    const opt = Object.assign(\n      {\n        closeButton: true,\n        location: this.defaultConfig.location ?? 'bottom-center',\n      },\n      config,\n    );\n    this.moreToastsColor.set(opt.color);\n\n    if (this.defaultConfig.limit) {\n      if (this.activeToasts().length >= this.defaultConfig.limit) {\n        this.reservedToasts.update((value) => {\n          return [...value, opt];\n        });\n        return;\n      }\n    }\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(AXToastComponent, {\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      scrollStrategy: this.scrollStrategy,\n    });\n\n    this.activeToasts.update((value) => {\n      return [...value, dialogRef.id];\n    });\n\n    const toastRef = dialogRef.componentInstance as AXToastComponent;\n    dialogRef.closed.subscribe(() => {\n      this.activeToasts.update((value) => {\n        return [...value].filter((dialogID) => dialogID !== dialogRef.id);\n      });\n      setTimeout(() => {\n        this.reposition(opt.location, gap);\n      }, 0);\n    });\n\n    return {\n      close: () => {\n        toastRef.close();\n      },\n    };\n  }\n\n  public hideAll() {\n    this.dialog.closeAll();\n  }\n\n  private createReservedCounterToast() {\n    const opt: AXToastData = {\n      closeButton: false,\n      color: this.moreToastsColor(),\n      location: 'bottom-center',\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(AXToastComponent, {\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      scrollStrategy: this.scrollStrategy,\n    });\n    this.toastCounterElement.set(dialogRef.componentInstance as AXToastComponent);\n  }\n\n  private reposition(toastLocation: AXLocation, gap: number): void {\n    const list = this.dialog.openDialogs\n      .map((c) => c.componentInstance as AXToastComponent)\n      .filter((c) => c.config?.location == toastLocation);\n\n    list.forEach((element, index) => {\n      const pos = this.getRepositionPosition(index, gap, list, toastLocation);\n      console.log(index, element);\n\n      this.getPositionStrategy(\n        element.dialogRef.config.positionStrategy as GlobalPositionStrategy,\n        toastLocation,\n        pos,\n        gap,\n      ).apply();\n    });\n  }\n\n  private getRepositionPosition(index: number, gap: number, list: AXToastComponent[], toastLocation: string) {\n    if (index === 0) {\n      return gap + 'px';\n    }\n    const previouseElement = list[index - 1];\n    if (toastLocation.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 AXToastComponent)\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"]}
234
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toast.service.js","sourceRoot":"","sources":["../../../../../../libs/components/toast/src/lib/toast.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { AXLocation, AXStyleColorType } from '@acorex/components/common';\nimport { Dialog } from '@angular/cdk/dialog';\nimport { GlobalPositionStrategy, ScrollStrategy, ScrollStrategyOptions } from '@angular/cdk/overlay';\nimport { Injectable, effect, inject, signal } from '@angular/core';\nimport { AXToastData, AXToastDisplayConfig, AXToastRef } from './toast.class';\nimport { AXToastComponent } from './toast.component';\nimport { AXToastConfig, AX_TOAST_CONFIG } from './toast.config';\n\n@Injectable()\nexport class AXToastService {\n  private dialog: Dialog = inject(Dialog);\n  private defaultConfig: AXToastConfig = inject(AX_TOAST_CONFIG);\n  private activeToasts = signal<string[]>([]);\n  private reservedToasts = signal<AXToastDisplayConfig[]>([]);\n  private toastCounterElement = signal<AXToastComponent | null>(null);\n  private moreToastsColor = signal<AXStyleColorType>('primary');\n  private moreToastsLocation = signal<AXLocation>('bottom-center');\n  private reserveCounter = signal(0);\n\n  scrollStrategy: ScrollStrategy;\n\n  constructor(private readonly scrollStrategyOptions: ScrollStrategyOptions) {\n    this.scrollStrategy = this.scrollStrategyOptions.noop();\n  }\n\n  #effect = effect(\n    () => {\n      if (this.defaultConfig.limit <= 0) return;\n      this.handleShowReservedToast();\n      this.handleShowReservedToastCounter();\n      this.handleReserveCounter();\n    },\n    { allowSignalWrites: true },\n  );\n\n  primary(content: string) {\n    this.show({\n      timeOut: this.defaultConfig.timeOut,\n      color: 'primary',\n      content: content,\n    });\n  }\n  secondary(content: string) {\n    this.show({\n      timeOut: this.defaultConfig.timeOut,\n      color: 'secondary',\n      content: content,\n    });\n  }\n  success(content: string) {\n    this.show({\n      timeOut: this.defaultConfig.timeOut,\n      color: 'success',\n      content: content,\n    });\n  }\n  warning(content: string) {\n    this.show({\n      timeOut: this.defaultConfig.timeOut,\n      color: 'warning',\n      content: content,\n    });\n  }\n  danger(content: string) {\n    this.show({\n      timeOut: this.defaultConfig.timeOut,\n      color: 'danger',\n      content: content,\n    });\n  }\n\n  show(config: AXToastDisplayConfig): AXToastRef {\n    const opt = Object.assign(\n      {\n        closeButton: true,\n        location: this.defaultConfig.location ?? 'bottom-center',\n      },\n      config,\n    );\n    this.moreToastsColor.set(opt.color);\n    this.moreToastsLocation.set(opt.location);\n\n    if (this.defaultConfig.limit > 0) {\n      if (this.activeToasts().length >= this.defaultConfig.limit) {\n        this.reservedToasts.update((value) => [...value, opt]);\n        return {\n          close: () => {\n            //TODO close reserved toast\n          },\n        };\n      }\n    }\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(AXToastComponent, {\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      scrollStrategy: this.scrollStrategy,\n    });\n\n    this.activeToasts.update((value) => [...value, dialogRef.id]);\n\n    const toastRef = dialogRef.componentInstance as AXToastComponent;\n    dialogRef.closed.subscribe(() => {\n      this.activeToasts.update((value) => [...value].filter((dialogID) => dialogID !== dialogRef.id));\n      setTimeout(() => {\n        this.reposition(opt.location, gap);\n      }, 0);\n    });\n\n    return {\n      close: () => {\n        toastRef.close();\n      },\n    };\n  }\n\n  hideAll() {\n    this.dialog.closeAll();\n  }\n\n  private handleShowReservedToast() {\n    if (this.activeToasts().length > this.defaultConfig.limit - 1) return;\n    if (!this.reservedToasts().length) return;\n    this.show(this.reservedToasts()[0]);\n    this.reservedToasts.update((value) => {\n      const toasts = [...value];\n      toasts.shift();\n      return toasts;\n    });\n  }\n\n  private handleShowReservedToastCounter() {\n    if (this.reservedToasts().length === this.reserveCounter()) return;\n    this.reserveCounter.set(this.reservedToasts().length);\n    if (this.toastCounterElement() !== null) this.toastCounterElement().close();\n    this.createReservedCounterToast();\n  }\n\n  private handleReserveCounter() {\n    if (this.reserveCounter() !== 0) return;\n    if (this.toastCounterElement() === null) return;\n    this.toastCounterElement().close();\n  }\n\n  private createReservedCounterToast() {\n    const opt: AXToastData = {\n      closeButton: false,\n      color: this.moreToastsColor(),\n      location: this.moreToastsLocation(),\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(AXToastComponent, {\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      scrollStrategy: this.scrollStrategy,\n    });\n    this.toastCounterElement.set(dialogRef.componentInstance as AXToastComponent);\n  }\n\n  private reposition(toastLocation: AXLocation, gap: number): void {\n    const list = this.dialog.openDialogs\n      .map((c) => c.componentInstance as AXToastComponent)\n      .filter((c) => c.config?.location == toastLocation);\n\n    list.forEach((element, index) => {\n      const pos = this.getRepositionPosition(index, gap, list, toastLocation);\n      console.log(index, element);\n\n      this.getPositionStrategy(\n        element.dialogRef.config.positionStrategy as GlobalPositionStrategy,\n        toastLocation,\n        pos,\n        gap,\n      ).apply();\n    });\n  }\n\n  private getRepositionPosition(index: number, gap: number, list: AXToastComponent[], toastLocation: string) {\n    if (index === 0) return gap + 'px';\n    const previouseElement = list[index - 1];\n    if (toastLocation.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 AXToastComponent)\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"]}
@@ -274,7 +274,13 @@ const AX_PLACEMENT_MAP = {
274
274
  },
275
275
  'bottom-start': {
276
276
  origin: AX_PLACEMENT_BOTTOM_START,
277
- alts: [AX_PLACEMENT_BOTTOM_END, AX_PLACEMENT_TOP_START, AX_PLACEMENT_TOP_END],
277
+ alts: [
278
+ AX_PLACEMENT_BOTTOM_END,
279
+ AX_PLACEMENT_TOP_START,
280
+ AX_PLACEMENT_TOP_END,
281
+ AX_PLACEMENT_START,
282
+ AX_PLACEMENT_END,
283
+ ],
278
284
  },
279
285
  'bottom-end': {
280
286
  origin: AX_PLACEMENT_BOTTOM_END,