@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.
Files changed (32) hide show
  1. package/dialog/lib/dialog.component.d.ts +11 -11
  2. package/dialog/lib/dialog.service.d.ts +2 -2
  3. package/esm2022/common/lib/types/placement.mjs +8 -2
  4. package/esm2022/datetime-picker/lib/datetime-picker.component.mjs +3 -3
  5. package/esm2022/dialog/lib/dialog.component.mjs +12 -12
  6. package/esm2022/dialog/lib/dialog.service.mjs +5 -5
  7. package/esm2022/form/lib/validation-rule.directive.mjs +1 -1
  8. package/esm2022/notification/lib/notification.component.mjs +4 -4
  9. package/esm2022/notification/lib/notification.config.mjs +2 -1
  10. package/esm2022/notification/lib/notification.service.mjs +137 -39
  11. package/esm2022/toast/lib/toast.component.mjs +2 -2
  12. package/esm2022/toast/lib/toast.config.mjs +2 -1
  13. package/esm2022/toast/lib/toast.service.mjs +140 -36
  14. package/fesm2022/acorex-components-common.mjs +7 -1
  15. package/fesm2022/acorex-components-common.mjs.map +1 -1
  16. package/fesm2022/acorex-components-datetime-picker.mjs +2 -2
  17. package/fesm2022/acorex-components-datetime-picker.mjs.map +1 -1
  18. package/fesm2022/acorex-components-dialog.mjs +15 -15
  19. package/fesm2022/acorex-components-dialog.mjs.map +1 -1
  20. package/fesm2022/acorex-components-form.mjs.map +1 -1
  21. package/fesm2022/acorex-components-notification.mjs +139 -40
  22. package/fesm2022/acorex-components-notification.mjs.map +1 -1
  23. package/fesm2022/acorex-components-toast.mjs +140 -35
  24. package/fesm2022/acorex-components-toast.mjs.map +1 -1
  25. package/form/lib/validation-rule.directive.d.ts +1 -1
  26. package/notification/lib/notification.component.d.ts +3 -3
  27. package/notification/lib/notification.config.d.ts +1 -0
  28. package/notification/lib/notification.service.d.ts +13 -0
  29. package/package.json +1 -1
  30. package/toast/lib/toast.component.d.ts +1 -1
  31. package/toast/lib/toast.config.d.ts +1 -0
  32. package/toast/lib/toast.service.d.ts +13 -0
@@ -1,6 +1,6 @@
1
1
  import { Dialog } from '@angular/cdk/dialog';
2
2
  import { GlobalPositionStrategy, ScrollStrategyOptions } from '@angular/cdk/overlay';
3
- import { Injectable, inject } from '@angular/core';
3
+ import { Injectable, effect, inject, signal } from '@angular/core';
4
4
  import { AXToastComponent } from './toast.component';
5
5
  import { AX_TOAST_CONFIG } from './toast.config';
6
6
  import * as i0 from "@angular/core";
@@ -10,8 +10,22 @@ export class AXToastService {
10
10
  this.scrollStrategyOptions = scrollStrategyOptions;
11
11
  this.dialog = inject(Dialog);
12
12
  this.defaultConfig = inject(AX_TOAST_CONFIG);
13
+ this.activeToasts = signal([]);
14
+ this.reservedToasts = signal([]);
15
+ this.toastCounterElement = signal(null);
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 });
13
26
  this.scrollStrategy = this.scrollStrategyOptions.noop();
14
27
  }
28
+ #effect;
15
29
  primary(content) {
16
30
  this.show({
17
31
  timeOut: this.defaultConfig.timeOut,
@@ -52,35 +66,21 @@ export class AXToastService {
52
66
  closeButton: true,
53
67
  location: this.defaultConfig.location ?? 'bottom-center',
54
68
  }, config);
69
+ this.moreToastsColor.set(opt.color);
70
+ this.moreToastsLocation.set(opt.location);
71
+ if (this.defaultConfig.limit > 0) {
72
+ if (this.activeToasts().length >= this.defaultConfig.limit) {
73
+ this.reservedToasts.update((value) => [...value, opt]);
74
+ return {
75
+ close: () => {
76
+ //TODO close reserved toast
77
+ },
78
+ };
79
+ }
80
+ }
55
81
  const gap = this.defaultConfig.gap;
56
- let positionStrategy = new GlobalPositionStrategy();
57
82
  const pos = this.getPosition(opt.location) + gap + 'px';
58
- switch (opt.location) {
59
- case 'bottom-center':
60
- positionStrategy = positionStrategy.bottom(pos).centerHorizontally();
61
- break;
62
- case 'bottom-end':
63
- positionStrategy = positionStrategy.bottom(pos).right(gap + 'px');
64
- break;
65
- case 'bottom-start':
66
- positionStrategy = positionStrategy.bottom(pos).left(gap + 'px');
67
- break;
68
- case 'top-center':
69
- positionStrategy = positionStrategy.top(pos).centerHorizontally();
70
- break;
71
- case 'top-end':
72
- positionStrategy = positionStrategy.top(pos).right(gap + 'px');
73
- break;
74
- case 'top-start':
75
- positionStrategy = positionStrategy.top(pos).left(gap + 'px');
76
- break;
77
- case 'center-start':
78
- positionStrategy = positionStrategy.centerVertically().left(gap + 'px');
79
- break;
80
- case 'center-end':
81
- positionStrategy = positionStrategy.centerVertically().right(gap + 'px');
82
- break;
83
- }
83
+ const positionStrategy = this.getPositionStrategy(new GlobalPositionStrategy(), opt.location, pos, gap);
84
84
  const dialogRef = this.dialog.open(AXToastComponent, {
85
85
  data: opt,
86
86
  autoFocus: '__no_element__',
@@ -91,12 +91,16 @@ export class AXToastService {
91
91
  closeOnDestroy: true,
92
92
  hasBackdrop: false,
93
93
  panelClass: ['ax-animate-animated', 'ax-animate-fadeIn', 'ax-animate-faster'],
94
- positionStrategy: positionStrategy,
94
+ positionStrategy,
95
95
  scrollStrategy: this.scrollStrategy,
96
96
  });
97
+ this.activeToasts.update((value) => [...value, dialogRef.id]);
97
98
  const toastRef = dialogRef.componentInstance;
98
99
  dialogRef.closed.subscribe(() => {
99
- this.reposition();
100
+ this.activeToasts.update((value) => [...value].filter((dialogID) => dialogID !== dialogRef.id));
101
+ setTimeout(() => {
102
+ this.reposition(opt.location, gap);
103
+ }, 0);
100
104
  });
101
105
  return {
102
106
  close: () => {
@@ -107,18 +111,118 @@ export class AXToastService {
107
111
  hideAll() {
108
112
  this.dialog.closeAll();
109
113
  }
110
- reposition() {
111
- //TODO: reposition vertically afer close toast
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
+ }
141
+ createReservedCounterToast() {
142
+ const opt = {
143
+ closeButton: false,
144
+ color: this.moreToastsColor(),
145
+ location: this.moreToastsLocation(),
146
+ title: `And ${this.reserveCounter()} more...`,
147
+ timeOutProgress: false,
148
+ };
149
+ const gap = this.defaultConfig.gap;
150
+ const pos = this.getPosition(opt.location) + gap + 'px';
151
+ const positionStrategy = this.getPositionStrategy(new GlobalPositionStrategy(), opt.location, pos, gap);
152
+ const dialogRef = this.dialog.open(AXToastComponent, {
153
+ data: opt,
154
+ autoFocus: '__no_element__',
155
+ restoreFocus: true,
156
+ role: 'dialog',
157
+ ariaModal: true,
158
+ closeOnNavigation: true,
159
+ closeOnDestroy: true,
160
+ hasBackdrop: false,
161
+ panelClass: ['ax-animate-animated', 'ax-animate-fadeIn', 'ax-animate-faster'],
162
+ positionStrategy,
163
+ scrollStrategy: this.scrollStrategy,
164
+ });
165
+ this.toastCounterElement.set(dialogRef.componentInstance);
166
+ }
167
+ reposition(toastLocation, gap) {
168
+ const list = this.dialog.openDialogs
169
+ .map((c) => c.componentInstance)
170
+ .filter((c) => c.config?.location == toastLocation);
171
+ list.forEach((element, index) => {
172
+ const pos = this.getRepositionPosition(index, gap, list, toastLocation);
173
+ console.log(index, element);
174
+ this.getPositionStrategy(element.dialogRef.config.positionStrategy, toastLocation, pos, gap).apply();
175
+ });
176
+ }
177
+ getRepositionPosition(index, gap, list, toastLocation) {
178
+ if (index === 0)
179
+ return gap + 'px';
180
+ const previouseElement = list[index - 1];
181
+ if (toastLocation.split('-')[0] == 'bottom') {
182
+ return window.innerHeight - previouseElement.getHostElement().offsetTop + gap + 'px';
183
+ }
184
+ return (previouseElement.getHostElement().offsetTop +
185
+ previouseElement.getHostElement().offsetHeight +
186
+ gap +
187
+ 'px');
112
188
  }
113
189
  getPosition(location) {
114
- const list = this.dialog.openDialogs.map((c) => c.componentInstance).filter((c) => c.config?.location == location);
190
+ const list = this.dialog.openDialogs
191
+ .map((c) => c.componentInstance)
192
+ .filter((c) => c.config?.location == location);
115
193
  if (list.length == 0)
116
194
  return 0;
117
195
  if (location.split('-')[0] == 'bottom') {
118
196
  return window.innerHeight - list[list.length - 1].getHostElement().offsetTop;
119
197
  }
120
- else {
121
- return list[list.length - 1].getHostElement().offsetTop + list[list.length - 1].getHostElement().offsetHeight;
198
+ return (list[list.length - 1].getHostElement().offsetTop + list[list.length - 1].getHostElement().offsetHeight);
199
+ }
200
+ getPositionStrategy(positionStrategy, location, pos, gap) {
201
+ switch (location) {
202
+ case 'bottom-center':
203
+ return positionStrategy.bottom(pos).centerHorizontally();
204
+ break;
205
+ case 'bottom-end':
206
+ return positionStrategy.bottom(pos).right(gap + 'px');
207
+ break;
208
+ case 'bottom-start':
209
+ return positionStrategy.bottom(pos).left(gap + 'px');
210
+ break;
211
+ case 'top-center':
212
+ return positionStrategy.top(pos).centerHorizontally();
213
+ break;
214
+ case 'top-end':
215
+ return positionStrategy.top(pos).right(gap + 'px');
216
+ break;
217
+ case 'top-start':
218
+ return positionStrategy.top(pos).left(gap + 'px');
219
+ break;
220
+ case 'center-start':
221
+ return positionStrategy.centerVertically().left(gap + 'px');
222
+ break;
223
+ case 'center-end':
224
+ return positionStrategy.centerVertically().right(gap + 'px');
225
+ break;
122
226
  }
123
227
  }
124
228
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXToastService, deps: [{ token: i1.ScrollStrategyOptions }], target: i0.ɵɵFactoryTarget.Injectable }); }
@@ -127,4 +231,4 @@ export class AXToastService {
127
231
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXToastService, decorators: [{
128
232
  type: Injectable
129
233
  }], ctorParameters: () => [{ type: i1.ScrollStrategyOptions }] });
130
- //# 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 { Dialog } from '@angular/cdk/dialog';\nimport { GlobalPositionStrategy, ScrollStrategy, ScrollStrategyOptions } from '@angular/cdk/overlay';\nimport { Injectable, inject } from '@angular/core';\nimport { 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\n  scrollStrategy: ScrollStrategy;\n\n  constructor(private readonly scrollStrategyOptions: ScrollStrategyOptions) {\n    this.scrollStrategy = this.scrollStrategyOptions.noop();\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\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  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    const gap = this.defaultConfig.gap;\n\n    let positionStrategy = new GlobalPositionStrategy();\n    const pos = this.getPosition(opt.location) + gap + 'px';\n    switch (opt.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    }\n\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: positionStrategy,\n      scrollStrategy: this.scrollStrategy,\n    });\n\n    const toastRef = dialogRef.componentInstance as AXToastComponent;\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.map((c) => c.componentInstance as AXToastComponent).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"]}
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,