@daffodil/design 0.67.0 → 0.68.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (79) hide show
  1. package/esm2022/article/article/article.component.mjs +2 -2
  2. package/esm2022/article/examples/article-headings/article-headings.component.mjs +3 -4
  3. package/esm2022/loading-icon/examples/loading-icon-color/loading-icon-color.component.mjs +3 -3
  4. package/esm2022/loading-icon/loading-icon/loading-icon.component.mjs +3 -3
  5. package/esm2022/modal/service/modal.service.mjs +2 -3
  6. package/esm2022/toast/daffodil-design-toast.mjs +5 -0
  7. package/esm2022/toast/examples/daffodil-design-toast-examples.mjs +5 -0
  8. package/esm2022/toast/examples/default-toast/default-toast.component.mjs +38 -0
  9. package/esm2022/toast/examples/default-toast/default-toast.module.mjs +36 -0
  10. package/esm2022/toast/examples/index.mjs +2 -0
  11. package/esm2022/toast/examples/public_api.mjs +15 -0
  12. package/esm2022/toast/examples/toast-positions/toast-positions.component.mjs +42 -0
  13. package/esm2022/toast/examples/toast-positions/toast-positions.module.mjs +57 -0
  14. package/esm2022/toast/examples/toast-status/toast-status.component.mjs +45 -0
  15. package/esm2022/toast/examples/toast-status/toast-status.module.mjs +40 -0
  16. package/esm2022/toast/examples/toast-with-custom-duration/toast-with-custom-duration.component.mjs +26 -0
  17. package/esm2022/toast/examples/toast-with-custom-duration/toast-with-custom-duration.module.mjs +32 -0
  18. package/esm2022/toast/index.mjs +2 -0
  19. package/esm2022/toast/interfaces/toast-action.mjs +2 -0
  20. package/esm2022/toast/interfaces/toast.mjs +2 -0
  21. package/esm2022/toast/options/daff-toast-options.mjs +16 -0
  22. package/esm2022/toast/public_api.mjs +9 -0
  23. package/esm2022/toast/service/changes-focus.mjs +2 -0
  24. package/esm2022/toast/service/position-strategy.mjs +29 -0
  25. package/esm2022/toast/service/position.service.mjs +33 -0
  26. package/esm2022/toast/service/toast.service.mjs +116 -0
  27. package/esm2022/toast/toast/toast-config.mjs +2 -0
  28. package/esm2022/toast/toast/toast-template.component.mjs +262 -0
  29. package/esm2022/toast/toast/toast.component.mjs +82 -0
  30. package/esm2022/toast/toast-actions/toast-actions.directive.mjs +19 -0
  31. package/esm2022/toast/toast-message/toast-message.directive.mjs +19 -0
  32. package/esm2022/toast/toast-title/toast-title.directive.mjs +19 -0
  33. package/esm2022/toast/toast.module.mjs +70 -0
  34. package/fesm2022/daffodil-design-article-examples.mjs +2 -2
  35. package/fesm2022/daffodil-design-article-examples.mjs.map +1 -1
  36. package/fesm2022/daffodil-design-article.mjs +2 -2
  37. package/fesm2022/daffodil-design-article.mjs.map +1 -1
  38. package/fesm2022/daffodil-design-loading-icon-examples.mjs +2 -2
  39. package/fesm2022/daffodil-design-loading-icon-examples.mjs.map +1 -1
  40. package/fesm2022/daffodil-design-loading-icon.mjs +2 -2
  41. package/fesm2022/daffodil-design-loading-icon.mjs.map +1 -1
  42. package/fesm2022/daffodil-design-modal.mjs +1 -2
  43. package/fesm2022/daffodil-design-modal.mjs.map +1 -1
  44. package/fesm2022/daffodil-design-toast-examples.mjs +287 -0
  45. package/fesm2022/daffodil-design-toast-examples.mjs.map +1 -0
  46. package/fesm2022/daffodil-design-toast.mjs +625 -0
  47. package/fesm2022/daffodil-design-toast.mjs.map +1 -0
  48. package/loading-icon/src/loading-icon-theme.scss +24 -8
  49. package/navbar/README.md +1 -1
  50. package/package.json +1 -1
  51. package/scss/theme.scss +2 -0
  52. package/toast/README.md +115 -0
  53. package/toast/examples/default-toast/default-toast.component.d.ts +15 -0
  54. package/toast/examples/default-toast/default-toast.module.d.ts +11 -0
  55. package/toast/examples/index.d.ts +1 -0
  56. package/toast/examples/public_api.d.ts +2 -0
  57. package/toast/examples/toast-positions/toast-positions.component.d.ts +17 -0
  58. package/toast/examples/toast-positions/toast-positions.module.d.ts +12 -0
  59. package/toast/examples/toast-status/toast-status.component.d.ts +14 -0
  60. package/toast/examples/toast-status/toast-status.module.d.ts +12 -0
  61. package/toast/examples/toast-with-custom-duration/toast-with-custom-duration.component.d.ts +10 -0
  62. package/toast/examples/toast-with-custom-duration/toast-with-custom-duration.module.d.ts +10 -0
  63. package/toast/index.d.ts +1 -0
  64. package/toast/interfaces/toast-action.d.ts +38 -0
  65. package/toast/interfaces/toast.d.ts +20 -0
  66. package/toast/options/daff-toast-options.d.ts +15 -0
  67. package/toast/public_api.d.ts +11 -0
  68. package/toast/service/changes-focus.d.ts +2 -0
  69. package/toast/service/position-strategy.d.ts +3 -0
  70. package/toast/service/position.service.d.ts +15 -0
  71. package/toast/service/toast.service.d.ts +29 -0
  72. package/toast/src/toast-theme.scss +63 -0
  73. package/toast/toast/toast-config.d.ts +7 -0
  74. package/toast/toast/toast-template.component.d.ts +20 -0
  75. package/toast/toast/toast.component.d.ts +52 -0
  76. package/toast/toast-actions/toast-actions.directive.d.ts +6 -0
  77. package/toast/toast-message/toast-message.directive.d.ts +6 -0
  78. package/toast/toast-title/toast-title.directive.d.ts +6 -0
  79. package/toast/toast.module.d.ts +17 -0
@@ -0,0 +1,32 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { NgModule } from '@angular/core';
3
+ import { DaffButtonModule } from '@daffodil/design/button';
4
+ import { DaffToastModule } from '@daffodil/design/toast';
5
+ import { ToastWithCustomDurationComponent } from './toast-with-custom-duration.component';
6
+ import * as i0 from "@angular/core";
7
+ export class ToastWithCustomDurationModule {
8
+ /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.1", ngImport: i0, type: ToastWithCustomDurationModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
9
+ /** @nocollapse */ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.1.1", ngImport: i0, type: ToastWithCustomDurationModule, declarations: [ToastWithCustomDurationComponent], imports: [CommonModule,
10
+ DaffToastModule,
11
+ DaffButtonModule], exports: [ToastWithCustomDurationComponent] }); }
12
+ /** @nocollapse */ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.1.1", ngImport: i0, type: ToastWithCustomDurationModule, imports: [CommonModule,
13
+ DaffToastModule,
14
+ DaffButtonModule] }); }
15
+ }
16
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.1", ngImport: i0, type: ToastWithCustomDurationModule, decorators: [{
17
+ type: NgModule,
18
+ args: [{
19
+ declarations: [
20
+ ToastWithCustomDurationComponent,
21
+ ],
22
+ imports: [
23
+ CommonModule,
24
+ DaffToastModule,
25
+ DaffButtonModule,
26
+ ],
27
+ exports: [
28
+ ToastWithCustomDurationComponent,
29
+ ],
30
+ }]
31
+ }] });
32
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9hc3Qtd2l0aC1jdXN0b20tZHVyYXRpb24ubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9kZXNpZ24vdG9hc3QvZXhhbXBsZXMvc3JjL3RvYXN0LXdpdGgtY3VzdG9tLWR1cmF0aW9uL3RvYXN0LXdpdGgtY3VzdG9tLWR1cmF0aW9uLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV6QyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFFekQsT0FBTyxFQUFFLGdDQUFnQyxFQUFFLE1BQU0sd0NBQXdDLENBQUM7O0FBZTFGLE1BQU0sT0FBTyw2QkFBNkI7aUlBQTdCLDZCQUE2QjtrSUFBN0IsNkJBQTZCLGlCQVh0QyxnQ0FBZ0MsYUFHaEMsWUFBWTtZQUNaLGVBQWU7WUFDZixnQkFBZ0IsYUFHaEIsZ0NBQWdDO2tJQUd2Qiw2QkFBNkIsWUFSdEMsWUFBWTtZQUNaLGVBQWU7WUFDZixnQkFBZ0I7OzJGQU1QLDZCQUE2QjtrQkFiekMsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUU7d0JBQ1osZ0NBQWdDO3FCQUNqQztvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixlQUFlO3dCQUNmLGdCQUFnQjtxQkFDakI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLGdDQUFnQztxQkFDakM7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHsgRGFmZkJ1dHRvbk1vZHVsZSB9IGZyb20gJ0BkYWZmb2RpbC9kZXNpZ24vYnV0dG9uJztcbmltcG9ydCB7IERhZmZUb2FzdE1vZHVsZSB9IGZyb20gJ0BkYWZmb2RpbC9kZXNpZ24vdG9hc3QnO1xuXG5pbXBvcnQgeyBUb2FzdFdpdGhDdXN0b21EdXJhdGlvbkNvbXBvbmVudCB9IGZyb20gJy4vdG9hc3Qtd2l0aC1jdXN0b20tZHVyYXRpb24uY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgVG9hc3RXaXRoQ3VzdG9tRHVyYXRpb25Db21wb25lbnQsXG4gIF0sXG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgRGFmZlRvYXN0TW9kdWxlLFxuICAgIERhZmZCdXR0b25Nb2R1bGUsXG4gIF0sXG4gIGV4cG9ydHM6IFtcbiAgICBUb2FzdFdpdGhDdXN0b21EdXJhdGlvbkNvbXBvbmVudCxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgVG9hc3RXaXRoQ3VzdG9tRHVyYXRpb25Nb2R1bGUgeyB9XG4iXX0=
@@ -0,0 +1,2 @@
1
+ export * from './public_api';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL2Rlc2lnbi90b2FzdC9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3B1YmxpY19hcGknO1xuIl19
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9hc3QtYWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9kZXNpZ24vdG9hc3Qvc3JjL2ludGVyZmFjZXMvdG9hc3QtYWN0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFdmVudEVtaXR0ZXIgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHtcbiAgRGFmZlBhbGV0dGUsXG4gIERhZmZTdGF0dXMsXG59IGZyb20gJ0BkYWZmb2RpbC9kZXNpZ24nO1xuXG4vKipcbiAqIEFuIGludGVyZmFjZSBmb3IgcHJvcGVydGllcyBvZiBhY3Rpb25zLCBzcGVjaWZpY2FsbHkgdGhlIERhZmZCdXR0b25Db21wb25lbnQsIHBsYWNlZCBpbnNpZGUgb2YgdGhlIHRvYXN0LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIERhZmZUb2FzdEFjdGlvbiB7XG4gIC8qKlxuICAgKiBUaGUgdHlwZXMgb2YgYnV0dG9ucyBhdmFpbGFibGUgdG8gYmUgdXNlZCwgYXMgZGVmaW5lZCBpbiB0aGUge0BsaW5rIERhZmZCdXR0b25Db21wb25lbnR9LlxuICAgKi9cbiAgdHlwZT86ICdyYWlzZWQnIHwgJ3VuZGVybGluZScgfCAnc3Ryb2tlZCcgfCAnZmxhdCcgfCB1bmRlZmluZWQ7XG5cbiAgLyoqXG4gICAqIFRoZSB0ZXh0IGZvciB0aGUgYnV0dG9uXG4gICAqL1xuICBjb250ZW50OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRoZSBzaXplIG9mIHRoZSBidXR0b24sIGFzIGRlZmluZWQgaW4gdGhlIHtAbGluayBEYWZmQnV0dG9uQ29tcG9uZW50fS5cbiAgICovXG4gIHNpemU/OiAnc20nIHwgJ21kJyB8ICdsZycgfCB1bmRlZmluZWQ7XG5cbiAgLyoqXG4gICAqIFRoZSBjb2xvciBvZiB0aGUgYnV0dG9uLCBhcyBkZWZpbmVkIGluIHRoZSB7QGxpbmsgRGFmZkJ1dHRvbkNvbXBvbmVudH0uXG4gICAqIENvbG9yIGFuZCBzdGF0dXMgc2hvdWxkIG5vdCBiZSB1c2VkIHNpbXVsdGFuZW91c2x5LlxuICAgKi9cbiAgY29sb3I/OiBEYWZmUGFsZXR0ZTtcblxuICAvKipcbiAgICogVGhlIHN0YXR1cyBvZiB0aGUgYnV0dG9uLCBhcyBkZWZpbmVkIGluIHRoZSB7QGxpbmsgRGFmZkJ1dHRvbkNvbXBvbmVudH0uXG4gICAqIENvbG9yIGFuZCBzdGF0dXMgc2hvdWxkIG5vdCBiZSB1c2VkIHNpbXVsdGFuZW91c2x5LlxuICAgKi9cbiAgc3RhdHVzPzogRGFmZlN0YXR1cztcblxuICBkYXRhPzogUmVjb3JkPHN0cmluZywgYW55PjtcblxuICAvKipcbiAgICogU2V0cyBhbiBFdmVudEVtaXR0ZXIgb24gYSBEYWZmVG9hc3RBY3Rpb25cbiAgICovXG4gIGV2ZW50RW1pdHRlcj86IEV2ZW50RW1pdHRlcjxEYWZmVG9hc3RBY3Rpb24+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIERhZmZUb2FzdEFjdGlvbkV2ZW50IHtcbiAgZXZlbnQ6IE1vdXNlRXZlbnQ7XG5cbiAgYWN0aW9uOiBEYWZmVG9hc3RBY3Rpb247XG59XG4iXX0=
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9hc3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2Rlc2lnbi90b2FzdC9zcmMvaW50ZXJmYWNlcy90b2FzdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQgeyBEYWZmU3RhdHVzIH0gZnJvbSAnQGRhZmZvZGlsL2Rlc2lnbic7XG5cbmltcG9ydCB7IERhZmZUb2FzdEFjdGlvbiB9IGZyb20gJy4vdG9hc3QtYWN0aW9uJztcblxuLyoqIFBvc3NpYmxlIGRhdGEgdGhhdCBjYW4gYmUgc2hvd24gb24gYSB0b2FzdCAqL1xuZXhwb3J0IGludGVyZmFjZSBEYWZmVG9hc3REYXRhIHtcbiAgLyoqIEEgdGl0bGUgdGhhdCBwcm92aWRlcyBhIHF1aWNrIG92ZXZpZXcgb2YgdGhlIHRvYXN0ICovXG4gIHRpdGxlOiBzdHJpbmc7XG5cbiAgLyoqIEEgc2hvcnQgbWVzc2FnZSB1c2VkIHRvIHByb3ZpZGUgYWRkaXRpb25hbCBkZXRhaWxzIGFib3V0IHRoZSB0b2FzdCAqL1xuICBtZXNzYWdlPzogc3RyaW5nO1xuXG4gIC8qKiBTZXRzIGEgc3RhdHVzIG9uIHRoZSB0b2FzdCAqL1xuICBzdGF0dXM/OiBEYWZmU3RhdHVzO1xuXG4gIC8qKiBVc2VkIHRvIGRpc3BsYXkgYWN0aW9ucyBpbiB0aGUgdG9hc3QgKi9cbiAgYWN0aW9ucz86IERhZmZUb2FzdEFjdGlvbltdO1xuXG4gIC8qKiBXaGV0aGVyIG9yIG5vdCB0aGUgdG9hc3QgaXMgZGlzbWlzc2libGUgKi9cbiAgZGlzbWlzc2libGU/OiBib29sZWFuO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIERhZmZUb2FzdCBleHRlbmRzIERhZmZUb2FzdERhdGEge1xuICBkaXNtaXNzOiAoKSA9PiB2b2lkO1xuICBkaXNtaXNzYWxTdHJlYW06IE9ic2VydmFibGU8dm9pZCB8IG51bWJlcj47XG59XG4iXX0=
@@ -0,0 +1,16 @@
1
+ import { InjectionToken, } from '@angular/core';
2
+ ;
3
+ ;
4
+ export const daffToastDefaultOptions = {
5
+ position: {
6
+ vertical: 'top',
7
+ horizontal: 'right',
8
+ },
9
+ useParent: true,
10
+ };
11
+ export const DAFF_TOAST_OPTIONS = new InjectionToken('DAFF_TOAST_OPTIONS', { providedIn: 'root', factory: () => daffToastDefaultOptions });
12
+ export const provideDaffToastOptions = (options) => ({ provide: DAFF_TOAST_OPTIONS, useValue: {
13
+ ...daffToastDefaultOptions,
14
+ ...options,
15
+ } });
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGFmZi10b2FzdC1vcHRpb25zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9kZXNpZ24vdG9hc3Qvc3JjL29wdGlvbnMvZGFmZi10b2FzdC1vcHRpb25zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxjQUFjLEdBRWYsTUFBTSxlQUFlLENBQUM7QUFLOEMsQ0FBQztBQUVjLENBQUM7QUFTckYsTUFBTSxDQUFDLE1BQU0sdUJBQXVCLEdBQXFCO0lBQ3ZELFFBQVEsRUFBRTtRQUNSLFFBQVEsRUFBRSxLQUFLO1FBQ2YsVUFBVSxFQUFFLE9BQU87S0FDcEI7SUFDRCxTQUFTLEVBQUUsSUFBSTtDQUNoQixDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sa0JBQWtCLEdBQUcsSUFBSSxjQUFjLENBQUMsb0JBQW9CLEVBQUUsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQyx1QkFBdUIsRUFBRSxDQUFDLENBQUM7QUFFM0ksTUFBTSxDQUFDLE1BQU0sdUJBQXVCLEdBQUcsQ0FBQyxPQUF5QixFQUFpQixFQUFFLENBQUMsQ0FBQyxFQUFFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxRQUFRLEVBQUU7UUFDN0gsR0FBRyx1QkFBdUI7UUFDMUIsR0FBRyxPQUFPO0tBQ1gsRUFBQyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBJbmplY3Rpb25Ub2tlbixcbiAgVmFsdWVQcm92aWRlcixcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbnR5cGUgV2l0aG91dDxULCBVPiA9IHsgW1AgaW4gRXhjbHVkZTxrZXlvZiBULCBrZXlvZiBVPl0/OiBuZXZlciB9O1xudHlwZSBYT1I8VCwgVT4gPSAoVCB8IFUpIGV4dGVuZHMgUmVjb3JkPHN0cmluZyx1bmtub3duPiA/IChXaXRob3V0PFQsIFU+ICYgVSkgfCAoV2l0aG91dDxVLCBUPiAmIFQpIDogVCB8IFU7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVmVydGljYWxQb3NpdGlvblR5cGVzIHsgdmVydGljYWw6ICd0b3AnIHwgJ2JvdHRvbScgfTtcblxuZXhwb3J0IGludGVyZmFjZSBIb3Jpem9udGFsUG9zaXRpb25UeXBlcyB7IGhvcml6b250YWw6ICdsZWZ0JyB8ICdjZW50ZXInIHwgJ3JpZ2h0JyB9O1xuXG5leHBvcnQgdHlwZSBEYWZmVG9hc3RQb3NpdGlvbiA9IFZlcnRpY2FsUG9zaXRpb25UeXBlcyAmIEhvcml6b250YWxQb3NpdGlvblR5cGVzO1xuXG5leHBvcnQgaW50ZXJmYWNlIERhZmZUb2FzdE9wdGlvbnMge1xuICBwb3NpdGlvbjogRGFmZlRvYXN0UG9zaXRpb247XG4gIHVzZVBhcmVudDogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGNvbnN0IGRhZmZUb2FzdERlZmF1bHRPcHRpb25zOiBEYWZmVG9hc3RPcHRpb25zID0ge1xuICBwb3NpdGlvbjoge1xuICAgIHZlcnRpY2FsOiAndG9wJyxcbiAgICBob3Jpem9udGFsOiAncmlnaHQnLFxuICB9LFxuICB1c2VQYXJlbnQ6IHRydWUsXG59O1xuXG5leHBvcnQgY29uc3QgREFGRl9UT0FTVF9PUFRJT05TID0gbmV3IEluamVjdGlvblRva2VuKCdEQUZGX1RPQVNUX09QVElPTlMnLCB7IHByb3ZpZGVkSW46ICdyb290JywgZmFjdG9yeTogKCkgPT4gZGFmZlRvYXN0RGVmYXVsdE9wdGlvbnMgfSk7XG5cbmV4cG9ydCBjb25zdCBwcm92aWRlRGFmZlRvYXN0T3B0aW9ucyA9IChvcHRpb25zOiBEYWZmVG9hc3RPcHRpb25zKTogVmFsdWVQcm92aWRlciA9PiAoeyBwcm92aWRlOiBEQUZGX1RPQVNUX09QVElPTlMsIHVzZVZhbHVlOiB7XG4gIC4uLmRhZmZUb2FzdERlZmF1bHRPcHRpb25zLFxuICAuLi5vcHRpb25zLFxufX0pO1xuIl19
@@ -0,0 +1,9 @@
1
+ export { DaffToastPositionService } from './service/position.service';
2
+ export { DaffToastModule } from './toast.module';
3
+ export { DaffToastService } from './service/toast.service';
4
+ export { DAFF_TOAST_OPTIONS, provideDaffToastOptions, } from './options/daff-toast-options';
5
+ export * from './toast/toast.component';
6
+ export * from './toast-actions/toast-actions.directive';
7
+ export * from './toast-title/toast-title.directive';
8
+ export * from './toast-message/toast-message.directive';
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL2xpYnMvZGVzaWduL3RvYXN0L3NyYy9wdWJsaWNfYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQ3RFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNqRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQVMzRCxPQUFPLEVBQ0wsa0JBQWtCLEVBQ2xCLHVCQUF1QixHQUN4QixNQUFNLDhCQUE4QixDQUFDO0FBRXRDLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMseUNBQXlDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBEYWZmVG9hc3RQb3NpdGlvblNlcnZpY2UgfSBmcm9tICcuL3NlcnZpY2UvcG9zaXRpb24uc2VydmljZSc7XG5leHBvcnQgeyBEYWZmVG9hc3RNb2R1bGUgfSBmcm9tICcuL3RvYXN0Lm1vZHVsZSc7XG5leHBvcnQgeyBEYWZmVG9hc3RTZXJ2aWNlIH0gZnJvbSAnLi9zZXJ2aWNlL3RvYXN0LnNlcnZpY2UnO1xuZXhwb3J0IHsgRGFmZlRvYXN0Q29uZmlndXJhdGlvbiB9IGZyb20gJy4vdG9hc3QvdG9hc3QtY29uZmlnJztcbmV4cG9ydCB7XG4gIERhZmZUb2FzdCxcbiAgRGFmZlRvYXN0RGF0YSxcbn0gZnJvbSAnLi9pbnRlcmZhY2VzL3RvYXN0JztcblxuZXhwb3J0IHsgRGFmZlRvYXN0QWN0aW9uIH0gZnJvbSAnLi9pbnRlcmZhY2VzL3RvYXN0LWFjdGlvbic7XG5cbmV4cG9ydCB7XG4gIERBRkZfVE9BU1RfT1BUSU9OUyxcbiAgcHJvdmlkZURhZmZUb2FzdE9wdGlvbnMsXG59IGZyb20gJy4vb3B0aW9ucy9kYWZmLXRvYXN0LW9wdGlvbnMnO1xuXG5leHBvcnQgKiBmcm9tICcuL3RvYXN0L3RvYXN0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3RvYXN0LWFjdGlvbnMvdG9hc3QtYWN0aW9ucy5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi90b2FzdC10aXRsZS90b2FzdC10aXRsZS5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi90b2FzdC1tZXNzYWdlL3RvYXN0LW1lc3NhZ2UuZGlyZWN0aXZlJztcbiJdfQ==
@@ -0,0 +1,2 @@
1
+ export const daffToastChangesFocus = (toast) => toast.actions?.length > 0;
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhbmdlcy1mb2N1cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvZGVzaWduL3RvYXN0L3NyYy9zZXJ2aWNlL2NoYW5nZXMtZm9jdXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxDQUFDLE1BQU0scUJBQXFCLEdBQUcsQ0FBQyxLQUFnQixFQUFXLEVBQUUsQ0FBQyxLQUFLLENBQUMsT0FBTyxFQUFFLE1BQU0sR0FBRyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEYWZmVG9hc3QgfSBmcm9tICcuLi9pbnRlcmZhY2VzL3RvYXN0JztcblxuZXhwb3J0IGNvbnN0IGRhZmZUb2FzdENoYW5nZXNGb2N1cyA9ICh0b2FzdDogRGFmZlRvYXN0KTogYm9vbGVhbiA9PiB0b2FzdC5hY3Rpb25zPy5sZW5ndGggPiAwO1xuIl19
@@ -0,0 +1,29 @@
1
+ import { GlobalPositionStrategy, } from '@angular/cdk/overlay';
2
+ export const createPositionStrategy = (position) => {
3
+ const strat = new GlobalPositionStrategy();
4
+ switch (position.horizontal) {
5
+ case 'left':
6
+ strat.left('48px');
7
+ break;
8
+ case 'right':
9
+ strat.right('48px');
10
+ break;
11
+ case 'center':
12
+ strat.centerHorizontally();
13
+ break;
14
+ default:
15
+ strat.right('48px');
16
+ }
17
+ switch (position.vertical) {
18
+ case 'top':
19
+ strat.top('80px');
20
+ break;
21
+ case 'bottom':
22
+ strat.bottom('48px');
23
+ break;
24
+ default:
25
+ strat.top('80px');
26
+ }
27
+ return strat;
28
+ };
29
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9zaXRpb24tc3RyYXRlZ3kuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2Rlc2lnbi90b2FzdC9zcmMvc2VydmljZS9wb3NpdGlvbi1zdHJhdGVneS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsc0JBQXNCLEdBRXZCLE1BQU0sc0JBQXNCLENBQUM7QUFJOUIsTUFBTSxDQUFDLE1BQU0sc0JBQXNCLEdBQUcsQ0FBQyxRQUEyQixFQUFvQixFQUFFO0lBQ3RGLE1BQU0sS0FBSyxHQUFHLElBQUksc0JBQXNCLEVBQUUsQ0FBQztJQUUzQyxRQUFTLFFBQVEsQ0FBQyxVQUFVLEVBQUc7UUFDN0IsS0FBSyxNQUFNO1lBQ1QsS0FBSyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUNuQixNQUFNO1FBQ1IsS0FBSyxPQUFPO1lBQ1YsS0FBSyxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUNwQixNQUFNO1FBQ1IsS0FBSyxRQUFRO1lBQ1gsS0FBSyxDQUFDLGtCQUFrQixFQUFFLENBQUM7WUFDM0IsTUFBTTtRQUNSO1lBQ0UsS0FBSyxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQztLQUN2QjtJQUVELFFBQU8sUUFBUSxDQUFDLFFBQVEsRUFBRTtRQUN4QixLQUFLLEtBQUs7WUFDUixLQUFLLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1lBQ2xCLE1BQU07UUFDUixLQUFLLFFBQVE7WUFDWCxLQUFLLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1lBQ3JCLE1BQU07UUFDUjtZQUNFLEtBQUssQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFDLENBQUM7S0FDckI7SUFFRCxPQUFPLEtBQUssQ0FBQztBQUNmLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEdsb2JhbFBvc2l0aW9uU3RyYXRlZ3ksXG4gIFBvc2l0aW9uU3RyYXRlZ3ksXG59IGZyb20gJ0Bhbmd1bGFyL2Nkay9vdmVybGF5JztcblxuaW1wb3J0IHsgRGFmZlRvYXN0UG9zaXRpb24gfSBmcm9tICcuLi9vcHRpb25zL2RhZmYtdG9hc3Qtb3B0aW9ucyc7XG5cbmV4cG9ydCBjb25zdCBjcmVhdGVQb3NpdGlvblN0cmF0ZWd5ID0gKHBvc2l0aW9uOiBEYWZmVG9hc3RQb3NpdGlvbik6IFBvc2l0aW9uU3RyYXRlZ3kgPT4ge1xuICBjb25zdCBzdHJhdCA9IG5ldyBHbG9iYWxQb3NpdGlvblN0cmF0ZWd5KCk7XG5cbiAgc3dpdGNoICggcG9zaXRpb24uaG9yaXpvbnRhbCApIHtcbiAgICBjYXNlICdsZWZ0JzpcbiAgICAgIHN0cmF0LmxlZnQoJzQ4cHgnKTtcbiAgICAgIGJyZWFrO1xuICAgIGNhc2UgJ3JpZ2h0JzpcbiAgICAgIHN0cmF0LnJpZ2h0KCc0OHB4Jyk7XG4gICAgICBicmVhaztcbiAgICBjYXNlICdjZW50ZXInOlxuICAgICAgc3RyYXQuY2VudGVySG9yaXpvbnRhbGx5KCk7XG4gICAgICBicmVhaztcbiAgICBkZWZhdWx0OlxuICAgICAgc3RyYXQucmlnaHQoJzQ4cHgnKTtcbiAgfVxuXG4gIHN3aXRjaChwb3NpdGlvbi52ZXJ0aWNhbCkge1xuICAgIGNhc2UgJ3RvcCc6XG4gICAgICBzdHJhdC50b3AoJzgwcHgnKTtcbiAgICAgIGJyZWFrO1xuICAgIGNhc2UgJ2JvdHRvbSc6XG4gICAgICBzdHJhdC5ib3R0b20oJzQ4cHgnKTtcbiAgICAgIGJyZWFrO1xuICAgIGRlZmF1bHQ6XG4gICAgICBzdHJhdC50b3AoJzgwcHgnKTtcbiAgfVxuXG4gIHJldHVybiBzdHJhdDtcbn07XG4iXX0=
@@ -0,0 +1,33 @@
1
+ import { BreakpointObserver } from '@angular/cdk/layout';
2
+ import { Inject, Injectable, } from '@angular/core';
3
+ import { DaffBreakpoints } from '@daffodil/design';
4
+ import { DAFF_TOAST_OPTIONS, } from '../options/daff-toast-options';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@angular/cdk/layout";
7
+ export class DaffToastPositionService {
8
+ constructor(options, mediaQuery) {
9
+ this.options = options;
10
+ this.mediaQuery = mediaQuery;
11
+ this._config = options.position;
12
+ }
13
+ get config() {
14
+ return this.mediaQuery.isMatched(DaffBreakpoints.MOBILE)
15
+ ? this._position ?? this._config
16
+ : { vertical: 'bottom', horizontal: 'center' };
17
+ }
18
+ set config(val) {
19
+ this._config = val;
20
+ }
21
+ setPosition(position) {
22
+ this._position = position;
23
+ }
24
+ /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.1", ngImport: i0, type: DaffToastPositionService, deps: [{ token: DAFF_TOAST_OPTIONS }, { token: i1.BreakpointObserver }], target: i0.ɵɵFactoryTarget.Injectable }); }
25
+ /** @nocollapse */ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.1.1", ngImport: i0, type: DaffToastPositionService }); }
26
+ }
27
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.1", ngImport: i0, type: DaffToastPositionService, decorators: [{
28
+ type: Injectable
29
+ }], ctorParameters: () => [{ type: undefined, decorators: [{
30
+ type: Inject,
31
+ args: [DAFF_TOAST_OPTIONS]
32
+ }] }, { type: i1.BreakpointObserver }] });
33
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9zaXRpb24uc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvZGVzaWduL3RvYXN0L3NyYy9zZXJ2aWNlL3Bvc2l0aW9uLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDekQsT0FBTyxFQUNMLE1BQU0sRUFDTixVQUFVLEdBQ1gsTUFBTSxlQUFlLENBQUM7QUFFdkIsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBRW5ELE9BQU8sRUFHTCxrQkFBa0IsR0FDbkIsTUFBTSwrQkFBK0IsQ0FBQzs7O0FBR3ZDLE1BQU0sT0FBTyx3QkFBd0I7SUFFbkMsWUFBZ0QsT0FBeUIsRUFBVSxVQUE4QjtRQUFqRSxZQUFPLEdBQVAsT0FBTyxDQUFrQjtRQUFVLGVBQVUsR0FBVixVQUFVLENBQW9CO1FBQy9HLElBQUksQ0FBQyxPQUFPLEdBQUcsT0FBTyxDQUFDLFFBQVEsQ0FBQztJQUNsQyxDQUFDO0lBS0QsSUFBSSxNQUFNO1FBQ1IsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLFNBQVMsQ0FBQyxlQUFlLENBQUMsTUFBTSxDQUFDO1lBQ3RELENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxJQUFJLElBQUksQ0FBQyxPQUFPO1lBQ2hDLENBQUMsQ0FBb0IsRUFBRSxRQUFRLEVBQUUsUUFBUSxFQUFFLFVBQVUsRUFBRSxRQUFRLEVBQUUsQ0FBQztJQUN0RSxDQUFDO0lBRUQsSUFBSSxNQUFNLENBQUMsR0FBc0I7UUFDL0IsSUFBSSxDQUFDLE9BQU8sR0FBRyxHQUFHLENBQUM7SUFDckIsQ0FBQztJQUVELFdBQVcsQ0FBQyxRQUEyQjtRQUNyQyxJQUFJLENBQUMsU0FBUyxHQUFHLFFBQVEsQ0FBQztJQUM1QixDQUFDO2lJQXJCVSx3QkFBd0Isa0JBRWYsa0JBQWtCO3FJQUYzQix3QkFBd0I7OzJGQUF4Qix3QkFBd0I7a0JBRHBDLFVBQVU7OzBCQUdJLE1BQU07MkJBQUMsa0JBQWtCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQnJlYWtwb2ludE9ic2VydmVyIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2xheW91dCc7XG5pbXBvcnQge1xuICBJbmplY3QsXG4gIEluamVjdGFibGUsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBEYWZmQnJlYWtwb2ludHMgfSBmcm9tICdAZGFmZm9kaWwvZGVzaWduJztcblxuaW1wb3J0IHtcbiAgRGFmZlRvYXN0T3B0aW9ucyxcbiAgRGFmZlRvYXN0UG9zaXRpb24sXG4gIERBRkZfVE9BU1RfT1BUSU9OUyxcbn0gZnJvbSAnLi4vb3B0aW9ucy9kYWZmLXRvYXN0LW9wdGlvbnMnO1xuXG5ASW5qZWN0YWJsZSgpXG5leHBvcnQgY2xhc3MgRGFmZlRvYXN0UG9zaXRpb25TZXJ2aWNlIHtcblxuICBjb25zdHJ1Y3RvcihASW5qZWN0KERBRkZfVE9BU1RfT1BUSU9OUykgcHJpdmF0ZSBvcHRpb25zOiBEYWZmVG9hc3RPcHRpb25zLCBwcml2YXRlIG1lZGlhUXVlcnk6IEJyZWFrcG9pbnRPYnNlcnZlcikge1xuICAgIHRoaXMuX2NvbmZpZyA9IG9wdGlvbnMucG9zaXRpb247XG4gIH1cblxuICBwcml2YXRlIF9jb25maWc6IERhZmZUb2FzdFBvc2l0aW9uO1xuICBwcml2YXRlIF9wb3NpdGlvbjogRGFmZlRvYXN0UG9zaXRpb247XG5cbiAgZ2V0IGNvbmZpZygpOiBEYWZmVG9hc3RQb3NpdGlvbiB7XG4gICAgcmV0dXJuIHRoaXMubWVkaWFRdWVyeS5pc01hdGNoZWQoRGFmZkJyZWFrcG9pbnRzLk1PQklMRSlcbiAgICAgID8gdGhpcy5fcG9zaXRpb24gPz8gdGhpcy5fY29uZmlnXG4gICAgICA6IDxEYWZmVG9hc3RQb3NpdGlvbj57IHZlcnRpY2FsOiAnYm90dG9tJywgaG9yaXpvbnRhbDogJ2NlbnRlcicgfTtcbiAgfVxuXG4gIHNldCBjb25maWcodmFsOiBEYWZmVG9hc3RQb3NpdGlvbikge1xuICAgIHRoaXMuX2NvbmZpZyA9IHZhbDtcbiAgfVxuXG4gIHNldFBvc2l0aW9uKHBvc2l0aW9uOiBEYWZmVG9hc3RQb3NpdGlvbikge1xuICAgIHRoaXMuX3Bvc2l0aW9uID0gcG9zaXRpb247XG4gIH1cbn1cbiJdfQ==
@@ -0,0 +1,116 @@
1
+ import { BreakpointObserver } from '@angular/cdk/layout';
2
+ import { Overlay, } from '@angular/cdk/overlay';
3
+ import { ComponentPortal } from '@angular/cdk/portal';
4
+ import { EventEmitter, Inject, Injectable, Optional, SkipSelf, } from '@angular/core';
5
+ import { EMPTY, merge, of, } from 'rxjs';
6
+ import { delay, filter, map, take, tap, } from 'rxjs/operators';
7
+ import { DaffBreakpoints, DaffFocusStackService, } from '@daffodil/design';
8
+ import { daffToastChangesFocus } from './changes-focus';
9
+ import { createPositionStrategy } from './position-strategy';
10
+ import { DaffToastPositionService } from './position.service';
11
+ import { DAFF_TOAST_OPTIONS, } from '../options/daff-toast-options';
12
+ import { daffDefaultToastConfiguration, } from '../toast/toast-config';
13
+ import { DaffToastTemplateComponent } from '../toast/toast-template.component';
14
+ import { DaffToastModule } from '../toast.module';
15
+ import * as i0 from "@angular/core";
16
+ import * as i1 from "@angular/cdk/overlay";
17
+ import * as i2 from "@angular/cdk/layout";
18
+ import * as i3 from "./position.service";
19
+ import * as i4 from "@daffodil/design";
20
+ export class DaffToastService {
21
+ constructor(overlay, options, _parentToast, mediaQuery, toastPosition, focusStack) {
22
+ this.overlay = overlay;
23
+ this.options = options;
24
+ this._parentToast = _parentToast;
25
+ this.mediaQuery = mediaQuery;
26
+ this.toastPosition = toastPosition;
27
+ this.focusStack = focusStack;
28
+ this._toasts = [];
29
+ this._sub = this.mediaQuery.observe(DaffBreakpoints.MOBILE).pipe(filter(() => this._overlayRef !== undefined), map((position) => createPositionStrategy(this.toastPosition.config)), tap((strategy) => this._overlayRef.updatePositionStrategy(strategy))).subscribe();
30
+ }
31
+ ngOnDestroy() {
32
+ this._sub.unsubscribe();
33
+ }
34
+ _attachToastTemplate(overlayRef) {
35
+ const template = overlayRef.attach(new ComponentPortal(DaffToastTemplateComponent));
36
+ return template;
37
+ }
38
+ _createOverlayRef() {
39
+ return this.overlay.create({
40
+ hasBackdrop: false,
41
+ scrollStrategy: this.overlay.scrollStrategies.noop(),
42
+ positionStrategy: createPositionStrategy(this.toastPosition.config),
43
+ });
44
+ }
45
+ open(toast, configuration) {
46
+ if (this._parentToast && this.options.useParent) {
47
+ return this._parentToast.open(toast, configuration);
48
+ }
49
+ const config = {
50
+ ...daffDefaultToastConfiguration,
51
+ // sets the default duration to 5000ms if a toast does not have actions
52
+ duration: toast.actions?.length > 0 ? undefined : 5000,
53
+ ...configuration,
54
+ };
55
+ if (this._toasts.length === 0) {
56
+ this._overlayRef = this._createOverlayRef();
57
+ this._template = this._attachToastTemplate(this._overlayRef);
58
+ }
59
+ const dismissEvent = new EventEmitter();
60
+ const _toastPlus = {
61
+ dismissible: true,
62
+ ...toast,
63
+ dismiss: () => {
64
+ dismissEvent.emit();
65
+ },
66
+ dismissalStream: merge(config.duration ? of(undefined).pipe(delay(config.duration)) : EMPTY, dismissEvent).pipe(take(1)),
67
+ };
68
+ _toastPlus.dismissalStream.subscribe(() => {
69
+ this.close(_toastPlus);
70
+ });
71
+ this._toasts = [
72
+ _toastPlus,
73
+ ...this._toasts,
74
+ ];
75
+ this._template.instance.items = this._toasts;
76
+ return _toastPlus;
77
+ }
78
+ close(toast) {
79
+ if (this._parentToast && this.options.useParent) {
80
+ this._parentToast.close(toast);
81
+ return;
82
+ }
83
+ if (daffToastChangesFocus(toast)) {
84
+ this.focusStack.pop();
85
+ }
86
+ const index = this._toasts.indexOf(toast);
87
+ if (index === -1) {
88
+ throw new Error('The Toast that you are trying to remove does not exist.');
89
+ }
90
+ this._toasts = this._toasts.filter(m => m !== toast);
91
+ this._template.instance.items = [...this._toasts];
92
+ // This currently overrides the ":leave" animation as we currently
93
+ // remove the animating element immediately after there are no more toasts,
94
+ // without waiting for the animation to complete.
95
+ if (this._toasts.length === 0) {
96
+ this._overlayRef.dispose();
97
+ this._template.destroy();
98
+ this._overlayRef = undefined;
99
+ this._template = undefined;
100
+ }
101
+ }
102
+ /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.1", ngImport: i0, type: DaffToastService, deps: [{ token: i1.Overlay }, { token: DAFF_TOAST_OPTIONS }, { token: DaffToastService, optional: true, skipSelf: true }, { token: i2.BreakpointObserver }, { token: i3.DaffToastPositionService }, { token: i4.DaffFocusStackService }], target: i0.ɵɵFactoryTarget.Injectable }); }
103
+ /** @nocollapse */ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.1.1", ngImport: i0, type: DaffToastService, providedIn: DaffToastModule }); }
104
+ }
105
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.1", ngImport: i0, type: DaffToastService, decorators: [{
106
+ type: Injectable,
107
+ args: [{ providedIn: DaffToastModule }]
108
+ }], ctorParameters: () => [{ type: i1.Overlay }, { type: undefined, decorators: [{
109
+ type: Inject,
110
+ args: [DAFF_TOAST_OPTIONS]
111
+ }] }, { type: DaffToastService, decorators: [{
112
+ type: Optional
113
+ }, {
114
+ type: SkipSelf
115
+ }] }, { type: i2.BreakpointObserver }, { type: i3.DaffToastPositionService }, { type: i4.DaffFocusStackService }] });
116
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toast.service.js","sourceRoot":"","sources":["../../../../../libs/design/toast/src/service/toast.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { BreakpointObserver } from '@angular/cdk/layout';\nimport {\n  Overlay,\n  OverlayRef,\n} from '@angular/cdk/overlay';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport {\n  ComponentRef,\n  EventEmitter,\n  Inject,\n  Injectable,\n  OnDestroy,\n  Optional,\n  SkipSelf,\n} from '@angular/core';\nimport {\n  EMPTY,\n  interval,\n  merge,\n  of,\n  Subscription,\n} from 'rxjs';\nimport {\n  delay,\n  filter,\n  map,\n  take,\n  tap,\n} from 'rxjs/operators';\n\nimport {\n  DaffBreakpoints,\n  DaffFocusStackService,\n} from '@daffodil/design';\n\nimport { daffToastChangesFocus } from './changes-focus';\nimport { createPositionStrategy } from './position-strategy';\nimport { DaffToastPositionService } from './position.service';\nimport {\n  DaffToast,\n  DaffToastData,\n} from '../interfaces/toast';\nimport {\n  DAFF_TOAST_OPTIONS,\n  DaffToastOptions,\n} from '../options/daff-toast-options';\nimport {\n  daffDefaultToastConfiguration,\n  DaffToastConfiguration,\n} from '../toast/toast-config';\nimport { DaffToastTemplateComponent } from '../toast/toast-template.component';\nimport { DaffToastModule } from '../toast.module';\n\n@Injectable({ providedIn: DaffToastModule })\nexport class DaffToastService implements OnDestroy {\n\n  private _sub: Subscription;\n\n  private _toasts: DaffToast[] = [];\n\n  private _overlayRef?: OverlayRef;\n\n  private _template?: ComponentRef<DaffToastTemplateComponent>;\n\n  constructor(\n    private overlay: Overlay,\n    @Inject(DAFF_TOAST_OPTIONS) private options: DaffToastOptions,\n    @Optional() @SkipSelf() private _parentToast: DaffToastService,\n    private mediaQuery: BreakpointObserver,\n    private toastPosition: DaffToastPositionService,\n    private focusStack: DaffFocusStackService,\n  ) {\n    this._sub = this.mediaQuery.observe(DaffBreakpoints.MOBILE).pipe(\n      filter(() => this._overlayRef !== undefined),\n      map((position) => createPositionStrategy(this.toastPosition.config)),\n      tap((strategy) => this._overlayRef.updatePositionStrategy(strategy)),\n    ).subscribe();\n  }\n\n  ngOnDestroy(): void {\n    this._sub.unsubscribe();\n  }\n\n  private _attachToastTemplate(\n\t  overlayRef: OverlayRef,\n  ): ComponentRef<DaffToastTemplateComponent> {\n\t  const template = overlayRef.attach(new ComponentPortal(DaffToastTemplateComponent));\n\t  return template;\n  }\n\n  private _createOverlayRef(): OverlayRef {\n    return this.overlay.create({\n\t    hasBackdrop: false,\n\t    scrollStrategy: this.overlay.scrollStrategies.noop(),\n      positionStrategy: createPositionStrategy(this.toastPosition.config),\n\t  });\n  }\n\n  open(\n\t  toast: DaffToastData,\n\t  configuration?: Partial<DaffToastConfiguration>,\n  ): DaffToast {\n    if(this._parentToast && this.options.useParent) {\n      return this._parentToast.open(toast, configuration);\n    }\n\n\t  const config: DaffToastConfiguration = {\n      ...daffDefaultToastConfiguration,\n      // sets the default duration to 5000ms if a toast does not have actions\n      duration: toast.actions?.length > 0 ? undefined : 5000,\n      ...configuration,\n    };\n    if(this._toasts.length === 0) {\n      this._overlayRef = this._createOverlayRef();\n      this._template = this._attachToastTemplate(this._overlayRef);\n    }\n    const dismissEvent = new EventEmitter<void>();\n    const _toastPlus: DaffToast = {\n      dismissible: true,\n      ...toast,\n      dismiss: () => {\n        dismissEvent.emit();\n      },\n      dismissalStream: merge(\n        config.duration ? of(undefined).pipe(delay(config.duration)) : EMPTY,\n        dismissEvent,\n      ).pipe(\n        take(1),\n      ),\n    };\n\n    _toastPlus.dismissalStream.subscribe(() => {\n      this.close(_toastPlus);\n    });\n\n\t  this._toasts = [\n      _toastPlus,\n      ...this._toasts,\n    ];\n\n    this._template.instance.items = this._toasts;\n\n\t  return _toastPlus;\n  }\n\n  close(toast: DaffToast): void {\n    if(this._parentToast && this.options.useParent) {\n      this._parentToast.close(toast);\n      return;\n    }\n\n    if(daffToastChangesFocus(toast)) {\n      this.focusStack.pop();\n    }\n\n\t  const index = this._toasts.indexOf(toast);\n\t  if (index === -1) {\n\t    throw new Error(\n\t      'The Toast that you are trying to remove does not exist.',\n\t    );\n\t  }\n\n\t  this._toasts = this._toasts.filter(m => m !== toast);\n    this._template.instance.items = [...this._toasts];\n\n    // This currently overrides the \":leave\" animation as we currently\n    // remove the animating element immediately after there are no more toasts,\n    // without waiting for the animation to complete.\n    if(this._toasts.length === 0) {\n      this._overlayRef.dispose();\n      this._template.destroy();\n      this._overlayRef = undefined;\n      this._template = undefined;\n    }\n  }\n}\n"]}
@@ -0,0 +1,2 @@
1
+ export const daffDefaultToastConfiguration = {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9hc3QtY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9kZXNpZ24vdG9hc3Qvc3JjL3RvYXN0L3RvYXN0LWNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFPQSxNQUFNLENBQUMsTUFBTSw2QkFBNkIsR0FBMkIsRUFBRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBEYWZmVG9hc3RDb25maWd1cmF0aW9uIHtcbiAgLyoqXG4gICAqIFRoZSBkdXJhdGlvbiAoaW4gbWlsbGlzZWNvbmRzKSB0aGF0IGEgdG9hc3QgaXMgdmlzaWJsZSBiZWZvcmUgaXQncyBkaXNtaXNzZWQuXG4gICAqL1xuICBkdXJhdGlvbj86IG51bWJlcjtcbn1cblxuZXhwb3J0IGNvbnN0IGRhZmZEZWZhdWx0VG9hc3RDb25maWd1cmF0aW9uOiBEYWZmVG9hc3RDb25maWd1cmF0aW9uID0ge307XG4iXX0=
@@ -0,0 +1,262 @@
1
+ import { animate, style, transition, trigger, } from '@angular/animations';
2
+ import { Input, ChangeDetectionStrategy, Component, ChangeDetectorRef, Inject, Output, EventEmitter, } from '@angular/core';
3
+ import { faTimes } from '@fortawesome/free-solid-svg-icons';
4
+ import { DAFF_TOAST_OPTIONS, } from '../options/daff-toast-options';
5
+ import { DaffToastPositionService } from '../service/position.service';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "../service/position.service";
8
+ import * as i2 from "@angular/common";
9
+ import * as i3 from "@daffodil/design/button";
10
+ import * as i4 from "@fortawesome/angular-fontawesome";
11
+ import * as i5 from "./toast.component";
12
+ import * as i6 from "../toast-actions/toast-actions.directive";
13
+ import * as i7 from "../toast-title/toast-title.directive";
14
+ import * as i8 from "../toast-message/toast-message.directive";
15
+ export class DaffToastTemplateComponent {
16
+ constructor(cd, options, toastPosition) {
17
+ this.cd = cd;
18
+ this.options = options;
19
+ this.toastPosition = toastPosition;
20
+ this.faTimes = faTimes;
21
+ this._items = [];
22
+ this.closeToast = new EventEmitter();
23
+ }
24
+ onCloseToast(event) {
25
+ this.closeToast.emit();
26
+ }
27
+ get slideAnimation() {
28
+ switch (this.toastPosition.config.horizontal + '-' + this.toastPosition.config.vertical) {
29
+ case 'left-top':
30
+ case 'left-bottom':
31
+ return {
32
+ value: 0,
33
+ params: {
34
+ startX: '-100%',
35
+ endX: '0',
36
+ startY: '0',
37
+ endY: '0',
38
+ },
39
+ };
40
+ case 'right-top':
41
+ case 'right-bottom':
42
+ return {
43
+ value: 0,
44
+ params: {
45
+ startX: '100%',
46
+ endX: '0',
47
+ startY: '0',
48
+ endY: '0',
49
+ },
50
+ };
51
+ case 'center-top':
52
+ return {
53
+ value: 0,
54
+ params: {
55
+ startX: '0',
56
+ endX: '0',
57
+ startY: '-100%',
58
+ endY: '0',
59
+ },
60
+ };
61
+ case 'center-bottom':
62
+ return {
63
+ value: 0,
64
+ params: {
65
+ startX: '0',
66
+ endX: '0',
67
+ startY: '100%',
68
+ endY: '0',
69
+ },
70
+ };
71
+ }
72
+ }
73
+ get items() {
74
+ return this._items;
75
+ }
76
+ set items(value) {
77
+ this._items = value;
78
+ this.cd.markForCheck();
79
+ }
80
+ /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.1", ngImport: i0, type: DaffToastTemplateComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: DAFF_TOAST_OPTIONS }, { token: i1.DaffToastPositionService }], target: i0.ɵɵFactoryTarget.Component }); }
81
+ /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.1", type: DaffToastTemplateComponent, selector: "ng-component", inputs: { items: "items" }, outputs: { closeToast: "closeToast" }, ngImport: i0, template: `
82
+ <daff-toast
83
+ *ngFor="let item of items | slice:0:3"
84
+ [toast]="item"
85
+ [status]="item.status ?? null"
86
+ (closeToast)="item.dismiss()"
87
+ [@slideIn]="slideAnimation"
88
+ [attr.role]="item.actions ? 'alertdialog' : undefined"
89
+ [attr.aria-labelledby]="item.actions ? item.title : undefined"
90
+ [attr.aria-describedby]="item.actions ? item.message : undefined">
91
+ <div daffToastTitle>{{ item.title }}</div>
92
+ <div daffToastMessage>{{ item.message }}</div>
93
+ <div daffToastActions *ngIf="item.actions">
94
+ <ng-container *ngFor="let action of item.actions">
95
+ <ng-container *ngTemplateOutlet="button;context:{ action, item }"></ng-container>
96
+ </ng-container>
97
+ </div>
98
+ <button daff-icon-button color="theme-contrast"
99
+ *ngIf="item.dismissible"
100
+ aria-label="close button"
101
+ [attr.aria-hidden]="item.actions ? undefined : true"
102
+ (click)="onCloseToast(item.dismiss())">
103
+ <fa-icon [icon]="faTimes" size="sm" [fixedWidth]="true"></fa-icon>
104
+ </button>
105
+ </daff-toast>
106
+
107
+ <ng-template #button let-action="action" let-item="item">
108
+ <ng-container [ngSwitch]="action.type">
109
+ <button type="button" *ngSwitchDefault daff-button
110
+ [status]="action.status"
111
+ [color]="action.color"
112
+ [size]="action.size"
113
+ [attr.aria-label]="action.content"
114
+ (click)="action.eventEmitter?.emit({ event: $event, action})">
115
+ {{ action.content }}
116
+ </button>
117
+ <button type="button" *ngSwitchCase="'stroked'" daff-stroked-button
118
+ [status]="action.status"
119
+ [color]="action.color"
120
+ [size]="action.size"
121
+ [attr.aria-label]="action.content"
122
+ (click)="action.eventEmitter?.emit({ event: $event, action})">
123
+ {{ action.content }}
124
+ </button>
125
+ <button type="button" *ngSwitchCase="'raised'" daff-raised-button
126
+ [status]="action.status"
127
+ [color]="action.color"
128
+ [size]="action.size"
129
+ [attr.aria-label]="action.content"
130
+ (click)="action.eventEmitter?.emit({ event: $event, action})">
131
+ {{ action.content }}
132
+ </button>
133
+ <button type="button" *ngSwitchCase="'flat'" daff-flat-button
134
+ [status]="action.status"
135
+ [color]="action.color"
136
+ [size]="action.size"
137
+ [attr.aria-label]="action.content"
138
+ (click)="action.eventEmitter?.emit({ event: $event, action})">
139
+ {{ action.content }}
140
+ </button>
141
+ <button type="button" *ngSwitchCase="'underline'" daff-underline-button
142
+ [status]="action.status"
143
+ [color]="action.color"
144
+ [size]="action.size"
145
+ [attr.aria-label]="action.content"
146
+ (click)="action.eventEmitter?.emit({ event: $event, action})">
147
+ {{ action.content }}
148
+ </button>
149
+ </ng-container>
150
+ </ng-template>
151
+ `, isInline: true, dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i2.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "component", type: i3.DaffButtonComponent, selector: "button[daff-button],button[daff-stroked-button],button[daff-raised-button],button[daff-flat-button],button[daff-icon-button],button[daff-underline-button],a[daff-button],a[daff-stroked-button],a[daff-raised-button],a[daff-flat-button],a[daff-icon-button],a[daff-underline-button]", inputs: ["color", "size", "status", "loading", "tabindex", "disabled"] }, { kind: "component", type: i4.FaIconComponent, selector: "fa-icon", inputs: ["icon", "title", "animation", "spin", "pulse", "mask", "styles", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "classes", "transform", "a11yRole"] }, { kind: "component", type: i5.DaffToastComponent, selector: "daff-toast", inputs: ["status", "toast"] }, { kind: "directive", type: i6.DaffToastActionsDirective, selector: "[daffToastActions]" }, { kind: "directive", type: i7.DaffToastTitleDirective, selector: "[daffToastTitle]" }, { kind: "directive", type: i8.DaffToastMessageDirective, selector: "[daffToastMessage]" }, { kind: "pipe", type: i2.SlicePipe, name: "slice" }], animations: [
152
+ trigger('slideIn', [
153
+ transition(':enter', [
154
+ style({ opacity: '0', transform: 'translate({{startX}}, {{startY}})' }),
155
+ animate('300ms ease-out', style({ opacity: '1', transform: 'translate({{endX}}, {{endY}})' })),
156
+ ], { params: {
157
+ startX: '0',
158
+ startY: '0',
159
+ endX: '0',
160
+ endY: '0',
161
+ } }),
162
+ ]),
163
+ ], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
164
+ }
165
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.1", ngImport: i0, type: DaffToastTemplateComponent, decorators: [{
166
+ type: Component,
167
+ args: [{
168
+ changeDetection: ChangeDetectionStrategy.OnPush,
169
+ template: `
170
+ <daff-toast
171
+ *ngFor="let item of items | slice:0:3"
172
+ [toast]="item"
173
+ [status]="item.status ?? null"
174
+ (closeToast)="item.dismiss()"
175
+ [@slideIn]="slideAnimation"
176
+ [attr.role]="item.actions ? 'alertdialog' : undefined"
177
+ [attr.aria-labelledby]="item.actions ? item.title : undefined"
178
+ [attr.aria-describedby]="item.actions ? item.message : undefined">
179
+ <div daffToastTitle>{{ item.title }}</div>
180
+ <div daffToastMessage>{{ item.message }}</div>
181
+ <div daffToastActions *ngIf="item.actions">
182
+ <ng-container *ngFor="let action of item.actions">
183
+ <ng-container *ngTemplateOutlet="button;context:{ action, item }"></ng-container>
184
+ </ng-container>
185
+ </div>
186
+ <button daff-icon-button color="theme-contrast"
187
+ *ngIf="item.dismissible"
188
+ aria-label="close button"
189
+ [attr.aria-hidden]="item.actions ? undefined : true"
190
+ (click)="onCloseToast(item.dismiss())">
191
+ <fa-icon [icon]="faTimes" size="sm" [fixedWidth]="true"></fa-icon>
192
+ </button>
193
+ </daff-toast>
194
+
195
+ <ng-template #button let-action="action" let-item="item">
196
+ <ng-container [ngSwitch]="action.type">
197
+ <button type="button" *ngSwitchDefault daff-button
198
+ [status]="action.status"
199
+ [color]="action.color"
200
+ [size]="action.size"
201
+ [attr.aria-label]="action.content"
202
+ (click)="action.eventEmitter?.emit({ event: $event, action})">
203
+ {{ action.content }}
204
+ </button>
205
+ <button type="button" *ngSwitchCase="'stroked'" daff-stroked-button
206
+ [status]="action.status"
207
+ [color]="action.color"
208
+ [size]="action.size"
209
+ [attr.aria-label]="action.content"
210
+ (click)="action.eventEmitter?.emit({ event: $event, action})">
211
+ {{ action.content }}
212
+ </button>
213
+ <button type="button" *ngSwitchCase="'raised'" daff-raised-button
214
+ [status]="action.status"
215
+ [color]="action.color"
216
+ [size]="action.size"
217
+ [attr.aria-label]="action.content"
218
+ (click)="action.eventEmitter?.emit({ event: $event, action})">
219
+ {{ action.content }}
220
+ </button>
221
+ <button type="button" *ngSwitchCase="'flat'" daff-flat-button
222
+ [status]="action.status"
223
+ [color]="action.color"
224
+ [size]="action.size"
225
+ [attr.aria-label]="action.content"
226
+ (click)="action.eventEmitter?.emit({ event: $event, action})">
227
+ {{ action.content }}
228
+ </button>
229
+ <button type="button" *ngSwitchCase="'underline'" daff-underline-button
230
+ [status]="action.status"
231
+ [color]="action.color"
232
+ [size]="action.size"
233
+ [attr.aria-label]="action.content"
234
+ (click)="action.eventEmitter?.emit({ event: $event, action})">
235
+ {{ action.content }}
236
+ </button>
237
+ </ng-container>
238
+ </ng-template>
239
+ `,
240
+ animations: [
241
+ trigger('slideIn', [
242
+ transition(':enter', [
243
+ style({ opacity: '0', transform: 'translate({{startX}}, {{startY}})' }),
244
+ animate('300ms ease-out', style({ opacity: '1', transform: 'translate({{endX}}, {{endY}})' })),
245
+ ], { params: {
246
+ startX: '0',
247
+ startY: '0',
248
+ endX: '0',
249
+ endY: '0',
250
+ } }),
251
+ ]),
252
+ ],
253
+ }]
254
+ }], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: undefined, decorators: [{
255
+ type: Inject,
256
+ args: [DAFF_TOAST_OPTIONS]
257
+ }] }, { type: i1.DaffToastPositionService }], propDecorators: { closeToast: [{
258
+ type: Output
259
+ }], items: [{
260
+ type: Input
261
+ }] } });
262
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toast-template.component.js","sourceRoot":"","sources":["../../../../../libs/design/toast/src/toast/toast-template.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  animate,\n  style,\n  transition,\n  trigger,\n} from '@angular/animations';\nimport {\n  Input,\n  ChangeDetectionStrategy,\n  Component,\n  ChangeDetectorRef,\n  Inject,\n  Output,\n  EventEmitter,\n} from '@angular/core';\nimport { faTimes } from '@fortawesome/free-solid-svg-icons';\n\nimport { DaffToast } from '../interfaces/toast';\nimport {\n  DaffToastOptions,\n  DAFF_TOAST_OPTIONS,\n} from '../options/daff-toast-options';\nimport { DaffToastPositionService } from '../service/position.service';\n\n@Component({\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  template: `\n    <daff-toast\n      *ngFor=\"let item of items | slice:0:3\"\n      [toast]=\"item\"\n      [status]=\"item.status ?? null\"\n      (closeToast)=\"item.dismiss()\"\n      [@slideIn]=\"slideAnimation\"\n      [attr.role]=\"item.actions ? 'alertdialog' : undefined\"\n      [attr.aria-labelledby]=\"item.actions ? item.title : undefined\"\n      [attr.aria-describedby]=\"item.actions ? item.message : undefined\">\n      <div daffToastTitle>{{ item.title }}</div>\n      <div daffToastMessage>{{ item.message }}</div>\n      <div daffToastActions *ngIf=\"item.actions\">\n        <ng-container *ngFor=\"let action of item.actions\">\n          <ng-container *ngTemplateOutlet=\"button;context:{ action, item }\"></ng-container>\n        </ng-container>\n      </div>\n      <button daff-icon-button color=\"theme-contrast\"\n        *ngIf=\"item.dismissible\"\n        aria-label=\"close button\"\n        [attr.aria-hidden]=\"item.actions ? undefined : true\"\n        (click)=\"onCloseToast(item.dismiss())\">\n          <fa-icon [icon]=\"faTimes\" size=\"sm\" [fixedWidth]=\"true\"></fa-icon>\n      </button>\n    </daff-toast>\n\n    <ng-template #button let-action=\"action\" let-item=\"item\">\n      <ng-container [ngSwitch]=\"action.type\">\n        <button type=\"button\" *ngSwitchDefault daff-button\n          [status]=\"action.status\"\n          [color]=\"action.color\"\n          [size]=\"action.size\"\n          [attr.aria-label]=\"action.content\"\n          (click)=\"action.eventEmitter?.emit({ event: $event, action})\">\n            {{ action.content }}\n        </button>\n        <button type=\"button\" *ngSwitchCase=\"'stroked'\" daff-stroked-button\n          [status]=\"action.status\"\n          [color]=\"action.color\"\n          [size]=\"action.size\"\n          [attr.aria-label]=\"action.content\"\n          (click)=\"action.eventEmitter?.emit({ event: $event, action})\">\n            {{ action.content }}\n        </button>\n        <button type=\"button\" *ngSwitchCase=\"'raised'\" daff-raised-button\n          [status]=\"action.status\"\n          [color]=\"action.color\"\n          [size]=\"action.size\"\n          [attr.aria-label]=\"action.content\"\n          (click)=\"action.eventEmitter?.emit({ event: $event, action})\">\n            {{ action.content }}\n        </button>\n        <button type=\"button\" *ngSwitchCase=\"'flat'\" daff-flat-button\n          [status]=\"action.status\"\n          [color]=\"action.color\"\n          [size]=\"action.size\"\n          [attr.aria-label]=\"action.content\"\n          (click)=\"action.eventEmitter?.emit({ event: $event, action})\">\n            {{ action.content }}\n        </button>\n        <button type=\"button\" *ngSwitchCase=\"'underline'\" daff-underline-button\n          [status]=\"action.status\"\n          [color]=\"action.color\"\n          [size]=\"action.size\"\n          [attr.aria-label]=\"action.content\"\n          (click)=\"action.eventEmitter?.emit({ event: $event, action})\">\n            {{ action.content }}\n        </button>\n      </ng-container>\n    </ng-template>\n  `,\n  animations: [\n    trigger('slideIn', [\n      transition(':enter', [\n        style({ opacity: '0', transform: 'translate({{startX}}, {{startY}})' }),\n        animate('300ms ease-out', style({ opacity: '1', transform: 'translate({{endX}}, {{endY}})' })),\n      ],\n      { params: {\n        startX: '0',\n        startY: '0',\n        endX: '0',\n        endY: '0',\n      } }),\n    ]),\n  ],\n})\nexport class DaffToastTemplateComponent {\n  faTimes = faTimes;\n\n  private _items: DaffToast[] = [];\n\n  constructor(\n    private cd: ChangeDetectorRef,\n    @Inject(DAFF_TOAST_OPTIONS)\n    private options: DaffToastOptions,\n    private toastPosition: DaffToastPositionService,\n  ) { }\n\n  @Output() closeToast: EventEmitter<void> = new EventEmitter();\n\n  onCloseToast(event: Event) {\n    this.closeToast.emit();\n  }\n\n  get slideAnimation(): any {\n    switch (this.toastPosition.config.horizontal + '-' + this.toastPosition.config.vertical) {\n      case 'left-top':\n      case 'left-bottom':\n        return {\n          value: 0,\n          params: {\n            startX: '-100%',\n            endX: '0',\n            startY: '0',\n            endY: '0',\n          },\n        };\n      case 'right-top':\n      case 'right-bottom':\n        return {\n          value: 0,\n          params: {\n            startX: '100%',\n            endX: '0',\n            startY: '0',\n            endY: '0',\n          },\n        };\n\n      case 'center-top':\n        return {\n          value: 0,\n          params: {\n            startX: '0',\n            endX: '0',\n            startY: '-100%',\n            endY: '0',\n          },\n        };\n\n      case 'center-bottom':\n        return {\n          value: 0,\n          params: {\n            startX: '0',\n            endX: '0',\n            startY: '100%',\n            endY: '0',\n          },\n        };\n    }\n  }\n\n  @Input()\n  get items(): DaffToast[] {\n    return this._items;\n  }\n  set items(value: DaffToast[]) {\n    this._items = value;\n    this.cd.markForCheck();\n  }\n}\n"]}