@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.
- package/esm2022/article/article/article.component.mjs +2 -2
- package/esm2022/article/examples/article-headings/article-headings.component.mjs +3 -4
- package/esm2022/loading-icon/examples/loading-icon-color/loading-icon-color.component.mjs +3 -3
- package/esm2022/loading-icon/loading-icon/loading-icon.component.mjs +3 -3
- package/esm2022/modal/service/modal.service.mjs +2 -3
- package/esm2022/toast/daffodil-design-toast.mjs +5 -0
- package/esm2022/toast/examples/daffodil-design-toast-examples.mjs +5 -0
- package/esm2022/toast/examples/default-toast/default-toast.component.mjs +38 -0
- package/esm2022/toast/examples/default-toast/default-toast.module.mjs +36 -0
- package/esm2022/toast/examples/index.mjs +2 -0
- package/esm2022/toast/examples/public_api.mjs +15 -0
- package/esm2022/toast/examples/toast-positions/toast-positions.component.mjs +42 -0
- package/esm2022/toast/examples/toast-positions/toast-positions.module.mjs +57 -0
- package/esm2022/toast/examples/toast-status/toast-status.component.mjs +45 -0
- package/esm2022/toast/examples/toast-status/toast-status.module.mjs +40 -0
- package/esm2022/toast/examples/toast-with-custom-duration/toast-with-custom-duration.component.mjs +26 -0
- package/esm2022/toast/examples/toast-with-custom-duration/toast-with-custom-duration.module.mjs +32 -0
- package/esm2022/toast/index.mjs +2 -0
- package/esm2022/toast/interfaces/toast-action.mjs +2 -0
- package/esm2022/toast/interfaces/toast.mjs +2 -0
- package/esm2022/toast/options/daff-toast-options.mjs +16 -0
- package/esm2022/toast/public_api.mjs +9 -0
- package/esm2022/toast/service/changes-focus.mjs +2 -0
- package/esm2022/toast/service/position-strategy.mjs +29 -0
- package/esm2022/toast/service/position.service.mjs +33 -0
- package/esm2022/toast/service/toast.service.mjs +116 -0
- package/esm2022/toast/toast/toast-config.mjs +2 -0
- package/esm2022/toast/toast/toast-template.component.mjs +262 -0
- package/esm2022/toast/toast/toast.component.mjs +82 -0
- package/esm2022/toast/toast-actions/toast-actions.directive.mjs +19 -0
- package/esm2022/toast/toast-message/toast-message.directive.mjs +19 -0
- package/esm2022/toast/toast-title/toast-title.directive.mjs +19 -0
- package/esm2022/toast/toast.module.mjs +70 -0
- package/fesm2022/daffodil-design-article-examples.mjs +2 -2
- package/fesm2022/daffodil-design-article-examples.mjs.map +1 -1
- package/fesm2022/daffodil-design-article.mjs +2 -2
- package/fesm2022/daffodil-design-article.mjs.map +1 -1
- package/fesm2022/daffodil-design-loading-icon-examples.mjs +2 -2
- package/fesm2022/daffodil-design-loading-icon-examples.mjs.map +1 -1
- package/fesm2022/daffodil-design-loading-icon.mjs +2 -2
- package/fesm2022/daffodil-design-loading-icon.mjs.map +1 -1
- package/fesm2022/daffodil-design-modal.mjs +1 -2
- package/fesm2022/daffodil-design-modal.mjs.map +1 -1
- package/fesm2022/daffodil-design-toast-examples.mjs +287 -0
- package/fesm2022/daffodil-design-toast-examples.mjs.map +1 -0
- package/fesm2022/daffodil-design-toast.mjs +625 -0
- package/fesm2022/daffodil-design-toast.mjs.map +1 -0
- package/loading-icon/src/loading-icon-theme.scss +24 -8
- package/navbar/README.md +1 -1
- package/package.json +1 -1
- package/scss/theme.scss +2 -0
- package/toast/README.md +115 -0
- package/toast/examples/default-toast/default-toast.component.d.ts +15 -0
- package/toast/examples/default-toast/default-toast.module.d.ts +11 -0
- package/toast/examples/index.d.ts +1 -0
- package/toast/examples/public_api.d.ts +2 -0
- package/toast/examples/toast-positions/toast-positions.component.d.ts +17 -0
- package/toast/examples/toast-positions/toast-positions.module.d.ts +12 -0
- package/toast/examples/toast-status/toast-status.component.d.ts +14 -0
- package/toast/examples/toast-status/toast-status.module.d.ts +12 -0
- package/toast/examples/toast-with-custom-duration/toast-with-custom-duration.component.d.ts +10 -0
- package/toast/examples/toast-with-custom-duration/toast-with-custom-duration.module.d.ts +10 -0
- package/toast/index.d.ts +1 -0
- package/toast/interfaces/toast-action.d.ts +38 -0
- package/toast/interfaces/toast.d.ts +20 -0
- package/toast/options/daff-toast-options.d.ts +15 -0
- package/toast/public_api.d.ts +11 -0
- package/toast/service/changes-focus.d.ts +2 -0
- package/toast/service/position-strategy.d.ts +3 -0
- package/toast/service/position.service.d.ts +15 -0
- package/toast/service/toast.service.d.ts +29 -0
- package/toast/src/toast-theme.scss +63 -0
- package/toast/toast/toast-config.d.ts +7 -0
- package/toast/toast/toast-template.component.d.ts +20 -0
- package/toast/toast/toast.component.d.ts +52 -0
- package/toast/toast-actions/toast-actions.directive.d.ts +6 -0
- package/toast/toast-message/toast-message.directive.d.ts +6 -0
- package/toast/toast-title/toast-title.directive.d.ts +6 -0
- package/toast/toast.module.d.ts +17 -0
package/esm2022/toast/examples/toast-with-custom-duration/toast-with-custom-duration.module.mjs
ADDED
@@ -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":"AAAA,OAAO,EACL,OAAO,EACP,KAAK,EACL,UAAU,EACV,OAAO,GACR,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EACL,KAAK,EACL,uBAAuB,EACvB,SAAS,EACT,iBAAiB,EACjB,MAAM,EACN,MAAM,EACN,YAAY,GACb,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,OAAO,EAAE,MAAM,mCAAmC,CAAC;AAG5D,OAAO,EAEL,kBAAkB,GACnB,MAAM,+BAA+B,CAAC;AACvC,OAAO,EAAE,wBAAwB,EAAE,MAAM,6BAA6B,CAAC;;;;;;;;;;AA0FvE,MAAM,OAAO,0BAA0B;IAKrC,YACU,EAAqB,EAErB,OAAyB,EACzB,aAAuC;QAHvC,OAAE,GAAF,EAAE,CAAmB;QAErB,YAAO,GAAP,OAAO,CAAkB;QACzB,kBAAa,GAAb,aAAa,CAA0B;QARjD,YAAO,GAAG,OAAO,CAAC;QAEV,WAAM,GAAgB,EAAE,CAAC;QASvB,eAAU,GAAuB,IAAI,YAAY,EAAE,CAAC;IAF1D,CAAC;IAIL,YAAY,CAAC,KAAY;QACvB,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;IACzB,CAAC;IAED,IAAI,cAAc;QAChB,QAAQ,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,UAAU,GAAG,GAAG,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,QAAQ,EAAE;YACvF,KAAK,UAAU,CAAC;YAChB,KAAK,aAAa;gBAChB,OAAO;oBACL,KAAK,EAAE,CAAC;oBACR,MAAM,EAAE;wBACN,MAAM,EAAE,OAAO;wBACf,IAAI,EAAE,GAAG;wBACT,MAAM,EAAE,GAAG;wBACX,IAAI,EAAE,GAAG;qBACV;iBACF,CAAC;YACJ,KAAK,WAAW,CAAC;YACjB,KAAK,cAAc;gBACjB,OAAO;oBACL,KAAK,EAAE,CAAC;oBACR,MAAM,EAAE;wBACN,MAAM,EAAE,MAAM;wBACd,IAAI,EAAE,GAAG;wBACT,MAAM,EAAE,GAAG;wBACX,IAAI,EAAE,GAAG;qBACV;iBACF,CAAC;YAEJ,KAAK,YAAY;gBACf,OAAO;oBACL,KAAK,EAAE,CAAC;oBACR,MAAM,EAAE;wBACN,MAAM,EAAE,GAAG;wBACX,IAAI,EAAE,GAAG;wBACT,MAAM,EAAE,OAAO;wBACf,IAAI,EAAE,GAAG;qBACV;iBACF,CAAC;YAEJ,KAAK,eAAe;gBAClB,OAAO;oBACL,KAAK,EAAE,CAAC;oBACR,MAAM,EAAE;wBACN,MAAM,EAAE,GAAG;wBACX,IAAI,EAAE,GAAG;wBACT,MAAM,EAAE,MAAM;wBACd,IAAI,EAAE,GAAG;qBACV;iBACF,CAAC;SACL;IACH,CAAC;IAED,IACI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IACD,IAAI,KAAK,CAAC,KAAkB;QAC1B,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC;IACzB,CAAC;iIA1EU,0BAA0B,mDAO3B,kBAAkB;qHAPjB,0BAA0B,uHAtF3B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAsET,mxDACW;YACV,OAAO,CAAC,SAAS,EAAE;gBACjB,UAAU,CAAC,QAAQ,EAAE;oBACnB,KAAK,CAAC,EAAE,OAAO,EAAE,GAAG,EAAE,SAAS,EAAE,mCAAmC,EAAE,CAAC;oBACvE,OAAO,CAAC,gBAAgB,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,GAAG,EAAE,SAAS,EAAE,+BAA+B,EAAE,CAAC,CAAC;iBAC/F,EACD,EAAE,MAAM,EAAE;wBACR,MAAM,EAAE,GAAG;wBACX,MAAM,EAAE,GAAG;wBACX,IAAI,EAAE,GAAG;wBACT,IAAI,EAAE,GAAG;qBACV,EAAE,CAAC;aACL,CAAC;SACH;;2FAEU,0BAA0B;kBAxFtC,SAAS;mBAAC;oBACT,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAsET;oBACD,UAAU,EAAE;wBACV,OAAO,CAAC,SAAS,EAAE;4BACjB,UAAU,CAAC,QAAQ,EAAE;gCACnB,KAAK,CAAC,EAAE,OAAO,EAAE,GAAG,EAAE,SAAS,EAAE,mCAAmC,EAAE,CAAC;gCACvE,OAAO,CAAC,gBAAgB,EAAE,KAAK,CAAC,EAAE,OAAO,EAAE,GAAG,EAAE,SAAS,EAAE,+BAA+B,EAAE,CAAC,CAAC;6BAC/F,EACD,EAAE,MAAM,EAAE;oCACR,MAAM,EAAE,GAAG;oCACX,MAAM,EAAE,GAAG;oCACX,IAAI,EAAE,GAAG;oCACT,IAAI,EAAE,GAAG;iCACV,EAAE,CAAC;yBACL,CAAC;qBACH;iBACF;;0BAQI,MAAM;2BAAC,kBAAkB;gFAKlB,UAAU;sBAAnB,MAAM;gBAwDH,KAAK;sBADR,KAAK","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"]}
|