cps-ui-kit 0.165.0 → 17.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/cps-autocomplete/cps-autocomplete.component.mjs +824 -0
- package/esm2022/lib/components/cps-button/cps-button.component.mjs +190 -0
- package/esm2022/lib/components/cps-button-toggle/cps-button-toggle.component.mjs +235 -0
- package/esm2022/lib/components/cps-checkbox/cps-checkbox.component.mjs +149 -0
- package/esm2022/lib/components/cps-chip/cps-chip.component.mjs +94 -0
- package/esm2022/lib/components/cps-datepicker/cps-datepicker.component.mjs +382 -0
- package/esm2022/lib/components/cps-expansion-panel/cps-expansion-panel.component.mjs +209 -0
- package/esm2022/lib/components/cps-file-upload/cps-file-upload.component.mjs +138 -0
- package/esm2022/lib/components/cps-icon/cps-icon.component.mjs +193 -0
- package/esm2022/lib/components/cps-info-circle/cps-info-circle.component.mjs +61 -0
- package/esm2022/lib/components/cps-input/cps-input.component.mjs +386 -0
- package/{esm2020 → esm2022}/lib/components/cps-loader/cps-loader.component.mjs +5 -5
- package/esm2022/lib/components/cps-menu/cps-menu.component.mjs +552 -0
- package/esm2022/lib/components/cps-paginator/cps-paginator.component.mjs +114 -0
- package/esm2022/lib/components/cps-paginator/pipes/cps-paginate.pipe.mjs +30 -0
- package/{esm2020 → esm2022}/lib/components/cps-progress-circular/cps-progress-circular.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/cps-progress-linear/cps-progress-linear.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/components/cps-radio-group/cps-radio/cps-radio.component.mjs +7 -7
- package/esm2022/lib/components/cps-radio-group/cps-radio-button/cps-radio-button.component.mjs +55 -0
- package/esm2022/lib/components/cps-radio-group/cps-radio-group.component.mjs +158 -0
- package/esm2022/lib/components/cps-select/cps-select.component.mjs +615 -0
- package/esm2022/lib/components/cps-sidebar-menu/cps-sidebar-menu.component.mjs +110 -0
- package/{esm2020 → esm2022}/lib/components/cps-tab-group/cps-tab/cps-tab.component.mjs +4 -4
- package/esm2022/lib/components/cps-tab-group/cps-tab-group.component.mjs +303 -0
- package/esm2022/lib/components/cps-table/components/internal/cps-sort-icon/cps-sort-icon.component.mjs +79 -0
- package/esm2022/lib/components/cps-table/components/internal/table-column-filter/table-column-filter.component.mjs +408 -0
- package/esm2022/lib/components/cps-table/components/internal/table-column-filter-constraint/table-column-filter-constraint.component.mjs +149 -0
- package/esm2022/lib/components/cps-table/components/internal/table-row-menu/table-row-menu.component.mjs +88 -0
- package/esm2022/lib/components/cps-table/cps-table.component.mjs +941 -0
- package/esm2022/lib/components/cps-table/directives/cps-table-column-filter.directive.mjs +181 -0
- package/{esm2020 → esm2022}/lib/components/cps-table/directives/cps-table-column-sortable.directive.mjs +5 -5
- package/{esm2020 → esm2022}/lib/components/cps-table/directives/cps-table-header-selectable.directive.mjs +5 -5
- package/{esm2020 → esm2022}/lib/components/cps-table/directives/cps-table-row-selectable.directive.mjs +5 -5
- package/esm2022/lib/components/cps-table/directives/internal/table-unsort.directive.mjs +220 -0
- package/esm2022/lib/components/cps-tag/cps-tag.component.mjs +136 -0
- package/esm2022/lib/components/cps-textarea/cps-textarea.component.mjs +291 -0
- package/esm2022/lib/components/cps-timepicker/cps-timepicker.component.mjs +351 -0
- package/esm2022/lib/components/cps-tree-autocomplete/cps-tree-autocomplete.component.mjs +251 -0
- package/esm2022/lib/components/cps-tree-select/cps-tree-select.component.mjs +87 -0
- package/esm2022/lib/components/cps-tree-table/cps-tree-table.component.mjs +1196 -0
- package/{esm2020 → esm2022}/lib/components/cps-tree-table/directives/cps-tree-table-column-filter.directive.mjs +5 -5
- package/{esm2020 → esm2022}/lib/components/cps-tree-table/directives/cps-tree-table-column-sortable.directive.mjs +5 -5
- package/{esm2020 → esm2022}/lib/components/cps-tree-table/directives/cps-tree-table-header-selectable.directive.mjs +5 -5
- package/{esm2020 → esm2022}/lib/components/cps-tree-table/directives/cps-tree-table-row-selectable.directive.mjs +5 -5
- package/esm2022/lib/components/cps-tree-table/directives/cps-tree-table-row-toggler.directive.mjs +43 -0
- package/esm2022/lib/components/cps-tree-table/directives/internal/tree-table-unsort.directive.mjs +354 -0
- package/esm2022/lib/components/internal/cps-base-tree-dropdown/cps-base-tree-dropdown.component.mjs +619 -0
- package/esm2022/lib/directives/cps-tooltip/cps-tooltip.directive.mjs +257 -0
- package/{esm2020 → esm2022}/lib/pipes/internal/check-option-selected.pipe.mjs +4 -4
- package/esm2022/lib/pipes/internal/combine-labels.pipe.mjs +25 -0
- package/{esm2020 → esm2022}/lib/pipes/internal/label-by-value.pipe.mjs +4 -4
- package/esm2022/lib/services/cps-dialog/cps-dialog.service.mjs +99 -0
- package/{esm2020 → esm2022}/lib/services/cps-dialog/internal/components/cps-confirmation/cps-confirmation.component.mjs +5 -5
- package/esm2022/lib/services/cps-dialog/internal/components/cps-dialog/cps-dialog.component.mjs +470 -0
- package/{esm2020 → esm2022}/lib/services/cps-dialog/internal/directives/cps-dialog-content.directive.mjs +5 -5
- package/esm2022/lib/services/cps-dialog/utils/cps-dialog-config.mjs +3 -0
- package/esm2022/lib/services/cps-notification/cps-notification.service.mjs +126 -0
- package/esm2022/lib/services/cps-notification/internal/components/cps-notification-container/cps-notification-container.component.mjs +91 -0
- package/{esm2020 → esm2022}/lib/services/cps-notification/internal/components/cps-toast/cps-toast.component.mjs +23 -23
- package/esm2022/lib/utils/colors-utils.mjs +57 -0
- package/esm2022/lib/utils/internal/size-utils.mjs +24 -0
- package/{esm2020 → esm2022}/public-api.mjs +2 -2
- package/{fesm2020 → fesm2022}/cps-ui-kit.mjs +481 -391
- package/fesm2022/cps-ui-kit.mjs.map +1 -0
- package/lib/components/cps-autocomplete/cps-autocomplete.component.d.ts +2 -2
- package/lib/components/cps-button/cps-button.component.d.ts +1 -1
- package/lib/components/cps-button-toggle/cps-button-toggle.component.d.ts +2 -2
- package/lib/components/cps-checkbox/cps-checkbox.component.d.ts +2 -2
- package/lib/components/cps-chip/cps-chip.component.d.ts +1 -1
- package/lib/components/cps-datepicker/cps-datepicker.component.d.ts +2 -2
- package/lib/components/cps-expansion-panel/cps-expansion-panel.component.d.ts +1 -1
- package/lib/components/cps-file-upload/cps-file-upload.component.d.ts +1 -1
- package/lib/components/cps-icon/cps-icon.component.d.ts +1 -1
- package/lib/components/cps-info-circle/cps-info-circle.component.d.ts +2 -2
- package/lib/components/cps-input/cps-input.component.d.ts +2 -2
- package/lib/components/cps-loader/cps-loader.component.d.ts +1 -1
- package/lib/components/cps-menu/cps-menu.component.d.ts +1 -1
- package/lib/components/cps-paginator/cps-paginator.component.d.ts +1 -1
- package/lib/components/cps-progress-circular/cps-progress-circular.component.d.ts +1 -1
- package/lib/components/cps-progress-linear/cps-progress-linear.component.d.ts +1 -1
- package/lib/components/cps-radio-group/cps-radio/cps-radio.component.d.ts +1 -1
- package/lib/components/cps-radio-group/cps-radio-button/cps-radio-button.component.d.ts +1 -1
- package/lib/components/cps-radio-group/cps-radio-group.component.d.ts +2 -2
- package/lib/components/cps-select/cps-select.component.d.ts +2 -2
- package/lib/components/cps-sidebar-menu/cps-sidebar-menu.component.d.ts +1 -1
- package/lib/components/cps-tab-group/cps-tab/cps-tab.component.d.ts +1 -1
- package/lib/components/cps-tab-group/cps-tab-group.component.d.ts +1 -1
- package/lib/components/cps-table/components/internal/cps-sort-icon/cps-sort-icon.component.d.ts +1 -1
- package/lib/components/cps-table/components/internal/table-column-filter/table-column-filter.component.d.ts +1 -1
- package/lib/components/cps-table/components/internal/table-column-filter-constraint/table-column-filter-constraint.component.d.ts +1 -1
- package/lib/components/cps-table/components/internal/table-row-menu/table-row-menu.component.d.ts +1 -1
- package/lib/components/cps-table/cps-table.component.d.ts +1 -1
- package/lib/components/cps-table/directives/cps-table-column-filter.directive.d.ts +1 -1
- package/lib/components/cps-table/directives/cps-table-column-sortable.directive.d.ts +1 -1
- package/lib/components/cps-table/directives/cps-table-row-selectable.directive.d.ts +1 -1
- package/lib/components/cps-tag/cps-tag.component.d.ts +1 -1
- package/lib/components/cps-textarea/cps-textarea.component.d.ts +2 -2
- package/lib/components/cps-timepicker/cps-timepicker.component.d.ts +2 -2
- package/lib/components/cps-tree-autocomplete/cps-tree-autocomplete.component.d.ts +1 -1
- package/lib/components/cps-tree-select/cps-tree-select.component.d.ts +1 -1
- package/lib/components/cps-tree-table/cps-tree-table.component.d.ts +4 -4
- package/lib/components/cps-tree-table/directives/cps-tree-table-column-filter.directive.d.ts +1 -1
- package/lib/components/cps-tree-table/directives/cps-tree-table-column-sortable.directive.d.ts +1 -1
- package/lib/components/cps-tree-table/directives/cps-tree-table-row-selectable.directive.d.ts +1 -1
- package/lib/components/cps-tree-table/directives/cps-tree-table-row-toggler.directive.d.ts +1 -1
- package/lib/components/internal/cps-base-tree-dropdown/cps-base-tree-dropdown.component.d.ts +2 -2
- package/lib/directives/{cps-tooltip.directive.d.ts → cps-tooltip/cps-tooltip.directive.d.ts} +2 -2
- package/lib/services/cps-dialog/cps-dialog.service.d.ts +13 -0
- package/lib/services/cps-dialog/utils/cps-dialog-config.d.ts +1 -1
- package/lib/services/cps-notification/cps-notification.service.d.ts +32 -0
- package/lib/services/cps-notification/internal/components/cps-notification-container/cps-notification-container.component.d.ts +1 -1
- package/lib/services/cps-notification/internal/components/cps-toast/cps-toast.component.d.ts +1 -1
- package/package.json +12 -18
- package/public-api.d.ts +1 -1
- package/esm2020/lib/components/cps-autocomplete/cps-autocomplete.component.mjs +0 -824
- package/esm2020/lib/components/cps-button/cps-button.component.mjs +0 -190
- package/esm2020/lib/components/cps-button-toggle/cps-button-toggle.component.mjs +0 -235
- package/esm2020/lib/components/cps-checkbox/cps-checkbox.component.mjs +0 -149
- package/esm2020/lib/components/cps-chip/cps-chip.component.mjs +0 -94
- package/esm2020/lib/components/cps-datepicker/cps-datepicker.component.mjs +0 -382
- package/esm2020/lib/components/cps-expansion-panel/cps-expansion-panel.component.mjs +0 -209
- package/esm2020/lib/components/cps-file-upload/cps-file-upload.component.mjs +0 -138
- package/esm2020/lib/components/cps-icon/cps-icon.component.mjs +0 -193
- package/esm2020/lib/components/cps-info-circle/cps-info-circle.component.mjs +0 -61
- package/esm2020/lib/components/cps-input/cps-input.component.mjs +0 -386
- package/esm2020/lib/components/cps-menu/cps-menu.component.mjs +0 -552
- package/esm2020/lib/components/cps-paginator/cps-paginator.component.mjs +0 -113
- package/esm2020/lib/components/cps-paginator/pipes/cps-paginate.pipe.mjs +0 -30
- package/esm2020/lib/components/cps-radio-group/cps-radio-button/cps-radio-button.component.mjs +0 -55
- package/esm2020/lib/components/cps-radio-group/cps-radio-group.component.mjs +0 -158
- package/esm2020/lib/components/cps-select/cps-select.component.mjs +0 -615
- package/esm2020/lib/components/cps-sidebar-menu/cps-sidebar-menu.component.mjs +0 -110
- package/esm2020/lib/components/cps-tab-group/cps-tab-group.component.mjs +0 -299
- package/esm2020/lib/components/cps-table/components/internal/cps-sort-icon/cps-sort-icon.component.mjs +0 -79
- package/esm2020/lib/components/cps-table/components/internal/table-column-filter/table-column-filter.component.mjs +0 -408
- package/esm2020/lib/components/cps-table/components/internal/table-column-filter-constraint/table-column-filter-constraint.component.mjs +0 -148
- package/esm2020/lib/components/cps-table/components/internal/table-row-menu/table-row-menu.component.mjs +0 -88
- package/esm2020/lib/components/cps-table/cps-table.component.mjs +0 -940
- package/esm2020/lib/components/cps-table/directives/cps-table-column-filter.directive.mjs +0 -181
- package/esm2020/lib/components/cps-table/directives/internal/table-unsort.directive.mjs +0 -210
- package/esm2020/lib/components/cps-tag/cps-tag.component.mjs +0 -136
- package/esm2020/lib/components/cps-textarea/cps-textarea.component.mjs +0 -291
- package/esm2020/lib/components/cps-timepicker/cps-timepicker.component.mjs +0 -351
- package/esm2020/lib/components/cps-tree-autocomplete/cps-tree-autocomplete.component.mjs +0 -250
- package/esm2020/lib/components/cps-tree-select/cps-tree-select.component.mjs +0 -87
- package/esm2020/lib/components/cps-tree-table/cps-tree-table.component.mjs +0 -1192
- package/esm2020/lib/components/cps-tree-table/directives/cps-tree-table-row-toggler.directive.mjs +0 -43
- package/esm2020/lib/components/cps-tree-table/directives/internal/tree-table-unsort.directive.mjs +0 -334
- package/esm2020/lib/components/internal/cps-base-tree-dropdown/cps-base-tree-dropdown.component.mjs +0 -616
- package/esm2020/lib/directives/cps-tooltip.directive.mjs +0 -257
- package/esm2020/lib/pipes/internal/combine-labels.pipe.mjs +0 -25
- package/esm2020/lib/services/cps-dialog/cps-dialog.service.mjs +0 -86
- package/esm2020/lib/services/cps-dialog/internal/components/cps-dialog/cps-dialog.component.mjs +0 -470
- package/esm2020/lib/services/cps-dialog/utils/cps-dialog-config.mjs +0 -3
- package/esm2020/lib/services/cps-notification/cps-notification.service.mjs +0 -94
- package/esm2020/lib/services/cps-notification/internal/components/cps-notification-container/cps-notification-container.component.mjs +0 -91
- package/esm2020/lib/utils/colors-utils.mjs +0 -57
- package/esm2020/lib/utils/internal/size-utils.mjs +0 -24
- package/fesm2015/cps-ui-kit.mjs +0 -12086
- package/fesm2015/cps-ui-kit.mjs.map +0 -1
- package/fesm2020/cps-ui-kit.mjs.map +0 -1
- /package/{esm2020 → esm2022}/cps-ui-kit.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/components/cps-table/cps-column-filter-types.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/services/cps-dialog/utils/cps-dialog-ref.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/services/cps-notification/utils/cps-notification-config.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/services/cps-notification/utils/internal/cps-notification-data.mjs +0 -0
|
@@ -5,14 +5,14 @@ export class CpsDialogContentDirective {
|
|
|
5
5
|
constructor(viewContainerRef) {
|
|
6
6
|
this.viewContainerRef = viewContainerRef;
|
|
7
7
|
}
|
|
8
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsDialogContentDirective, deps: [{ token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
9
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.1.2", type: CpsDialogContentDirective, isStandalone: true, selector: "[cpsDialogContent]", ngImport: i0 }); }
|
|
8
10
|
}
|
|
9
|
-
|
|
10
|
-
CpsDialogContentDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.2.9", type: CpsDialogContentDirective, isStandalone: true, selector: "[cpsDialogContent]", ngImport: i0 });
|
|
11
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CpsDialogContentDirective, decorators: [{
|
|
11
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsDialogContentDirective, decorators: [{
|
|
12
12
|
type: Directive,
|
|
13
13
|
args: [{
|
|
14
14
|
standalone: true,
|
|
15
15
|
selector: '[cpsDialogContent]'
|
|
16
16
|
}]
|
|
17
|
-
}], ctorParameters:
|
|
18
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
17
|
+
}], ctorParameters: () => [{ type: i0.ViewContainerRef }] });
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3BzLWRpYWxvZy1jb250ZW50LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Nwcy11aS1raXQvc3JjL2xpYi9zZXJ2aWNlcy9jcHMtZGlhbG9nL2ludGVybmFsL2RpcmVjdGl2ZXMvY3BzLWRpYWxvZy1jb250ZW50LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFvQixNQUFNLGVBQWUsQ0FBQzs7QUFNNUQsTUFBTSxPQUFPLHlCQUF5QjtJQUNwQyxrREFBa0Q7SUFDbEQsWUFBbUIsZ0JBQWtDO1FBQWxDLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBa0I7SUFBRyxDQUFDOzhHQUY5Qyx5QkFBeUI7a0dBQXpCLHlCQUF5Qjs7MkZBQXpCLHlCQUF5QjtrQkFKckMsU0FBUzttQkFBQztvQkFDVCxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFLG9CQUFvQjtpQkFDL0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIFZpZXdDb250YWluZXJSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQERpcmVjdGl2ZSh7XG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIHNlbGVjdG9yOiAnW2Nwc0RpYWxvZ0NvbnRlbnRdJ1xufSlcbmV4cG9ydCBjbGFzcyBDcHNEaWFsb2dDb250ZW50RGlyZWN0aXZlIHtcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLXVzZWxlc3MtY29uc3RydWN0b3JcbiAgY29uc3RydWN0b3IocHVibGljIHZpZXdDb250YWluZXJSZWY6IFZpZXdDb250YWluZXJSZWYpIHt9XG59XG4iXX0=
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export class CpsDialogConfig {
|
|
2
|
+
}
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3BzLWRpYWxvZy1jb25maWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jcHMtdWkta2l0L3NyYy9saWIvc2VydmljZXMvY3BzLWRpYWxvZy91dGlscy9jcHMtZGlhbG9nLWNvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLE9BQU8sZUFBZTtDQThKM0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDcHNUb29sdGlwUG9zaXRpb24gfSBmcm9tICcuLi8uLi8uLi9kaXJlY3RpdmVzL2Nwcy10b29sdGlwL2Nwcy10b29sdGlwLmRpcmVjdGl2ZSc7XG5cbmV4cG9ydCBjbGFzcyBDcHNEaWFsb2dDb25maWc8VCA9IGFueT4ge1xuICAvKipcbiAgICogQW4gb2JqZWN0IHRvIHBhc3MgdG8gdGhlIGNvbXBvbmVudCBsb2FkZWQgaW5zaWRlIHRoZSBEaWFsb2cuXG4gICAqL1xuICBkYXRhPzogVDtcbiAgLyoqXG4gICAqIERldGVybWluZXMgd2hldGhlciB0byBzaG93IHRoZSBoZWFkZXIgb3Igbm90LlxuICAgKi9cbiAgc2hvd0hlYWRlcj86IGJvb2xlYW47XG4gIC8qKlxuICAgKiBIZWFkZXIgdGV4dCBvZiB0aGUgZGlhbG9nLlxuICAgKi9cbiAgaGVhZGVyVGl0bGU/OiBzdHJpbmc7XG4gIC8qKlxuICAgKiBIZWFkZXIgaW5mb3JtYXRpb24gdG9vbHRpcC5cbiAgICovXG4gIGhlYWRlckluZm9Ub29sdGlwPzogc3RyaW5nO1xuICAvKipcbiAgICogSGVhZGVyIGluZm9ybWF0aW9uIHRvb2x0aXAgcG9zaXRpb24uXG4gICAqL1xuICBoZWFkZXJJbmZvVG9vbHRpcFBvc2l0aW9uPzogQ3BzVG9vbHRpcFBvc2l0aW9uO1xuICAvKipcbiAgICogSGVhZGVyIGljb24uXG4gICAqL1xuICBoZWFkZXJJY29uPzogc3RyaW5nO1xuICAvKipcbiAgICogSGVhZGVyIGljb24gY29sb3IuXG4gICAqL1xuICBoZWFkZXJJY29uQ29sb3I/OiBzdHJpbmc7XG4gIC8qKlxuICAgKiBEZXRlcm1pbmVzIHdoZXRoZXIgdG8gc2hvdyB0aGUgaGVhZGVyIGxlZnQgYm9yZGVyLlxuICAgKi9cbiAgc2hvd0hlYWRlckxlZnRCb3JkZXI/OiBib29sZWFuO1xuICAvKipcbiAgICogRGV0ZXJtaW5lcyB3aGV0aGVyIHRvIHNob3cgdGhlIGhlYWRlciBib3R0b20gYm9yZGVyLlxuICAgKi9cbiAgc2hvd0hlYWRlckJvdHRvbUJvcmRlcj86IGJvb2xlYW47XG4gIC8qKlxuICAgKiBJZGVudGlmaWVzIHRoZSBlbGVtZW50IChvciBlbGVtZW50cykgdGhhdCBsYWJlbHMgdGhlIGVsZW1lbnQgaXQgaXMgYXBwbGllZCB0by5cbiAgICovXG4gIGFyaWFMYWJlbGxlZEJ5Pzogc3RyaW5nO1xuICAvKipcbiAgICogV2lkdGggb2YgdGhlIGRpYWxvZy5cbiAgICovXG4gIHdpZHRoPzogc3RyaW5nO1xuICAvKipcbiAgICogSGVpZ2h0IG9mIHRoZSBkaWFsb2cuXG4gICAqL1xuICBoZWlnaHQ/OiBzdHJpbmc7XG4gIC8qKlxuICAgKiBNaW4td2lkdGggb2YgdGhlIGRpYWxvZy5cbiAgICovXG4gIG1pbldpZHRoPzogc3RyaW5nO1xuICAvKipcbiAgICogTWluLWhlaWdodCBvZiB0aGUgZGlhbG9nLlxuICAgKi9cbiAgbWluSGVpZ2h0Pzogc3RyaW5nO1xuICAvKipcbiAgICogTWF4LXdpZHRoIG9mIHRoZSBkaWFsb2cuXG4gICAqL1xuICBtYXhXaWR0aD86IHN0cmluZztcbiAgLyoqXG4gICAqIE1heC1oZWlnaHQgb2YgdGhlIGRpYWxvZy5cbiAgICovXG4gIG1heEhlaWdodD86IHN0cmluZztcbiAgLyoqXG4gICAqIFNwZWNpZmllcyBpZiBwcmVzc2luZyBlc2NhcGUga2V5IHNob3VsZCBoaWRlIHRoZSBkaWFsb2cuXG4gICAqL1xuICBjbG9zZU9uRXNjYXBlPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIEJhc2UgekluZGV4IHZhbHVlIHRvIHVzZSBpbiBsYXllcmluZy5cbiAgICovXG4gIGJhc2VaSW5kZXg/OiBudW1iZXI7XG4gIC8qKlxuICAgKiBEZXRlcm1pbmVzIHdoZXRoZXIgdG8gYXV0b21hdGljYWxseSBtYW5hZ2UgbGF5ZXJpbmcuXG4gICAqL1xuICBhdXRvWkluZGV4PzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIFNwZWNpZmllcyB3aGV0aGVyIHRoZSB1c2VyIGlzIGFsbG93ZWQgdG8gY2xvc2UgdGhlIGRpYWxvZy5cbiAgICovXG4gIGRpc2FibGVDbG9zZT86IGJvb2xlYW47XG4gIC8qKlxuICAgKiBJbmxpbmUgc3R5bGUgb2YgdGhlIGNvbXBvbmVudC5cbiAgICovXG4gIHN0eWxlPzogeyBba2xhc3M6IHN0cmluZ106IGFueSB9IHwgbnVsbCB8IHVuZGVmaW5lZDtcbiAgLyoqXG4gICAqIFN0eWxlIGNsYXNzIG9mIHRoZSBjb21wb25lbnQuXG4gICAqL1xuICBzdHlsZUNsYXNzPzogc3RyaW5nO1xuICAvKipcbiAgICogSW5saW5lIHN0eWxlIG9mIHRoZSBjb250ZW50LlxuICAgKi9cbiAgY29udGVudFN0eWxlPzogeyBba2xhc3M6IHN0cmluZ106IGFueSB9IHwgbnVsbCB8IHVuZGVmaW5lZDtcbiAgLyoqXG4gICAqIFN0eWxlIGNsYXNzIG9mIHRoZSBjb250ZW50LlxuICAgKi9cbiAgY29udGVudFN0eWxlQ2xhc3M/OiBzdHJpbmc7XG4gIC8qKlxuICAgKiBUcmFuc2l0aW9uIG9wdGlvbnMgb2YgdGhlIGFuaW1hdGlvbi5cbiAgICovXG4gIHRyYW5zaXRpb25PcHRpb25zPzogc3RyaW5nO1xuICAvKipcbiAgICogQWRkcyBhIGNsb3NlIGJ1dHRvbiB0byB0aGUgaGVhZGVyIHRvIGhpZGUgdGhlIGRpYWxvZy5cbiAgICovXG4gIHNob3dDbG9zZUJ0bj86IGJvb2xlYW47XG4gIC8qKlxuICAgKiBEZWZpbmVzIGlmIGJhY2tncm91bmQgc2hvdWxkIGJlIGJsb2NrZWQgd2hlbiBkaWFsb2cgaXMgZGlzcGxheWVkLlxuICAgKi9cbiAgbW9kYWw/OiBib29sZWFuO1xuICAvKipcbiAgICogV2hlbiBtb2RhbCBkaWFsb2cgaXMgZGlzcGxheWVkLCBkZXRlcm1pbmVzIHdoZXRoZXIgYmFja2dyb3VuZCBzaG91bGQgYmUgYmx1cnJlZC5cbiAgICovXG4gIGJsdXJyZWRCYWNrZ3JvdW5kPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIFN0eWxlIGNsYXNzIG9mIHRoZSBtYXNrLlxuICAgKi9cbiAgbWFza1N0eWxlQ2xhc3M/OiBzdHJpbmc7XG4gIC8qKlxuICAgKiBFbmFibGVzIHJlc2l6aW5nIG9mIHRoZSBjb250ZW50LlxuICAgKi9cbiAgcmVzaXphYmxlPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIEVuYWJsZXMgZHJhZ2dpbmcgdG8gY2hhbmdlIHRoZSBwb3NpdGlvbiB1c2luZyBoZWFkZXIuXG4gICAqL1xuICBkcmFnZ2FibGU/OiBib29sZWFuO1xuICAvKipcbiAgICogS2VlcHMgZGlhbG9nIGluIHRoZSB2aWV3cG9ydC5cbiAgICovXG4gIGtlZXBJblZpZXdwb3J0PzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIE1pbmltdW0gdmFsdWUgZm9yIHRoZSBsZWZ0IGNvb3JkaW5hdGUgb2YgZGlhbG9nIGluIGRyYWdnaW5nLlxuICAgKi9cbiAgbWluWD86IG51bWJlcjtcbiAgLyoqXG4gICAqIE1pbmltdW0gdmFsdWUgZm9yIHRoZSB0b3AgY29vcmRpbmF0ZSBvZiBkaWFsb2cgaW4gZHJhZ2dpbmcuXG4gICAqL1xuICBtaW5ZPzogbnVtYmVyO1xuICAvKipcbiAgICogRGV0ZXJtaW5lcyB3aGV0aGVyIHRoZSBkaWFsb2cgY2FuIGJlIGRpc3BsYXllZCBmdWxsIHNjcmVlbi5cbiAgICovXG4gIG1heGltaXphYmxlPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIERldGVybWluZXMgd2hldGhlciB0aGUgZGlhbG9nIGlzIGluaXRpYWxseSBvcGVuZWQgYXMgZnVsbCBzY3JlZW4uXG4gICAqL1xuICBtYXhpbWl6ZWQ/OiBib29sZWFuO1xuICAvKipcbiAgICogUG9zaXRpb24gb2YgdGhlIGRpYWxvZywgb3B0aW9ucyBhcmUgXCJjZW50ZXJcIiwgXCJ0b3BcIiwgXCJib3R0b21cIiwgXCJsZWZ0XCIsIFwicmlnaHRcIiwgXCJ0b3AtbGVmdFwiLCBcInRvcC1yaWdodFwiLCBcImJvdHRvbS1sZWZ0XCIgb3IgXCJib3R0b20tcmlnaHRcIi5cbiAgICovXG4gIHBvc2l0aW9uPzpcbiAgICB8ICdjZW50ZXInXG4gICAgfCAndG9wJ1xuICAgIHwgJ2JvdHRvbSdcbiAgICB8ICdsZWZ0J1xuICAgIHwgJ3JpZ2h0J1xuICAgIHwgJ3RvcC1sZWZ0J1xuICAgIHwgJ3RvcC1yaWdodCdcbiAgICB8ICdib3R0b20tbGVmdCdcbiAgICB8ICdib3R0b20tcmlnaHQnO1xufVxuIl19
|
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
import { Injectable, Inject, createComponent } from '@angular/core';
|
|
2
|
+
import { DOCUMENT } from '@angular/common';
|
|
3
|
+
import { CpsNotificationAppearance, CpsNotificationPosition } from './utils/cps-notification-config';
|
|
4
|
+
import { CpsNotificationType } from './utils/internal/cps-notification-data';
|
|
5
|
+
import { CpsNotificationContainerComponent } from './internal/components/cps-notification-container/cps-notification-container.component';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
/**
|
|
8
|
+
* Service for showing notifications.
|
|
9
|
+
* @group Services
|
|
10
|
+
*/
|
|
11
|
+
export class CpsNotificationService {
|
|
12
|
+
// eslint-disable-next-line no-useless-constructor
|
|
13
|
+
constructor(_appRef, document) {
|
|
14
|
+
this._appRef = _appRef;
|
|
15
|
+
this.document = document;
|
|
16
|
+
this._containersMap = new Map();
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Shows a notification with type 'info'.
|
|
20
|
+
* @param {string} message - Notification message.
|
|
21
|
+
* @param {string} details - Notification details.
|
|
22
|
+
* @param {CpsNotificationConfig} config - CpsNotificationConfig object.
|
|
23
|
+
* @group Method
|
|
24
|
+
*/
|
|
25
|
+
info(message, details, config) {
|
|
26
|
+
this._createNotification(CpsNotificationType.INFO, message, details, config);
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Shows a notification with type 'warning'.
|
|
30
|
+
* @param {string} message - Notification message.
|
|
31
|
+
* @param {string} details - Notification details.
|
|
32
|
+
* @param {CpsNotificationConfig} config - CpsNotificationConfig object.
|
|
33
|
+
* @group Method
|
|
34
|
+
*/
|
|
35
|
+
warning(message, details, config) {
|
|
36
|
+
this._createNotification(CpsNotificationType.WARNING, message, details, config);
|
|
37
|
+
}
|
|
38
|
+
/**
|
|
39
|
+
* Shows a notification with type 'success'.
|
|
40
|
+
* @param {string} message - Notification message.
|
|
41
|
+
* @param {string} details - Notification details.
|
|
42
|
+
* @param {CpsNotificationConfig} config - CpsNotificationConfig object.
|
|
43
|
+
* @group Method
|
|
44
|
+
*/
|
|
45
|
+
success(message, details, config) {
|
|
46
|
+
this._createNotification(CpsNotificationType.SUCCESS, message, details, config);
|
|
47
|
+
}
|
|
48
|
+
/**
|
|
49
|
+
* Shows a notification with type 'error'.
|
|
50
|
+
* @param {string} message - Notification message.
|
|
51
|
+
* @param {string} details - Notification details.
|
|
52
|
+
* @param {CpsNotificationConfig} config - CpsNotificationConfig object.
|
|
53
|
+
* @group Method
|
|
54
|
+
*/
|
|
55
|
+
error(message, details, config) {
|
|
56
|
+
this._createNotification(CpsNotificationType.ERROR, message, details, config);
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* Clears all notifications.
|
|
60
|
+
* @group Method
|
|
61
|
+
*/
|
|
62
|
+
clear() {
|
|
63
|
+
this._containersMap.forEach((container) => {
|
|
64
|
+
this._appRef.detachView(container.hostView);
|
|
65
|
+
container.destroy();
|
|
66
|
+
});
|
|
67
|
+
this._containersMap.clear();
|
|
68
|
+
}
|
|
69
|
+
_createNotification(type, message, details, config) {
|
|
70
|
+
config = this._initConfig(config);
|
|
71
|
+
const data = { type, message, details };
|
|
72
|
+
this._appendNotificationToContainer(data, config);
|
|
73
|
+
}
|
|
74
|
+
_initConfig(config) {
|
|
75
|
+
if (!config)
|
|
76
|
+
config = {};
|
|
77
|
+
if (!config.appearance)
|
|
78
|
+
config.appearance = CpsNotificationAppearance.FILLED;
|
|
79
|
+
if (!config.position)
|
|
80
|
+
config.position = CpsNotificationPosition.TOPRIGHT;
|
|
81
|
+
if (config.timeout === undefined || config.timeout === null)
|
|
82
|
+
config.timeout = 5000;
|
|
83
|
+
return config;
|
|
84
|
+
}
|
|
85
|
+
_appendNotificationToContainer(data, config) {
|
|
86
|
+
const position = config.position || CpsNotificationPosition.TOPRIGHT;
|
|
87
|
+
let containerComponentRef = this._containersMap.get(position);
|
|
88
|
+
const found = !!containerComponentRef;
|
|
89
|
+
if (!containerComponentRef) {
|
|
90
|
+
containerComponentRef = createComponent(CpsNotificationContainerComponent, { environmentInjector: this._appRef.injector });
|
|
91
|
+
containerComponentRef.setInput('position', position);
|
|
92
|
+
containerComponentRef.setInput('maxAmount', config.maxAmount);
|
|
93
|
+
this._appRef.attachView(containerComponentRef.hostView);
|
|
94
|
+
const domElem = containerComponentRef.hostView
|
|
95
|
+
.rootNodes[0];
|
|
96
|
+
this.document.body.appendChild(domElem);
|
|
97
|
+
containerComponentRef.instance.closed.subscribe(() => {
|
|
98
|
+
this._tryRemoveContainer(position);
|
|
99
|
+
});
|
|
100
|
+
this._containersMap.set(position, containerComponentRef);
|
|
101
|
+
}
|
|
102
|
+
if (found && config.maxAmount)
|
|
103
|
+
containerComponentRef.setInput('maxAmount', config.maxAmount);
|
|
104
|
+
containerComponentRef.instance.addNotification(config, data);
|
|
105
|
+
}
|
|
106
|
+
_tryRemoveContainer(position) {
|
|
107
|
+
const container = this._containersMap.get(position);
|
|
108
|
+
if (!container?.instance || container.instance.notifications.length > 0)
|
|
109
|
+
return;
|
|
110
|
+
if (container) {
|
|
111
|
+
this._appRef.detachView(container.hostView);
|
|
112
|
+
container.destroy();
|
|
113
|
+
this._containersMap.delete(position);
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsNotificationService, deps: [{ token: i0.ApplicationRef }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
117
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsNotificationService, providedIn: 'root' }); }
|
|
118
|
+
}
|
|
119
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsNotificationService, decorators: [{
|
|
120
|
+
type: Injectable,
|
|
121
|
+
args: [{ providedIn: 'root' }]
|
|
122
|
+
}], ctorParameters: () => [{ type: i0.ApplicationRef }, { type: Document, decorators: [{
|
|
123
|
+
type: Inject,
|
|
124
|
+
args: [DOCUMENT]
|
|
125
|
+
}] }] });
|
|
126
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-notification.service.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/services/cps-notification/cps-notification.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Injectable,\n  EmbeddedViewRef,\n  ComponentRef,\n  Inject,\n  ApplicationRef,\n  createComponent\n} from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\nimport {\n  CpsNotificationAppearance,\n  CpsNotificationConfig,\n  CpsNotificationPosition\n} from './utils/cps-notification-config';\nimport {\n  CpsNotificationData,\n  CpsNotificationType\n} from './utils/internal/cps-notification-data';\nimport { CpsNotificationContainerComponent } from './internal/components/cps-notification-container/cps-notification-container.component';\n\n/**\n * Service for showing notifications.\n * @group Services\n */\n@Injectable({ providedIn: 'root' })\nexport class CpsNotificationService {\n  private _containersMap: Map<\n    CpsNotificationPosition,\n    ComponentRef<CpsNotificationContainerComponent>\n  > = new Map();\n\n  // eslint-disable-next-line no-useless-constructor\n  constructor(\n    private _appRef: ApplicationRef,\n    @Inject(DOCUMENT) private document: Document\n  ) {}\n\n  /**\n   * Shows a notification with type 'info'.\n   * @param {string} message - Notification message.\n   * @param {string} details - Notification details.\n   * @param {CpsNotificationConfig} config - CpsNotificationConfig object.\n   * @group Method\n   */\n  public info(\n    message: string,\n    details?: string,\n    config?: CpsNotificationConfig\n  ) {\n    this._createNotification(\n      CpsNotificationType.INFO,\n      message,\n      details,\n      config\n    );\n  }\n\n  /**\n   * Shows a notification with type 'warning'.\n   * @param {string} message - Notification message.\n   * @param {string} details - Notification details.\n   * @param {CpsNotificationConfig} config - CpsNotificationConfig object.\n   * @group Method\n   */\n  public warning(\n    message: string,\n    details?: string,\n    config?: CpsNotificationConfig\n  ) {\n    this._createNotification(\n      CpsNotificationType.WARNING,\n      message,\n      details,\n      config\n    );\n  }\n\n  /**\n   * Shows a notification with type 'success'.\n   * @param {string} message - Notification message.\n   * @param {string} details - Notification details.\n   * @param {CpsNotificationConfig} config - CpsNotificationConfig object.\n   * @group Method\n   */\n  public success(\n    message: string,\n    details?: string,\n    config?: CpsNotificationConfig\n  ) {\n    this._createNotification(\n      CpsNotificationType.SUCCESS,\n      message,\n      details,\n      config\n    );\n  }\n\n  /**\n   * Shows a notification with type 'error'.\n   * @param {string} message - Notification message.\n   * @param {string} details - Notification details.\n   * @param {CpsNotificationConfig} config - CpsNotificationConfig object.\n   * @group Method\n   */\n  public error(\n    message: string,\n    details?: string,\n    config?: CpsNotificationConfig\n  ) {\n    this._createNotification(\n      CpsNotificationType.ERROR,\n      message,\n      details,\n      config\n    );\n  }\n\n  /**\n   * Clears all notifications.\n   * @group Method\n   */\n  public clear() {\n    this._containersMap.forEach((container) => {\n      this._appRef.detachView(container.hostView);\n      container.destroy();\n    });\n    this._containersMap.clear();\n  }\n\n  private _createNotification(\n    type: CpsNotificationType,\n    message: string,\n    details?: string,\n    config?: CpsNotificationConfig\n  ) {\n    config = this._initConfig(config);\n    const data: CpsNotificationData = { type, message, details };\n\n    this._appendNotificationToContainer(data, config);\n  }\n\n  private _initConfig(config?: CpsNotificationConfig): CpsNotificationConfig {\n    if (!config) config = {};\n    if (!config.appearance)\n      config.appearance = CpsNotificationAppearance.FILLED;\n    if (!config.position) config.position = CpsNotificationPosition.TOPRIGHT;\n    if (config.timeout === undefined || config.timeout === null)\n      config.timeout = 5000;\n    return config;\n  }\n\n  private _appendNotificationToContainer(\n    data: CpsNotificationData,\n    config: CpsNotificationConfig\n  ) {\n    const position = config.position || CpsNotificationPosition.TOPRIGHT;\n\n    let containerComponentRef = this._containersMap.get(position);\n    const found = !!containerComponentRef;\n\n    if (!containerComponentRef) {\n      containerComponentRef = createComponent(\n        CpsNotificationContainerComponent,\n        { environmentInjector: this._appRef.injector }\n      );\n      containerComponentRef.setInput('position', position);\n      containerComponentRef.setInput('maxAmount', config.maxAmount);\n\n      this._appRef.attachView(containerComponentRef.hostView);\n\n      const domElem = (containerComponentRef.hostView as EmbeddedViewRef<any>)\n        .rootNodes[0] as HTMLElement;\n      this.document.body.appendChild(domElem);\n\n      containerComponentRef.instance.closed.subscribe(() => {\n        this._tryRemoveContainer(position);\n      });\n\n      this._containersMap.set(position, containerComponentRef);\n    }\n\n    if (found && config.maxAmount)\n      containerComponentRef.setInput('maxAmount', config.maxAmount);\n\n    containerComponentRef.instance.addNotification(config, data);\n  }\n\n  private _tryRemoveContainer(position: CpsNotificationPosition) {\n    const container = this._containersMap.get(position);\n\n    if (!container?.instance || container.instance.notifications.length > 0)\n      return;\n\n    if (container) {\n      this._appRef.detachView(container.hostView);\n      container.destroy();\n      this._containersMap.delete(position);\n    }\n  }\n}\n"]}
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { Component, EventEmitter, Input, Output, ViewChild, ViewEncapsulation } from '@angular/core';
|
|
3
|
+
import { SharedModule } from 'primeng/api';
|
|
4
|
+
import { ZIndexUtils } from 'primeng/utils';
|
|
5
|
+
import { CpsNotificationPosition } from '../../../utils/cps-notification-config';
|
|
6
|
+
import { CpsButtonComponent } from '../../../../../components/cps-button/cps-button.component';
|
|
7
|
+
import { CpsInfoCircleComponent } from '../../../../../components/cps-info-circle/cps-info-circle.component';
|
|
8
|
+
import { CpsIconComponent } from '../../../../../components/cps-icon/cps-icon.component';
|
|
9
|
+
import { CpsToastComponent } from '../cps-toast/cps-toast.component';
|
|
10
|
+
import { animateChild, query, transition, trigger } from '@angular/animations';
|
|
11
|
+
import * as i0 from "@angular/core";
|
|
12
|
+
import * as i1 from "primeng/api";
|
|
13
|
+
import * as i2 from "@angular/common";
|
|
14
|
+
export class CpsNotificationContainerComponent {
|
|
15
|
+
// eslint-disable-next-line no-useless-constructor
|
|
16
|
+
constructor(renderer, zone, primeNGConfig, _cdRef) {
|
|
17
|
+
this.renderer = renderer;
|
|
18
|
+
this.zone = zone;
|
|
19
|
+
this.primeNGConfig = primeNGConfig;
|
|
20
|
+
this._cdRef = _cdRef;
|
|
21
|
+
/**
|
|
22
|
+
* Position of the notification container.
|
|
23
|
+
* @group Props
|
|
24
|
+
*/
|
|
25
|
+
this.position = CpsNotificationPosition.TOPRIGHT;
|
|
26
|
+
/**
|
|
27
|
+
* Callback to invoke on notification close.
|
|
28
|
+
* @param {CpsNotificationConfig} CpsNotificationConfig - notification closed.
|
|
29
|
+
* @group Emits
|
|
30
|
+
*/
|
|
31
|
+
this.closed = new EventEmitter();
|
|
32
|
+
this.CpsNotificationPosition = CpsNotificationPosition;
|
|
33
|
+
this.notifications = [];
|
|
34
|
+
}
|
|
35
|
+
ngAfterViewInit() {
|
|
36
|
+
this.wrapper = (this.container?.nativeElement).parentElement;
|
|
37
|
+
this.moveOnTop();
|
|
38
|
+
}
|
|
39
|
+
addNotification(config, data) {
|
|
40
|
+
if (this.notifications.length > 0 &&
|
|
41
|
+
this.notifications.length === this.maxAmount) {
|
|
42
|
+
this.notifications.pop();
|
|
43
|
+
}
|
|
44
|
+
this.notifications.unshift({ data, config });
|
|
45
|
+
}
|
|
46
|
+
onCloseNotification(index) {
|
|
47
|
+
this.notifications.splice(index, 1);
|
|
48
|
+
this.closed.emit();
|
|
49
|
+
this._cdRef.detectChanges();
|
|
50
|
+
}
|
|
51
|
+
moveOnTop() {
|
|
52
|
+
ZIndexUtils.set('modal', this.container?.nativeElement, this.primeNGConfig.zIndex.modal);
|
|
53
|
+
this.wrapper.style.zIndex = String(parseInt((this.container?.nativeElement).style.zIndex, 10) - 1);
|
|
54
|
+
}
|
|
55
|
+
ngOnDestroy() {
|
|
56
|
+
if (this.container?.nativeElement) {
|
|
57
|
+
ZIndexUtils.clear(this.container.nativeElement);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsNotificationContainerComponent, deps: [{ token: i0.Renderer2 }, { token: i0.NgZone }, { token: i1.PrimeNGConfig }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
61
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: CpsNotificationContainerComponent, isStandalone: true, selector: "cps-notification-container", inputs: { position: "position", maxAmount: "maxAmount" }, outputs: { closed: "closed" }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }], ngImport: i0, template: "<div\n [ngClass]=\"{\n 'cps-notification-container-mask': true,\n 'cps-notification-container-left':\n position === CpsNotificationPosition.LEFT,\n 'cps-notification-container-right':\n position === CpsNotificationPosition.RIGHT,\n 'cps-notification-container-top': position === CpsNotificationPosition.TOP,\n 'cps-notification-container-bottom':\n position === CpsNotificationPosition.BOTTOM,\n 'cps-notification-container-top-left':\n position === CpsNotificationPosition.TOPLEFT,\n 'cps-notification-container-top-right':\n position === CpsNotificationPosition.TOPRIGHT,\n 'cps-notification-container-bottom-left':\n position === CpsNotificationPosition.BOTTOMLEFT,\n 'cps-notification-container-bottom-right':\n position === CpsNotificationPosition.BOTTOMRIGHT\n }\">\n <div #container class=\"cps-notification-container\" role=\"notification\">\n <div\n #content\n class=\"cps-notification-container-content\"\n [ngStyle]=\"{\n 'align-items': [\n CpsNotificationPosition.RIGHT,\n CpsNotificationPosition.TOPRIGHT,\n CpsNotificationPosition.BOTTOMRIGHT\n ].includes(position)\n ? 'flex-end'\n : 'flex-start'\n }\">\n <cps-toast\n *ngFor=\"let notification of notifications; let i = index\"\n [data]=\"notification.data\"\n [config]=\"notification.config\"\n @notificationAnimation\n (closed)=\"onCloseNotification(i)\">\n </cps-toast>\n </div>\n </div>\n</div>\n", styles: [".cps-notification-container-mask{position:fixed;top:0;left:0;width:100%;height:100%;display:flex;justify-content:center;align-items:center;pointer-events:none}.cps-notification-container{box-sizing:border-box;display:flex;flex-direction:column;pointer-events:auto;transform:scale(1);position:relative;border-radius:4px;border:0 none;font-family:Source Sans Pro,sans-serif;font-size:1rem;font-weight:400}.cps-notification-container .cps-notification-container-content{background:transparent;flex-grow:1;gap:12px;display:flex;flex-direction:column-reverse}.cps-notification-container-top .cps-notification-container,.cps-notification-container-bottom .cps-notification-container,.cps-notification-container-left .cps-notification-container,.cps-notification-container-right .cps-notification-container,.cps-notification-container-top-left .cps-notification-container,.cps-notification-container-top-right .cps-notification-container,.cps-notification-container-bottom-left .cps-notification-container,.cps-notification-container-bottom-right .cps-notification-container{margin:.75rem;transform:translateZ(0)}.cps-notification-container-left{justify-content:flex-start}.cps-notification-container-right{justify-content:flex-end}.cps-notification-container-top{align-items:flex-start}.cps-notification-container-top-left{justify-content:flex-start;align-items:flex-start}.cps-notification-container-top-right{justify-content:flex-end;align-items:flex-start}.cps-notification-container-bottom{align-items:flex-end}.cps-notification-container-bottom-left{justify-content:flex-start;align-items:flex-end}.cps-notification-container-bottom-right{justify-content:flex-end;align-items:flex-end}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: SharedModule }, { kind: "component", type: CpsToastComponent, selector: "cps-toast", inputs: ["config", "data"], outputs: ["closed"] }], animations: [
|
|
62
|
+
trigger('notificationAnimation', [
|
|
63
|
+
transition(':enter, :leave', [query('@*', animateChild())])
|
|
64
|
+
])
|
|
65
|
+
], encapsulation: i0.ViewEncapsulation.None }); }
|
|
66
|
+
}
|
|
67
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsNotificationContainerComponent, decorators: [{
|
|
68
|
+
type: Component,
|
|
69
|
+
args: [{ selector: 'cps-notification-container', standalone: true, imports: [
|
|
70
|
+
CommonModule,
|
|
71
|
+
SharedModule,
|
|
72
|
+
CpsButtonComponent,
|
|
73
|
+
CpsInfoCircleComponent,
|
|
74
|
+
CpsIconComponent,
|
|
75
|
+
CpsToastComponent
|
|
76
|
+
], encapsulation: ViewEncapsulation.None, animations: [
|
|
77
|
+
trigger('notificationAnimation', [
|
|
78
|
+
transition(':enter, :leave', [query('@*', animateChild())])
|
|
79
|
+
])
|
|
80
|
+
], template: "<div\n [ngClass]=\"{\n 'cps-notification-container-mask': true,\n 'cps-notification-container-left':\n position === CpsNotificationPosition.LEFT,\n 'cps-notification-container-right':\n position === CpsNotificationPosition.RIGHT,\n 'cps-notification-container-top': position === CpsNotificationPosition.TOP,\n 'cps-notification-container-bottom':\n position === CpsNotificationPosition.BOTTOM,\n 'cps-notification-container-top-left':\n position === CpsNotificationPosition.TOPLEFT,\n 'cps-notification-container-top-right':\n position === CpsNotificationPosition.TOPRIGHT,\n 'cps-notification-container-bottom-left':\n position === CpsNotificationPosition.BOTTOMLEFT,\n 'cps-notification-container-bottom-right':\n position === CpsNotificationPosition.BOTTOMRIGHT\n }\">\n <div #container class=\"cps-notification-container\" role=\"notification\">\n <div\n #content\n class=\"cps-notification-container-content\"\n [ngStyle]=\"{\n 'align-items': [\n CpsNotificationPosition.RIGHT,\n CpsNotificationPosition.TOPRIGHT,\n CpsNotificationPosition.BOTTOMRIGHT\n ].includes(position)\n ? 'flex-end'\n : 'flex-start'\n }\">\n <cps-toast\n *ngFor=\"let notification of notifications; let i = index\"\n [data]=\"notification.data\"\n [config]=\"notification.config\"\n @notificationAnimation\n (closed)=\"onCloseNotification(i)\">\n </cps-toast>\n </div>\n </div>\n</div>\n", styles: [".cps-notification-container-mask{position:fixed;top:0;left:0;width:100%;height:100%;display:flex;justify-content:center;align-items:center;pointer-events:none}.cps-notification-container{box-sizing:border-box;display:flex;flex-direction:column;pointer-events:auto;transform:scale(1);position:relative;border-radius:4px;border:0 none;font-family:Source Sans Pro,sans-serif;font-size:1rem;font-weight:400}.cps-notification-container .cps-notification-container-content{background:transparent;flex-grow:1;gap:12px;display:flex;flex-direction:column-reverse}.cps-notification-container-top .cps-notification-container,.cps-notification-container-bottom .cps-notification-container,.cps-notification-container-left .cps-notification-container,.cps-notification-container-right .cps-notification-container,.cps-notification-container-top-left .cps-notification-container,.cps-notification-container-top-right .cps-notification-container,.cps-notification-container-bottom-left .cps-notification-container,.cps-notification-container-bottom-right .cps-notification-container{margin:.75rem;transform:translateZ(0)}.cps-notification-container-left{justify-content:flex-start}.cps-notification-container-right{justify-content:flex-end}.cps-notification-container-top{align-items:flex-start}.cps-notification-container-top-left{justify-content:flex-start;align-items:flex-start}.cps-notification-container-top-right{justify-content:flex-end;align-items:flex-start}.cps-notification-container-bottom{align-items:flex-end}.cps-notification-container-bottom-left{justify-content:flex-start;align-items:flex-end}.cps-notification-container-bottom-right{justify-content:flex-end;align-items:flex-end}\n"] }]
|
|
81
|
+
}], ctorParameters: () => [{ type: i0.Renderer2 }, { type: i0.NgZone }, { type: i1.PrimeNGConfig }, { type: i0.ChangeDetectorRef }], propDecorators: { position: [{
|
|
82
|
+
type: Input
|
|
83
|
+
}], maxAmount: [{
|
|
84
|
+
type: Input
|
|
85
|
+
}], closed: [{
|
|
86
|
+
type: Output
|
|
87
|
+
}], container: [{
|
|
88
|
+
type: ViewChild,
|
|
89
|
+
args: ['container']
|
|
90
|
+
}] } });
|
|
91
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-notification-container.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/cps-ui-kit/src/lib/services/cps-notification/internal/components/cps-notification-container/cps-notification-container.component.ts","../../../../../../../../../projects/cps-ui-kit/src/lib/services/cps-notification/internal/components/cps-notification-container/cps-notification-container.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  NgZone,\n  OnDestroy,\n  Output,\n  Renderer2,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\nimport { PrimeNGConfig, SharedModule } from 'primeng/api';\nimport { ZIndexUtils } from 'primeng/utils';\nimport {\n  CpsNotificationConfig,\n  CpsNotificationPosition\n} from '../../../utils/cps-notification-config';\nimport { CpsNotificationData } from '../../../utils/internal/cps-notification-data';\nimport { CpsButtonComponent } from '../../../../../components/cps-button/cps-button.component';\nimport { CpsInfoCircleComponent } from '../../../../../components/cps-info-circle/cps-info-circle.component';\nimport { CpsIconComponent } from '../../../../../components/cps-icon/cps-icon.component';\nimport { CpsToastComponent } from '../cps-toast/cps-toast.component';\nimport { animateChild, query, transition, trigger } from '@angular/animations';\n\ntype Nullable<T = void> = T | null | undefined;\n\n@Component({\n  selector: 'cps-notification-container',\n  standalone: true,\n  imports: [\n    CommonModule,\n    SharedModule,\n    CpsButtonComponent,\n    CpsInfoCircleComponent,\n    CpsIconComponent,\n    CpsToastComponent\n  ],\n  templateUrl: './cps-notification-container.component.html',\n  styleUrls: ['./cps-notification-container.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  animations: [\n    trigger('notificationAnimation', [\n      transition(':enter, :leave', [query('@*', animateChild())])\n    ])\n  ]\n})\nexport class CpsNotificationContainerComponent\n  implements AfterViewInit, OnDestroy\n{\n  /**\n   * Position of the notification container.\n   * @group Props\n   */\n  @Input() position = CpsNotificationPosition.TOPRIGHT;\n\n  /**\n   * Max amount of notifications to be displayed within the container.\n   * @group Props\n   */\n  @Input() maxAmount?: number;\n\n  /**\n   * Callback to invoke on notification close.\n   * @param {CpsNotificationConfig} CpsNotificationConfig - notification closed.\n   * @group Emits\n   */\n  @Output() closed = new EventEmitter();\n\n  CpsNotificationPosition = CpsNotificationPosition;\n\n  @ViewChild('container') container: Nullable<ElementRef>;\n\n  wrapper: Nullable<HTMLElement>;\n\n  notifications: {\n    data: CpsNotificationData;\n    config: CpsNotificationConfig;\n  }[] = [];\n\n  // eslint-disable-next-line no-useless-constructor\n  constructor(\n    public renderer: Renderer2,\n    public zone: NgZone,\n    public primeNGConfig: PrimeNGConfig,\n    private _cdRef: ChangeDetectorRef\n  ) {}\n\n  ngAfterViewInit() {\n    this.wrapper = (\n      this.container?.nativeElement as HTMLDivElement\n    ).parentElement;\n    this.moveOnTop();\n  }\n\n  addNotification(config: CpsNotificationConfig, data: CpsNotificationData) {\n    if (\n      this.notifications.length > 0 &&\n      this.notifications.length === this.maxAmount\n    ) {\n      this.notifications.pop();\n    }\n    this.notifications.unshift({ data, config });\n  }\n\n  onCloseNotification(index: number) {\n    this.notifications.splice(index, 1);\n    this.closed.emit();\n    this._cdRef.detectChanges();\n  }\n\n  moveOnTop() {\n    ZIndexUtils.set(\n      'modal',\n      this.container?.nativeElement,\n      this.primeNGConfig.zIndex.modal\n    );\n    (this.wrapper as HTMLElement).style.zIndex = String(\n      parseInt(\n        (this.container?.nativeElement as HTMLDivElement).style.zIndex,\n        10\n      ) - 1\n    );\n  }\n\n  ngOnDestroy() {\n    if (this.container?.nativeElement) {\n      ZIndexUtils.clear(this.container.nativeElement);\n    }\n  }\n}\n","<div\n  [ngClass]=\"{\n    'cps-notification-container-mask': true,\n    'cps-notification-container-left':\n      position === CpsNotificationPosition.LEFT,\n    'cps-notification-container-right':\n      position === CpsNotificationPosition.RIGHT,\n    'cps-notification-container-top': position === CpsNotificationPosition.TOP,\n    'cps-notification-container-bottom':\n      position === CpsNotificationPosition.BOTTOM,\n    'cps-notification-container-top-left':\n      position === CpsNotificationPosition.TOPLEFT,\n    'cps-notification-container-top-right':\n      position === CpsNotificationPosition.TOPRIGHT,\n    'cps-notification-container-bottom-left':\n      position === CpsNotificationPosition.BOTTOMLEFT,\n    'cps-notification-container-bottom-right':\n      position === CpsNotificationPosition.BOTTOMRIGHT\n  }\">\n  <div #container class=\"cps-notification-container\" role=\"notification\">\n    <div\n      #content\n      class=\"cps-notification-container-content\"\n      [ngStyle]=\"{\n        'align-items': [\n          CpsNotificationPosition.RIGHT,\n          CpsNotificationPosition.TOPRIGHT,\n          CpsNotificationPosition.BOTTOMRIGHT\n        ].includes(position)\n          ? 'flex-end'\n          : 'flex-start'\n      }\">\n      <cps-toast\n        *ngFor=\"let notification of notifications; let i = index\"\n        [data]=\"notification.data\"\n        [config]=\"notification.config\"\n        @notificationAnimation\n        (closed)=\"onCloseNotification(i)\">\n      </cps-toast>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -54,28 +54,28 @@ export class CpsToastComponent {
|
|
|
54
54
|
this.timeout = null;
|
|
55
55
|
}
|
|
56
56
|
}
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
57
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsToastComponent, deps: [{ token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
58
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: CpsToastComponent, isStandalone: true, selector: "cps-toast", inputs: { config: "config", data: "data" }, outputs: { closed: "closed" }, ngImport: i0, template: "<div\n (mouseenter)=\"clearTimeout()\"\n (mouseleave)=\"initiateTimeout()\"\n [class]=\"data.type\"\n [@toastState]=\"{\n value: 'visible'\n }\"\n [ngStyle]=\"{ 'max-width': maxWidth }\"\n class=\"cps-toast-content\">\n <div class=\"cps-toast-icon\" [ngClass]=\"{ filled: filled }\">\n <cps-icon\n [icon]=\"'toast-' + data.type\"\n [color]=\"filled ? '#fff' : color\"\n size=\"normal\"></cps-icon>\n </div>\n <div class=\"cps-toast-message\">\n <p class=\"cps-toast-message-header\">{{ data.message || '' }}</p>\n <p class=\"cps-toast-message-details\" *ngIf=\"data.details\">\n {{ data.details }}\n </p>\n </div>\n <div class=\"cps-toast-buttons\">\n <cps-button\n (clicked)=\"close()\"\n [color]=\"color\"\n icon=\"close-x\"\n class=\"cps-toast-close-button\"\n width=\"40\"\n type=\"borderless\"></cps-button>\n </div>\n</div>\n", styles: [":host .cps-toast-content{color:var(--cps-color-text-darkest);border-radius:4px;box-shadow:0 1px 3px #0000004d;display:flex;overflow:hidden}:host .cps-toast-content.success{background-color:var(--cps-color-success-bg);border:2px solid var(--cps-color-success)}:host .cps-toast-content.success .cps-toast-icon.filled{background-color:var(--cps-color-success)}:host .cps-toast-content.error{background-color:var(--cps-color-error-bg);border:2px solid var(--cps-color-error)}:host .cps-toast-content.error .cps-toast-icon.filled{background-color:var(--cps-color-error)}:host .cps-toast-content.warning{background-color:var(--cps-color-warn-bg);border:2px solid var(--cps-color-warn)}:host .cps-toast-content.warning .cps-toast-icon.filled{background-color:var(--cps-color-warn)}:host .cps-toast-content.info{background-color:var(--cps-color-info-bg);border:2px solid var(--cps-color-info)}:host .cps-toast-content.info .cps-toast-icon.filled{background-color:var(--cps-color-info)}:host .cps-toast-icon{display:flex;align-items:center;padding:20px}:host .cps-toast-message{display:flex;flex-direction:column;justify-content:center;padding:0 16px;font-weight:600;font-family:Source Sans Pro,sans-serif;cursor:default}:host .cps-toast-message .cps-toast-message-details{margin-top:0;font-size:14px}:host .cps-toast-buttons{display:flex;justify-content:center;align-items:center}:host .cps-toast-buttons .cps-toast-close-button{margin:0 8px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: CpsButtonComponent, selector: "cps-button", inputs: ["color", "contentColor", "type", "label", "icon", "iconPosition", "size", "width", "height", "disabled", "loading"], outputs: ["clicked"] }, { kind: "component", type: CpsIconComponent, selector: "cps-icon", inputs: ["icon", "size", "color"] }], animations: [
|
|
59
|
+
trigger('toastState', [
|
|
60
|
+
state('visible', style({
|
|
61
|
+
transform: 'translateY(0)',
|
|
62
|
+
opacity: 1
|
|
63
|
+
})),
|
|
64
|
+
transition('void => *', [
|
|
65
|
+
style({ transform: 'translateY(100%)', opacity: 0 }),
|
|
66
|
+
animate('200ms ease-out')
|
|
67
|
+
]),
|
|
68
|
+
transition('* => void', [
|
|
69
|
+
animate('200ms ease-in', style({
|
|
70
|
+
height: 0,
|
|
71
|
+
opacity: 0,
|
|
72
|
+
transform: 'translateY(-100%)'
|
|
73
|
+
}))
|
|
74
|
+
])
|
|
75
75
|
])
|
|
76
|
-
])
|
|
77
|
-
|
|
78
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
76
|
+
] }); }
|
|
77
|
+
}
|
|
78
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CpsToastComponent, decorators: [{
|
|
79
79
|
type: Component,
|
|
80
80
|
args: [{ standalone: true, imports: [CommonModule, CpsButtonComponent, CpsIconComponent], selector: 'cps-toast', animations: [
|
|
81
81
|
trigger('toastState', [
|
|
@@ -96,11 +96,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
96
96
|
])
|
|
97
97
|
])
|
|
98
98
|
], template: "<div\n (mouseenter)=\"clearTimeout()\"\n (mouseleave)=\"initiateTimeout()\"\n [class]=\"data.type\"\n [@toastState]=\"{\n value: 'visible'\n }\"\n [ngStyle]=\"{ 'max-width': maxWidth }\"\n class=\"cps-toast-content\">\n <div class=\"cps-toast-icon\" [ngClass]=\"{ filled: filled }\">\n <cps-icon\n [icon]=\"'toast-' + data.type\"\n [color]=\"filled ? '#fff' : color\"\n size=\"normal\"></cps-icon>\n </div>\n <div class=\"cps-toast-message\">\n <p class=\"cps-toast-message-header\">{{ data.message || '' }}</p>\n <p class=\"cps-toast-message-details\" *ngIf=\"data.details\">\n {{ data.details }}\n </p>\n </div>\n <div class=\"cps-toast-buttons\">\n <cps-button\n (clicked)=\"close()\"\n [color]=\"color\"\n icon=\"close-x\"\n class=\"cps-toast-close-button\"\n width=\"40\"\n type=\"borderless\"></cps-button>\n </div>\n</div>\n", styles: [":host .cps-toast-content{color:var(--cps-color-text-darkest);border-radius:4px;box-shadow:0 1px 3px #0000004d;display:flex;overflow:hidden}:host .cps-toast-content.success{background-color:var(--cps-color-success-bg);border:2px solid var(--cps-color-success)}:host .cps-toast-content.success .cps-toast-icon.filled{background-color:var(--cps-color-success)}:host .cps-toast-content.error{background-color:var(--cps-color-error-bg);border:2px solid var(--cps-color-error)}:host .cps-toast-content.error .cps-toast-icon.filled{background-color:var(--cps-color-error)}:host .cps-toast-content.warning{background-color:var(--cps-color-warn-bg);border:2px solid var(--cps-color-warn)}:host .cps-toast-content.warning .cps-toast-icon.filled{background-color:var(--cps-color-warn)}:host .cps-toast-content.info{background-color:var(--cps-color-info-bg);border:2px solid var(--cps-color-info)}:host .cps-toast-content.info .cps-toast-icon.filled{background-color:var(--cps-color-info)}:host .cps-toast-icon{display:flex;align-items:center;padding:20px}:host .cps-toast-message{display:flex;flex-direction:column;justify-content:center;padding:0 16px;font-weight:600;font-family:Source Sans Pro,sans-serif;cursor:default}:host .cps-toast-message .cps-toast-message-details{margin-top:0;font-size:14px}:host .cps-toast-buttons{display:flex;justify-content:center;align-items:center}:host .cps-toast-buttons .cps-toast-close-button{margin:0 8px}\n"] }]
|
|
99
|
-
}], ctorParameters:
|
|
99
|
+
}], ctorParameters: () => [{ type: i0.NgZone }], propDecorators: { config: [{
|
|
100
100
|
type: Input
|
|
101
101
|
}], data: [{
|
|
102
102
|
type: Input
|
|
103
103
|
}], closed: [{
|
|
104
104
|
type: Output
|
|
105
105
|
}] } });
|
|
106
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
106
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-toast.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/cps-ui-kit/src/lib/services/cps-notification/internal/components/cps-toast/cps-toast.component.ts","../../../../../../../../../projects/cps-ui-kit/src/lib/services/cps-notification/internal/components/cps-toast/cps-toast.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  EventEmitter,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Output\n} from '@angular/core';\nimport { CpsButtonComponent } from '../../../../../components/cps-button/cps-button.component';\nimport { CpsIconComponent } from '../../../../../components/cps-icon/cps-icon.component';\nimport { CommonModule } from '@angular/common';\nimport { convertSize } from '../../../../../utils/internal/size-utils';\nimport {\n  CpsNotificationAppearance,\n  CpsNotificationConfig\n} from '../../../utils/cps-notification-config';\nimport {\n  CpsNotificationData,\n  CpsNotificationType\n} from '../../../utils/internal/cps-notification-data';\nimport {\n  animate,\n  state,\n  style,\n  transition,\n  trigger\n} from '@angular/animations';\n\n@Component({\n  standalone: true,\n  imports: [CommonModule, CpsButtonComponent, CpsIconComponent],\n  selector: 'cps-toast',\n  templateUrl: './cps-toast.component.html',\n  styleUrls: ['./cps-toast.component.scss'],\n  animations: [\n    trigger('toastState', [\n      state(\n        'visible',\n        style({\n          transform: 'translateY(0)',\n          opacity: 1\n        })\n      ),\n      transition('void => *', [\n        style({ transform: 'translateY(100%)', opacity: 0 }),\n        animate('200ms ease-out')\n      ]),\n      transition('* => void', [\n        animate(\n          '200ms ease-in',\n          style({\n            height: 0,\n            opacity: 0,\n            transform: 'translateY(-100%)'\n          })\n        )\n      ])\n    ])\n  ]\n})\nexport class CpsToastComponent implements OnInit, AfterViewInit, OnDestroy {\n  @Input() config!: CpsNotificationConfig;\n  @Input() data!: CpsNotificationData;\n\n  /**\n   * Callback to invoke on toast close.\n   * @param {any}\n   * @group Emits\n   */\n  @Output() closed = new EventEmitter();\n\n  timeout: any;\n  maxWidth: string | undefined;\n  filled = true;\n  color = '';\n\n  // eslint-disable-next-line no-useless-constructor\n  constructor(private zone: NgZone) {}\n\n  ngOnInit(): void {\n    this.maxWidth = convertSize(this.config?.maxWidth || '');\n    this.filled = this.config?.appearance === CpsNotificationAppearance.FILLED;\n    this.color =\n      this.data?.type === CpsNotificationType.WARNING\n        ? 'warn'\n        : this.data?.type || CpsNotificationType.ERROR;\n  }\n\n  ngAfterViewInit(): void {\n    this.initiateTimeout();\n  }\n\n  ngOnDestroy() {\n    this.clearTimeout();\n  }\n\n  close() {\n    this.clearTimeout();\n    this.closed.emit();\n  }\n\n  initiateTimeout() {\n    if (this.config?.timeout === 0) return;\n    this.zone.runOutsideAngular(() => {\n      this.timeout = setTimeout(() => {\n        this.close();\n      }, this.config?.timeout || 5000);\n    });\n  }\n\n  clearTimeout() {\n    if (this.timeout) {\n      clearTimeout(this.timeout);\n      this.timeout = null;\n    }\n  }\n}\n","<div\n  (mouseenter)=\"clearTimeout()\"\n  (mouseleave)=\"initiateTimeout()\"\n  [class]=\"data.type\"\n  [@toastState]=\"{\n    value: 'visible'\n  }\"\n  [ngStyle]=\"{ 'max-width': maxWidth }\"\n  class=\"cps-toast-content\">\n  <div class=\"cps-toast-icon\" [ngClass]=\"{ filled: filled }\">\n    <cps-icon\n      [icon]=\"'toast-' + data.type\"\n      [color]=\"filled ? '#fff' : color\"\n      size=\"normal\"></cps-icon>\n  </div>\n  <div class=\"cps-toast-message\">\n    <p class=\"cps-toast-message-header\">{{ data.message || '' }}</p>\n    <p class=\"cps-toast-message-details\" *ngIf=\"data.details\">\n      {{ data.details }}\n    </p>\n  </div>\n  <div class=\"cps-toast-buttons\">\n    <cps-button\n      (clicked)=\"close()\"\n      [color]=\"color\"\n      icon=\"close-x\"\n      class=\"cps-toast-close-button\"\n      width=\"40\"\n      type=\"borderless\"></cps-button>\n  </div>\n</div>\n"]}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
const isSameDomain = (styleSheet) => {
|
|
2
|
+
if (!styleSheet.href) {
|
|
3
|
+
return true;
|
|
4
|
+
}
|
|
5
|
+
return styleSheet.href.indexOf(window.location.origin) === 0;
|
|
6
|
+
};
|
|
7
|
+
const isStyleRule = (rule) => rule.type === 1;
|
|
8
|
+
const isValidCSSColor = (val) => {
|
|
9
|
+
if (val === 'currentColor')
|
|
10
|
+
return true;
|
|
11
|
+
const element = document.createElement('div');
|
|
12
|
+
element.style.backgroundColor = val;
|
|
13
|
+
return element && element.style.backgroundColor !== '';
|
|
14
|
+
};
|
|
15
|
+
const isDark = (color) => {
|
|
16
|
+
let r = 0;
|
|
17
|
+
let g = 0;
|
|
18
|
+
let b = 0;
|
|
19
|
+
if (color.match(/^rgb/)) {
|
|
20
|
+
const colorMatched = color.match(/^rgba?\((\d+),\s*(\d+),\s*(\d+)(?:,\s*(\d+(?:\.\d+)?))?\)$/);
|
|
21
|
+
r = colorMatched[1];
|
|
22
|
+
g = colorMatched[2];
|
|
23
|
+
b = colorMatched[3];
|
|
24
|
+
}
|
|
25
|
+
else {
|
|
26
|
+
const colorNum = +('0x' + color.slice(1).replace(color.length < 5 && /./g, '$&$&'));
|
|
27
|
+
r = colorNum >> 16;
|
|
28
|
+
g = (colorNum >> 8) & 255;
|
|
29
|
+
b = colorNum & 255;
|
|
30
|
+
}
|
|
31
|
+
const hsp = Math.sqrt(0.299 * (r * r) + 0.587 * (g * g) + 0.114 * (b * b));
|
|
32
|
+
// Using the HSP value, determine whether the color is light or dark
|
|
33
|
+
return hsp <= 127.5;
|
|
34
|
+
};
|
|
35
|
+
export const getCpsColors = () => [...document.styleSheets].filter(isSameDomain).reduce((finalArr, sheet) => finalArr.concat([...sheet.cssRules].filter(isStyleRule).reduce((propValArr, rule) => {
|
|
36
|
+
const props = [...rule.style]
|
|
37
|
+
.map((propName) => [
|
|
38
|
+
propName.trim(),
|
|
39
|
+
rule.style.getPropertyValue(propName).trim()
|
|
40
|
+
])
|
|
41
|
+
.filter(([propName]) => propName.indexOf('--cps-color') === 0);
|
|
42
|
+
return [...propValArr, ...props];
|
|
43
|
+
}, [])), []);
|
|
44
|
+
export const getCSSColor = (val) => {
|
|
45
|
+
if (!val)
|
|
46
|
+
return '';
|
|
47
|
+
return isValidCSSColor(val) ? val : `var(--cps-color-${val})`;
|
|
48
|
+
};
|
|
49
|
+
export const getTextColor = (backgroundColor) => {
|
|
50
|
+
if (isDark(backgroundColor)) {
|
|
51
|
+
return '#FFFFFF';
|
|
52
|
+
}
|
|
53
|
+
else {
|
|
54
|
+
return '#000000';
|
|
55
|
+
}
|
|
56
|
+
};
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sb3JzLXV0aWxzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY3BzLXVpLWtpdC9zcmMvbGliL3V0aWxzL2NvbG9ycy11dGlscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLFlBQVksR0FBRyxDQUFDLFVBQWUsRUFBVyxFQUFFO0lBQ2hELElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDckIsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRUQsT0FBTyxVQUFVLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztBQUMvRCxDQUFDLENBQUM7QUFFRixNQUFNLFdBQVcsR0FBRyxDQUFDLElBQVMsRUFBVyxFQUFFLENBQUMsSUFBSSxDQUFDLElBQUksS0FBSyxDQUFDLENBQUM7QUFFNUQsTUFBTSxlQUFlLEdBQUcsQ0FBQyxHQUFXLEVBQVcsRUFBRTtJQUMvQyxJQUFJLEdBQUcsS0FBSyxjQUFjO1FBQUUsT0FBTyxJQUFJLENBQUM7SUFDeEMsTUFBTSxPQUFPLEdBQUcsUUFBUSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUM5QyxPQUFPLENBQUMsS0FBSyxDQUFDLGVBQWUsR0FBRyxHQUFHLENBQUM7SUFDcEMsT0FBTyxPQUFPLElBQUksT0FBTyxDQUFDLEtBQUssQ0FBQyxlQUFlLEtBQUssRUFBRSxDQUFDO0FBQ3pELENBQUMsQ0FBQztBQUVGLE1BQU0sTUFBTSxHQUFHLENBQUMsS0FBYSxFQUFXLEVBQUU7SUFDeEMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ1YsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ1YsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ1YsSUFBSSxLQUFLLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUM7UUFDeEIsTUFB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IGFueSk6IGJvb2xlYW4gPT4ge1xuICBpZiAoIXN0eWxlU2hlZXQuaHJlZikge1xuICAgIHJldHVybiB0cnVlO1xuICB9XG5cbiAgcmV0dXJuIHN0eWxlU2hlZXQuaHJlZi5pbmRleE9mKHdpbmRvdy5sb2NhdGlvbi5vcmlnaW4pID09PSAwO1xufTtcblxuY29uc3QgaXNTdHlsZVJ1bGUgPSAocnVsZTogYW55KTogYm9vbGVhbiA9PiBydWxlLnR5cGUgPT09IDE7XG5cbmNvbnN0IGlzVmFsaWRDU1NDb2xvciA9ICh2YWw6IHN0cmluZyk6IGJvb2xlYW4gPT4ge1xuICBpZiAodmFsID09PSAnY3VycmVudENvbG9yJykgcmV0dXJuIHRydWU7XG4gIGNvbnN0IGVsZW1lbnQgPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50KCdkaXYnKTtcbiAgZWxlbWVudC5zdHlsZS5iYWNrZ3JvdW5kQ29sb3IgPSB2YWw7XG4gIHJldHVybiBlbGVtZW50ICYmIGVsZW1lbnQuc3R5bGUuYmFja2dyb3VuZENvbG9yICE9PSAnJztcbn07XG5cbmNvbnN0IGlzRGFyayA9IChjb2xvcjogc3RyaW5nKTogYm9vbGVhbiA9PiB7XG4gIGxldCByID0gMDtcbiAgbGV0IGcgPSAwO1xuICBsZXQgYiA9IDA7XG4gIGlmIChjb2xvci5tYXRjaCgvXnJnYi8pKSB7XG4gICAgY29uc3QgY29sb3JNYXRjaGVkID0gY29sb3IubWF0Y2goXG4gICAgICAvXnJnYmE/XFwoKFxcZCspLFxccyooXFxkKyksXFxzKihcXGQrKSg/OixcXHMqKFxcZCsoPzpcXC5cXGQrKT8pKT9cXCkkL1xuICAgICkgYXMgYW55O1xuICAgIHIgPSBjb2xvck1hdGNoZWRbMV07XG4gICAgZyA9IGNvbG9yTWF0Y2hlZFsyXTtcbiAgICBiID0gY29sb3JNYXRjaGVkWzNdO1xuICB9IGVsc2Uge1xuICAgIGNvbnN0IGNvbG9yTnVtID0gKyhcbiAgICAgICcweCcgKyBjb2xvci5zbGljZSgxKS5yZXBsYWNlKGNvbG9yLmxlbmd0aCA8IDUgJiYgKC8uL2cgYXMgYW55KSwgJyQmJCYnKVxuICAgICk7XG5cbiAgICByID0gY29sb3JOdW0gPj4gMTY7XG4gICAgZyA9IChjb2xvck51bSA+PiA4KSAmIDI1NTtcbiAgICBiID0gY29sb3JOdW0gJiAyNTU7XG4gIH1cblxuICBjb25zdCBoc3AgPSBNYXRoLnNxcnQoMC4yOTkgKiAociAqIHIpICsgMC41ODcgKiAoZyAqIGcpICsgMC4xMTQgKiAoYiAqIGIpKTtcblxuICAvLyBVc2luZyB0aGUgSFNQIHZhbHVlLCBkZXRlcm1pbmUgd2hldGhlciB0aGUgY29sb3IgaXMgbGlnaHQgb3IgZGFya1xuICByZXR1cm4gaHNwIDw9IDEyNy41O1xufTtcblxuZXhwb3J0IGNvbnN0IGdldENwc0NvbG9ycyA9ICgpOiBbc3RyaW5nLCBzdHJpbmddW10gPT5cbiAgWy4uLihkb2N1bWVudC5zdHlsZVNoZWV0cyBhcyBhbnkpXS5maWx0ZXIoaXNTYW1lRG9tYWluKS5yZWR1Y2UoXG4gICAgKGZpbmFsQXJyLCBzaGVldCkgPT5cbiAgICAgIGZpbmFsQXJyLmNvbmNhdChcbiAgICAgICAgWy4uLnNoZWV0LmNzc1J1bGVzXS5maWx0ZXIoaXNTdHlsZVJ1bGUpLnJlZHVjZSgocHJvcFZhbEFyciwgcnVsZSkgPT4ge1xuICAgICAgICAgIGNvbnN0IHByb3BzID0gWy4uLnJ1bGUuc3R5bGVdXG4gICAgICAgICAgICAubWFwKChwcm9wTmFtZSkgPT4gW1xuICAgICAgICAgICAgICBwcm9wTmFtZS50cmltKCksXG4gICAgICAgICAgICAgIHJ1bGUuc3R5bGUuZ2V0UHJvcGVydHlWYWx1ZShwcm9wTmFtZSkudHJpbSgpXG4gICAgICAgICAgICBdKVxuICAgICAgICAgICAgLmZpbHRlcigoW3Byb3BOYW1lXSkgPT4gcHJvcE5hbWUuaW5kZXhPZignLS1jcHMtY29sb3InKSA9PT0gMCk7XG5cbiAgICAgICAgICByZXR1cm4gWy4uLnByb3BWYWxBcnIsIC4uLnByb3BzXTtcbiAgICAgICAgfSwgW10pXG4gICAgICApLFxuICAgIFtdXG4gICk7XG5cbmV4cG9ydCBjb25zdCBnZXRDU1NDb2xvciA9ICh2YWw6IHN0cmluZyk6IHN0cmluZyA9PiB7XG4gIGlmICghdmFsKSByZXR1cm4gJyc7XG4gIHJldHVybiBpc1ZhbGlkQ1NTQ29sb3IodmFsKSA/IHZhbCA6IGB2YXIoLS1jcHMtY29sb3ItJHt2YWx9KWA7XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0VGV4dENvbG9yID0gKGJhY2tncm91bmRDb2xvcjogc3RyaW5nKTogc3RyaW5nID0+IHtcbiAgaWYgKGlzRGFyayhiYWNrZ3JvdW5kQ29sb3IpKSB7XG4gICAgcmV0dXJuICcjRkZGRkZGJztcbiAgfSBlbHNlIHtcbiAgICByZXR1cm4gJyMwMDAwMDAnO1xuICB9XG59O1xuIl19
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
export const convertSize = (size) => {
|
|
2
|
+
const res = String(size).trim();
|
|
3
|
+
if (!res) {
|
|
4
|
+
return '';
|
|
5
|
+
}
|
|
6
|
+
if (res.startsWith('calc(') && res.endsWith(')'))
|
|
7
|
+
return res;
|
|
8
|
+
if (/^\d+(\.\d+)?$/i.test(res)) {
|
|
9
|
+
return res + 'px';
|
|
10
|
+
}
|
|
11
|
+
if (/^\d+(\.\d+)?(px|rem|em|%)$/i.test(res)) {
|
|
12
|
+
return res;
|
|
13
|
+
}
|
|
14
|
+
throw new Error(`Invalid size value: ${size}`);
|
|
15
|
+
};
|
|
16
|
+
export const parseSize = (size) => {
|
|
17
|
+
const match = size.match(/^(\d+(?:\.\d+)?)(px|rem|em|%)$/);
|
|
18
|
+
if (!match)
|
|
19
|
+
throw new Error(`Invalid size value: ${size}`);
|
|
20
|
+
const value = parseFloat(match[1]);
|
|
21
|
+
const unit = match[2];
|
|
22
|
+
return { value, unit };
|
|
23
|
+
};
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2l6ZS11dGlscy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Nwcy11aS1raXQvc3JjL2xpYi91dGlscy9pbnRlcm5hbC9zaXplLXV0aWxzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBQyxNQUFNLFdBQVcsR0FBRyxDQUFDLElBQXFCLEVBQVUsRUFBRTtJQUMzRCxNQUFNLEdBQUcsR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDaEMsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDO1FBQ1QsT0FBTyxFQUFFLENBQUM7SUFDWixDQUFDO0lBRUQsSUFBSSxHQUFHLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxJQUFJLEdBQUcsQ0FBQyxRQUFRLENBQUMsR0FBRyxDQUFDO1FBQUUsT0FBTyxHQUFHLENBQUM7SUFFN0QsSUFBSSxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQztRQUMvQixPQUFPLEdBQUcsR0FBRyxJQUFJLENBQUM7SUFDcEIsQ0FBQztJQUNELElBQUksNkJBQTZCLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUM7UUFDNUMsT0FBTyxHQUFHLENBQUM7SUFDYixDQUFDO0lBRUQsTUFBTSxJQUFJLEtBQUssQ0FBQyx1QkFBdUIsSUFBSSxFQUFFLENBQUMsQ0FBQztBQUNqRCxDQUFDLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxTQUFTLEdBQUcsQ0FBQyxJQUFZLEVBQW1DLEVBQUU7SUFDekUsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxnQ0FBZ0MsQ0FBQyxDQUFDO0lBQzNELElBQUksQ0FBQyxLQUFLO1FBQUUsTUFBTSxJQUFJLEtBQUssQ0FBQyx1QkFBdUIsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUMzRCxNQUFNLEtBQUssR0FBRyxVQUFVLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDbkMsTUFBTSxJQUFJLEdBQUcsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ3RCLE9BQU8sRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFLENBQUM7QUFDekIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IGNvbnZlcnRTaXplID0gKHNpemU6IG51bWJlciB8IHN0cmluZyk6IHN0cmluZyA9PiB7XG4gIGNvbnN0IHJlcyA9IFN0cmluZyhzaXplKS50cmltKCk7XG4gIGlmICghcmVzKSB7XG4gICAgcmV0dXJuICcnO1xuICB9XG5cbiAgaWYgKHJlcy5zdGFydHNXaXRoKCdjYWxjKCcpICYmIHJlcy5lbmRzV2l0aCgnKScpKSByZXR1cm4gcmVzO1xuXG4gIGlmICgvXlxcZCsoXFwuXFxkKyk/JC9pLnRlc3QocmVzKSkge1xuICAgIHJldHVybiByZXMgKyAncHgnO1xuICB9XG4gIGlmICgvXlxcZCsoXFwuXFxkKyk/KHB4fHJlbXxlbXwlKSQvaS50ZXN0KHJlcykpIHtcbiAgICByZXR1cm4gcmVzO1xuICB9XG5cbiAgdGhyb3cgbmV3IEVycm9yKGBJbnZhbGlkIHNpemUgdmFsdWU6ICR7c2l6ZX1gKTtcbn07XG5cbmV4cG9ydCBjb25zdCBwYXJzZVNpemUgPSAoc2l6ZTogc3RyaW5nKTogeyB2YWx1ZTogbnVtYmVyOyB1bml0OiBzdHJpbmcgfSA9PiB7XG4gIGNvbnN0IG1hdGNoID0gc2l6ZS5tYXRjaCgvXihcXGQrKD86XFwuXFxkKyk/KShweHxyZW18ZW18JSkkLyk7XG4gIGlmICghbWF0Y2gpIHRocm93IG5ldyBFcnJvcihgSW52YWxpZCBzaXplIHZhbHVlOiAke3NpemV9YCk7XG4gIGNvbnN0IHZhbHVlID0gcGFyc2VGbG9hdChtYXRjaFsxXSk7XG4gIGNvbnN0IHVuaXQgPSBtYXRjaFsyXTtcbiAgcmV0dXJuIHsgdmFsdWUsIHVuaXQgfTtcbn07XG4iXX0=
|
|
@@ -41,11 +41,11 @@ export * from './lib/components/cps-tab-group/cps-tab-group.component';
|
|
|
41
41
|
export * from './lib/components/cps-tab-group/cps-tab/cps-tab.component';
|
|
42
42
|
export * from './lib/components/cps-timepicker/cps-timepicker.component';
|
|
43
43
|
export * from './lib/components/cps-file-upload/cps-file-upload.component';
|
|
44
|
-
export * from './lib/directives/cps-tooltip.directive';
|
|
44
|
+
export * from './lib/directives/cps-tooltip/cps-tooltip.directive';
|
|
45
45
|
export * from './lib/services/cps-dialog/cps-dialog.service';
|
|
46
46
|
export * from './lib/services/cps-dialog/utils/cps-dialog-config';
|
|
47
47
|
export * from './lib/services/cps-dialog/utils/cps-dialog-ref';
|
|
48
48
|
export * from './lib/services/cps-notification/cps-notification.service';
|
|
49
49
|
export * from './lib/services/cps-notification/utils/cps-notification-config';
|
|
50
50
|
export * from './lib/utils/colors-utils';
|
|
51
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2Nwcy11aS1raXQvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsZ0RBQWdELENBQUM7QUFDL0QsY0FBYyxrREFBa0QsQ0FBQztBQUNqRSxjQUFjLDREQUE0RCxDQUFDO0FBQzNFLGNBQWMsOERBQThELENBQUM7QUFDN0UsY0FBYyx3RUFBd0UsQ0FBQztBQUN2RixjQUFjLDREQUE0RCxDQUFDO0FBQzNFLGNBQWMsa0RBQWtELENBQUM7QUFDakUsY0FBYyxzREFBc0QsQ0FBQztBQUNyRSxjQUFjLGdFQUFnRSxDQUFDO0FBQy9FLGNBQWMsNERBQTRELENBQUM7QUFDM0UsY0FBYyxnREFBZ0QsQ0FBQztBQUMvRCxjQUFjLDJFQUEyRSxDQUFDO0FBQzFGLGNBQWMseUVBQXlFLENBQUM7QUFDeEYsY0FBYyw2RUFBNkUsQ0FBQztBQUM1RixjQUFjLDBFQUEwRSxDQUFDO0FBQ3pGLGNBQWMsb0RBQW9ELENBQUM7QUFDbkUsY0FBYywwREFBMEQsQ0FBQztBQUN6RSxjQUFjLHFGQUFxRixDQUFDO0FBQ3BHLGNBQWMsbUZBQW1GLENBQUM7QUFDbEcsY0FBYyxpRkFBaUYsQ0FBQztBQUNoRyxjQUFjLHVGQUF1RixDQUFDO0FBQ3RHLGNBQWMsb0ZBQW9GLENBQUM7QUFDbkcsY0FBYyw0Q0FBNEMsQ0FBQztBQUMzRCxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsOENBQThDLENBQUM7QUFDN0QsY0FBYyx3REFBd0QsQ0FBQztBQUN2RSxjQUFjLHdEQUF3RCxDQUFDO0FBQ3ZFLGNBQWMsa0RBQWtELENBQUM7QUFDakUsY0FBYyxvRUFBb0UsQ0FBQztBQUNuRixjQUFjLHdFQUF3RSxDQUFDO0FBQ3ZGLGNBQWMsb0VBQW9FLENBQUM7QUFDbkYsY0FBYywwREFBMEQsQ0FBQztBQUN6RSxjQUFjLDhEQUE4RCxDQUFDO0FBQzdFLGNBQWMsc0RBQXNELENBQUM7QUFDckUsY0FBYyxnRUFBZ0UsQ0FBQztBQUMvRSxjQUFjLHdEQUF3RCxDQUFDO0FBQ3ZFLGNBQWMsMERBQTBELENBQUM7QUFDekUsY0FBYywwREFBMEQsQ0FBQztBQUN6RSxjQUFjLDREQUE0RCxDQUFDO0FBRTNFLGNBQWMsb0RBQW9ELENBQUM7QUFFbkUsY0FBYyw4Q0FBOEMsQ0FBQztBQUM3RCxjQUFjLG1EQUFtRCxDQUFDO0FBQ2xFLGNBQWMsZ0RBQWdELENBQUM7QUFFL0QsY0FBYywwREFBMEQsQ0FBQztBQUN6RSxjQUFjLCtEQUErRCxDQUFDO0FBRTlFLGNBQWMsMEJBQTBCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIGNwcy11aS1raXRcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1pY29uL2Nwcy1pY29uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1pbnB1dC9jcHMtaW5wdXQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXNlbGVjdC9jcHMtc2VsZWN0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy10cmVlLXNlbGVjdC9jcHMtdHJlZS1zZWxlY3QuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLWF1dG9jb21wbGV0ZS9jcHMtYXV0b2NvbXBsZXRlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy10cmVlLWF1dG9jb21wbGV0ZS9jcHMtdHJlZS1hdXRvY29tcGxldGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLWluZm8tY2lyY2xlL2Nwcy1pbmZvLWNpcmNsZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtYnV0dG9uL2Nwcy1idXR0b24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLWNoZWNrYm94L2Nwcy1jaGVja2JveC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtcmFkaW8tZ3JvdXAvY3BzLXJhZGlvL2Nwcy1yYWRpby5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtcmFkaW8tZ3JvdXAvY3BzLXJhZGlvLWdyb3VwLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy10YWJsZS9jcHMtdGFibGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXRhYmxlL2RpcmVjdGl2ZXMvY3BzLXRhYmxlLWNvbHVtbi1zb3J0YWJsZS5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdGFibGUvZGlyZWN0aXZlcy9jcHMtdGFibGUtY29sdW1uLWZpbHRlci5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdGFibGUvZGlyZWN0aXZlcy9jcHMtdGFibGUtaGVhZGVyLXNlbGVjdGFibGUuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXRhYmxlL2RpcmVjdGl2ZXMvY3BzLXRhYmxlLXJvdy1zZWxlY3RhYmxlLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy10YWJsZS9jcHMtY29sdW1uLWZpbHRlci10eXBlcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy10cmVlLXRhYmxlL2Nwcy10cmVlLXRhYmxlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy10cmVlLXRhYmxlL2RpcmVjdGl2ZXMvY3BzLXRyZWUtdGFibGUtY29sdW1uLXNvcnRhYmxlLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy10cmVlLXRhYmxlL2RpcmVjdGl2ZXMvY3BzLXRyZWUtdGFibGUtY29sdW1uLWZpbHRlci5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdHJlZS10YWJsZS9kaXJlY3RpdmVzL2Nwcy10cmVlLXRhYmxlLXJvdy10b2dnbGVyLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy10cmVlLXRhYmxlL2RpcmVjdGl2ZXMvY3BzLXRyZWUtdGFibGUtaGVhZGVyLXNlbGVjdGFibGUuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXRyZWUtdGFibGUvZGlyZWN0aXZlcy9jcHMtdHJlZS10YWJsZS1yb3ctc2VsZWN0YWJsZS5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdGFnL2Nwcy10YWcuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLWNoaXAvY3BzLWNoaXAuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLW1lbnUvY3BzLW1lbnUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXBhZ2luYXRvci9jcHMtcGFnaW5hdG9yLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1wYWdpbmF0b3IvcGlwZXMvY3BzLXBhZ2luYXRlLnBpcGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtbG9hZGVyL2Nwcy1sb2FkZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLWV4cGFuc2lvbi1wYW5lbC9jcHMtZXhwYW5zaW9uLXBhbmVsLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1wcm9ncmVzcy1jaXJjdWxhci9jcHMtcHJvZ3Jlc3MtY2lyY3VsYXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXByb2dyZXNzLWxpbmVhci9jcHMtcHJvZ3Jlc3MtbGluZWFyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1kYXRlcGlja2VyL2Nwcy1kYXRlcGlja2VyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1zaWRlYmFyLW1lbnUvY3BzLXNpZGViYXItbWVudS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdGV4dGFyZWEvY3BzLXRleHRhcmVhLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1idXR0b24tdG9nZ2xlL2Nwcy1idXR0b24tdG9nZ2xlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy10YWItZ3JvdXAvY3BzLXRhYi1ncm91cC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdGFiLWdyb3VwL2Nwcy10YWIvY3BzLXRhYi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdGltZXBpY2tlci9jcHMtdGltZXBpY2tlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtZmlsZS11cGxvYWQvY3BzLWZpbGUtdXBsb2FkLmNvbXBvbmVudCc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpcmVjdGl2ZXMvY3BzLXRvb2x0aXAvY3BzLXRvb2x0aXAuZGlyZWN0aXZlJztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZXMvY3BzLWRpYWxvZy9jcHMtZGlhbG9nLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZXMvY3BzLWRpYWxvZy91dGlscy9jcHMtZGlhbG9nLWNvbmZpZyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZXJ2aWNlcy9jcHMtZGlhbG9nL3V0aWxzL2Nwcy1kaWFsb2ctcmVmJztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZXMvY3BzLW5vdGlmaWNhdGlvbi9jcHMtbm90aWZpY2F0aW9uLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZXMvY3BzLW5vdGlmaWNhdGlvbi91dGlscy9jcHMtbm90aWZpY2F0aW9uLWNvbmZpZyc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL3V0aWxzL2NvbG9ycy11dGlscyc7XG4iXX0=
|