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.
Files changed (166) hide show
  1. package/esm2022/lib/components/cps-autocomplete/cps-autocomplete.component.mjs +824 -0
  2. package/esm2022/lib/components/cps-button/cps-button.component.mjs +190 -0
  3. package/esm2022/lib/components/cps-button-toggle/cps-button-toggle.component.mjs +235 -0
  4. package/esm2022/lib/components/cps-checkbox/cps-checkbox.component.mjs +149 -0
  5. package/esm2022/lib/components/cps-chip/cps-chip.component.mjs +94 -0
  6. package/esm2022/lib/components/cps-datepicker/cps-datepicker.component.mjs +382 -0
  7. package/esm2022/lib/components/cps-expansion-panel/cps-expansion-panel.component.mjs +209 -0
  8. package/esm2022/lib/components/cps-file-upload/cps-file-upload.component.mjs +138 -0
  9. package/esm2022/lib/components/cps-icon/cps-icon.component.mjs +193 -0
  10. package/esm2022/lib/components/cps-info-circle/cps-info-circle.component.mjs +61 -0
  11. package/esm2022/lib/components/cps-input/cps-input.component.mjs +386 -0
  12. package/{esm2020 → esm2022}/lib/components/cps-loader/cps-loader.component.mjs +5 -5
  13. package/esm2022/lib/components/cps-menu/cps-menu.component.mjs +552 -0
  14. package/esm2022/lib/components/cps-paginator/cps-paginator.component.mjs +114 -0
  15. package/esm2022/lib/components/cps-paginator/pipes/cps-paginate.pipe.mjs +30 -0
  16. package/{esm2020 → esm2022}/lib/components/cps-progress-circular/cps-progress-circular.component.mjs +4 -4
  17. package/{esm2020 → esm2022}/lib/components/cps-progress-linear/cps-progress-linear.component.mjs +4 -4
  18. package/{esm2020 → esm2022}/lib/components/cps-radio-group/cps-radio/cps-radio.component.mjs +7 -7
  19. package/esm2022/lib/components/cps-radio-group/cps-radio-button/cps-radio-button.component.mjs +55 -0
  20. package/esm2022/lib/components/cps-radio-group/cps-radio-group.component.mjs +158 -0
  21. package/esm2022/lib/components/cps-select/cps-select.component.mjs +615 -0
  22. package/esm2022/lib/components/cps-sidebar-menu/cps-sidebar-menu.component.mjs +110 -0
  23. package/{esm2020 → esm2022}/lib/components/cps-tab-group/cps-tab/cps-tab.component.mjs +4 -4
  24. package/esm2022/lib/components/cps-tab-group/cps-tab-group.component.mjs +303 -0
  25. package/esm2022/lib/components/cps-table/components/internal/cps-sort-icon/cps-sort-icon.component.mjs +79 -0
  26. package/esm2022/lib/components/cps-table/components/internal/table-column-filter/table-column-filter.component.mjs +408 -0
  27. package/esm2022/lib/components/cps-table/components/internal/table-column-filter-constraint/table-column-filter-constraint.component.mjs +149 -0
  28. package/esm2022/lib/components/cps-table/components/internal/table-row-menu/table-row-menu.component.mjs +88 -0
  29. package/esm2022/lib/components/cps-table/cps-table.component.mjs +941 -0
  30. package/esm2022/lib/components/cps-table/directives/cps-table-column-filter.directive.mjs +181 -0
  31. package/{esm2020 → esm2022}/lib/components/cps-table/directives/cps-table-column-sortable.directive.mjs +5 -5
  32. package/{esm2020 → esm2022}/lib/components/cps-table/directives/cps-table-header-selectable.directive.mjs +5 -5
  33. package/{esm2020 → esm2022}/lib/components/cps-table/directives/cps-table-row-selectable.directive.mjs +5 -5
  34. package/esm2022/lib/components/cps-table/directives/internal/table-unsort.directive.mjs +220 -0
  35. package/esm2022/lib/components/cps-tag/cps-tag.component.mjs +136 -0
  36. package/esm2022/lib/components/cps-textarea/cps-textarea.component.mjs +291 -0
  37. package/esm2022/lib/components/cps-timepicker/cps-timepicker.component.mjs +351 -0
  38. package/esm2022/lib/components/cps-tree-autocomplete/cps-tree-autocomplete.component.mjs +251 -0
  39. package/esm2022/lib/components/cps-tree-select/cps-tree-select.component.mjs +87 -0
  40. package/esm2022/lib/components/cps-tree-table/cps-tree-table.component.mjs +1196 -0
  41. package/{esm2020 → esm2022}/lib/components/cps-tree-table/directives/cps-tree-table-column-filter.directive.mjs +5 -5
  42. package/{esm2020 → esm2022}/lib/components/cps-tree-table/directives/cps-tree-table-column-sortable.directive.mjs +5 -5
  43. package/{esm2020 → esm2022}/lib/components/cps-tree-table/directives/cps-tree-table-header-selectable.directive.mjs +5 -5
  44. package/{esm2020 → esm2022}/lib/components/cps-tree-table/directives/cps-tree-table-row-selectable.directive.mjs +5 -5
  45. package/esm2022/lib/components/cps-tree-table/directives/cps-tree-table-row-toggler.directive.mjs +43 -0
  46. package/esm2022/lib/components/cps-tree-table/directives/internal/tree-table-unsort.directive.mjs +354 -0
  47. package/esm2022/lib/components/internal/cps-base-tree-dropdown/cps-base-tree-dropdown.component.mjs +619 -0
  48. package/esm2022/lib/directives/cps-tooltip/cps-tooltip.directive.mjs +257 -0
  49. package/{esm2020 → esm2022}/lib/pipes/internal/check-option-selected.pipe.mjs +4 -4
  50. package/esm2022/lib/pipes/internal/combine-labels.pipe.mjs +25 -0
  51. package/{esm2020 → esm2022}/lib/pipes/internal/label-by-value.pipe.mjs +4 -4
  52. package/esm2022/lib/services/cps-dialog/cps-dialog.service.mjs +99 -0
  53. package/{esm2020 → esm2022}/lib/services/cps-dialog/internal/components/cps-confirmation/cps-confirmation.component.mjs +5 -5
  54. package/esm2022/lib/services/cps-dialog/internal/components/cps-dialog/cps-dialog.component.mjs +470 -0
  55. package/{esm2020 → esm2022}/lib/services/cps-dialog/internal/directives/cps-dialog-content.directive.mjs +5 -5
  56. package/esm2022/lib/services/cps-dialog/utils/cps-dialog-config.mjs +3 -0
  57. package/esm2022/lib/services/cps-notification/cps-notification.service.mjs +126 -0
  58. package/esm2022/lib/services/cps-notification/internal/components/cps-notification-container/cps-notification-container.component.mjs +91 -0
  59. package/{esm2020 → esm2022}/lib/services/cps-notification/internal/components/cps-toast/cps-toast.component.mjs +23 -23
  60. package/esm2022/lib/utils/colors-utils.mjs +57 -0
  61. package/esm2022/lib/utils/internal/size-utils.mjs +24 -0
  62. package/{esm2020 → esm2022}/public-api.mjs +2 -2
  63. package/{fesm2020 → fesm2022}/cps-ui-kit.mjs +481 -391
  64. package/fesm2022/cps-ui-kit.mjs.map +1 -0
  65. package/lib/components/cps-autocomplete/cps-autocomplete.component.d.ts +2 -2
  66. package/lib/components/cps-button/cps-button.component.d.ts +1 -1
  67. package/lib/components/cps-button-toggle/cps-button-toggle.component.d.ts +2 -2
  68. package/lib/components/cps-checkbox/cps-checkbox.component.d.ts +2 -2
  69. package/lib/components/cps-chip/cps-chip.component.d.ts +1 -1
  70. package/lib/components/cps-datepicker/cps-datepicker.component.d.ts +2 -2
  71. package/lib/components/cps-expansion-panel/cps-expansion-panel.component.d.ts +1 -1
  72. package/lib/components/cps-file-upload/cps-file-upload.component.d.ts +1 -1
  73. package/lib/components/cps-icon/cps-icon.component.d.ts +1 -1
  74. package/lib/components/cps-info-circle/cps-info-circle.component.d.ts +2 -2
  75. package/lib/components/cps-input/cps-input.component.d.ts +2 -2
  76. package/lib/components/cps-loader/cps-loader.component.d.ts +1 -1
  77. package/lib/components/cps-menu/cps-menu.component.d.ts +1 -1
  78. package/lib/components/cps-paginator/cps-paginator.component.d.ts +1 -1
  79. package/lib/components/cps-progress-circular/cps-progress-circular.component.d.ts +1 -1
  80. package/lib/components/cps-progress-linear/cps-progress-linear.component.d.ts +1 -1
  81. package/lib/components/cps-radio-group/cps-radio/cps-radio.component.d.ts +1 -1
  82. package/lib/components/cps-radio-group/cps-radio-button/cps-radio-button.component.d.ts +1 -1
  83. package/lib/components/cps-radio-group/cps-radio-group.component.d.ts +2 -2
  84. package/lib/components/cps-select/cps-select.component.d.ts +2 -2
  85. package/lib/components/cps-sidebar-menu/cps-sidebar-menu.component.d.ts +1 -1
  86. package/lib/components/cps-tab-group/cps-tab/cps-tab.component.d.ts +1 -1
  87. package/lib/components/cps-tab-group/cps-tab-group.component.d.ts +1 -1
  88. package/lib/components/cps-table/components/internal/cps-sort-icon/cps-sort-icon.component.d.ts +1 -1
  89. package/lib/components/cps-table/components/internal/table-column-filter/table-column-filter.component.d.ts +1 -1
  90. package/lib/components/cps-table/components/internal/table-column-filter-constraint/table-column-filter-constraint.component.d.ts +1 -1
  91. package/lib/components/cps-table/components/internal/table-row-menu/table-row-menu.component.d.ts +1 -1
  92. package/lib/components/cps-table/cps-table.component.d.ts +1 -1
  93. package/lib/components/cps-table/directives/cps-table-column-filter.directive.d.ts +1 -1
  94. package/lib/components/cps-table/directives/cps-table-column-sortable.directive.d.ts +1 -1
  95. package/lib/components/cps-table/directives/cps-table-row-selectable.directive.d.ts +1 -1
  96. package/lib/components/cps-tag/cps-tag.component.d.ts +1 -1
  97. package/lib/components/cps-textarea/cps-textarea.component.d.ts +2 -2
  98. package/lib/components/cps-timepicker/cps-timepicker.component.d.ts +2 -2
  99. package/lib/components/cps-tree-autocomplete/cps-tree-autocomplete.component.d.ts +1 -1
  100. package/lib/components/cps-tree-select/cps-tree-select.component.d.ts +1 -1
  101. package/lib/components/cps-tree-table/cps-tree-table.component.d.ts +4 -4
  102. package/lib/components/cps-tree-table/directives/cps-tree-table-column-filter.directive.d.ts +1 -1
  103. package/lib/components/cps-tree-table/directives/cps-tree-table-column-sortable.directive.d.ts +1 -1
  104. package/lib/components/cps-tree-table/directives/cps-tree-table-row-selectable.directive.d.ts +1 -1
  105. package/lib/components/cps-tree-table/directives/cps-tree-table-row-toggler.directive.d.ts +1 -1
  106. package/lib/components/internal/cps-base-tree-dropdown/cps-base-tree-dropdown.component.d.ts +2 -2
  107. package/lib/directives/{cps-tooltip.directive.d.ts → cps-tooltip/cps-tooltip.directive.d.ts} +2 -2
  108. package/lib/services/cps-dialog/cps-dialog.service.d.ts +13 -0
  109. package/lib/services/cps-dialog/utils/cps-dialog-config.d.ts +1 -1
  110. package/lib/services/cps-notification/cps-notification.service.d.ts +32 -0
  111. package/lib/services/cps-notification/internal/components/cps-notification-container/cps-notification-container.component.d.ts +1 -1
  112. package/lib/services/cps-notification/internal/components/cps-toast/cps-toast.component.d.ts +1 -1
  113. package/package.json +12 -18
  114. package/public-api.d.ts +1 -1
  115. package/esm2020/lib/components/cps-autocomplete/cps-autocomplete.component.mjs +0 -824
  116. package/esm2020/lib/components/cps-button/cps-button.component.mjs +0 -190
  117. package/esm2020/lib/components/cps-button-toggle/cps-button-toggle.component.mjs +0 -235
  118. package/esm2020/lib/components/cps-checkbox/cps-checkbox.component.mjs +0 -149
  119. package/esm2020/lib/components/cps-chip/cps-chip.component.mjs +0 -94
  120. package/esm2020/lib/components/cps-datepicker/cps-datepicker.component.mjs +0 -382
  121. package/esm2020/lib/components/cps-expansion-panel/cps-expansion-panel.component.mjs +0 -209
  122. package/esm2020/lib/components/cps-file-upload/cps-file-upload.component.mjs +0 -138
  123. package/esm2020/lib/components/cps-icon/cps-icon.component.mjs +0 -193
  124. package/esm2020/lib/components/cps-info-circle/cps-info-circle.component.mjs +0 -61
  125. package/esm2020/lib/components/cps-input/cps-input.component.mjs +0 -386
  126. package/esm2020/lib/components/cps-menu/cps-menu.component.mjs +0 -552
  127. package/esm2020/lib/components/cps-paginator/cps-paginator.component.mjs +0 -113
  128. package/esm2020/lib/components/cps-paginator/pipes/cps-paginate.pipe.mjs +0 -30
  129. package/esm2020/lib/components/cps-radio-group/cps-radio-button/cps-radio-button.component.mjs +0 -55
  130. package/esm2020/lib/components/cps-radio-group/cps-radio-group.component.mjs +0 -158
  131. package/esm2020/lib/components/cps-select/cps-select.component.mjs +0 -615
  132. package/esm2020/lib/components/cps-sidebar-menu/cps-sidebar-menu.component.mjs +0 -110
  133. package/esm2020/lib/components/cps-tab-group/cps-tab-group.component.mjs +0 -299
  134. package/esm2020/lib/components/cps-table/components/internal/cps-sort-icon/cps-sort-icon.component.mjs +0 -79
  135. package/esm2020/lib/components/cps-table/components/internal/table-column-filter/table-column-filter.component.mjs +0 -408
  136. package/esm2020/lib/components/cps-table/components/internal/table-column-filter-constraint/table-column-filter-constraint.component.mjs +0 -148
  137. package/esm2020/lib/components/cps-table/components/internal/table-row-menu/table-row-menu.component.mjs +0 -88
  138. package/esm2020/lib/components/cps-table/cps-table.component.mjs +0 -940
  139. package/esm2020/lib/components/cps-table/directives/cps-table-column-filter.directive.mjs +0 -181
  140. package/esm2020/lib/components/cps-table/directives/internal/table-unsort.directive.mjs +0 -210
  141. package/esm2020/lib/components/cps-tag/cps-tag.component.mjs +0 -136
  142. package/esm2020/lib/components/cps-textarea/cps-textarea.component.mjs +0 -291
  143. package/esm2020/lib/components/cps-timepicker/cps-timepicker.component.mjs +0 -351
  144. package/esm2020/lib/components/cps-tree-autocomplete/cps-tree-autocomplete.component.mjs +0 -250
  145. package/esm2020/lib/components/cps-tree-select/cps-tree-select.component.mjs +0 -87
  146. package/esm2020/lib/components/cps-tree-table/cps-tree-table.component.mjs +0 -1192
  147. package/esm2020/lib/components/cps-tree-table/directives/cps-tree-table-row-toggler.directive.mjs +0 -43
  148. package/esm2020/lib/components/cps-tree-table/directives/internal/tree-table-unsort.directive.mjs +0 -334
  149. package/esm2020/lib/components/internal/cps-base-tree-dropdown/cps-base-tree-dropdown.component.mjs +0 -616
  150. package/esm2020/lib/directives/cps-tooltip.directive.mjs +0 -257
  151. package/esm2020/lib/pipes/internal/combine-labels.pipe.mjs +0 -25
  152. package/esm2020/lib/services/cps-dialog/cps-dialog.service.mjs +0 -86
  153. package/esm2020/lib/services/cps-dialog/internal/components/cps-dialog/cps-dialog.component.mjs +0 -470
  154. package/esm2020/lib/services/cps-dialog/utils/cps-dialog-config.mjs +0 -3
  155. package/esm2020/lib/services/cps-notification/cps-notification.service.mjs +0 -94
  156. package/esm2020/lib/services/cps-notification/internal/components/cps-notification-container/cps-notification-container.component.mjs +0 -91
  157. package/esm2020/lib/utils/colors-utils.mjs +0 -57
  158. package/esm2020/lib/utils/internal/size-utils.mjs +0 -24
  159. package/fesm2015/cps-ui-kit.mjs +0 -12086
  160. package/fesm2015/cps-ui-kit.mjs.map +0 -1
  161. package/fesm2020/cps-ui-kit.mjs.map +0 -1
  162. /package/{esm2020 → esm2022}/cps-ui-kit.mjs +0 -0
  163. /package/{esm2020 → esm2022}/lib/components/cps-table/cps-column-filter-types.mjs +0 -0
  164. /package/{esm2020 → esm2022}/lib/services/cps-dialog/utils/cps-dialog-ref.mjs +0 -0
  165. /package/{esm2020 → esm2022}/lib/services/cps-notification/utils/cps-notification-config.mjs +0 -0
  166. /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
- CpsDialogContentDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CpsDialogContentDirective, deps: [{ token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Directive });
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: function () { return [{ type: i0.ViewContainerRef }]; } });
18
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3BzLWRpYWxvZy1jb250ZW50LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Nwcy11aS1raXQvc3JjL2xpYi9zZXJ2aWNlcy9jcHMtZGlhbG9nL2ludGVybmFsL2RpcmVjdGl2ZXMvY3BzLWRpYWxvZy1jb250ZW50LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFvQixNQUFNLGVBQWUsQ0FBQzs7QUFNNUQsTUFBTSxPQUFPLHlCQUF5QjtJQUNwQyxrREFBa0Q7SUFDbEQsWUFBbUIsZ0JBQWtDO1FBQWxDLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBa0I7SUFBRyxDQUFDOztzSEFGOUMseUJBQXlCOzBHQUF6Qix5QkFBeUI7MkZBQXpCLHlCQUF5QjtrQkFKckMsU0FBUzttQkFBQztvQkFDVCxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsUUFBUSxFQUFFLG9CQUFvQjtpQkFDL0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIFZpZXdDb250YWluZXJSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQERpcmVjdGl2ZSh7XG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIHNlbGVjdG9yOiAnW2Nwc0RpYWxvZ0NvbnRlbnRdJ1xufSlcbmV4cG9ydCBjbGFzcyBDcHNEaWFsb2dDb250ZW50RGlyZWN0aXZlIHtcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLXVzZWxlc3MtY29uc3RydWN0b3JcbiAgY29uc3RydWN0b3IocHVibGljIHZpZXdDb250YWluZXJSZWY6IFZpZXdDb250YWluZXJSZWYpIHt9XG59XG4iXX0=
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
- CpsToastComponentfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: CpsToastComponent, deps: [{ token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
59
- CpsToastComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.9", 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: [
60
- trigger('toastState', [
61
- state('visible', style({
62
- transform: 'translateY(0)',
63
- opacity: 1
64
- })),
65
- transition('void => *', [
66
- style({ transform: 'translateY(100%)', opacity: 0 }),
67
- animate('200ms ease-out')
68
- ]),
69
- transition('* => void', [
70
- animate('200ms ease-in', style({
71
- height: 0,
72
- opacity: 0,
73
- transform: 'translateY(-100%)'
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 { thiscmp = 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: "15.2.9", ngImport: i0, type: CpsToastComponent, decorators: [{
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: function () { return [{ type: i0.NgZone }]; }, propDecorators: { config: [{
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,{"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"]}
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2Nwcy11aS1raXQvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsZ0RBQWdELENBQUM7QUFDL0QsY0FBYyxrREFBa0QsQ0FBQztBQUNqRSxjQUFjLDREQUE0RCxDQUFDO0FBQzNFLGNBQWMsOERBQThELENBQUM7QUFDN0UsY0FBYyx3RUFBd0UsQ0FBQztBQUN2RixjQUFjLDREQUE0RCxDQUFDO0FBQzNFLGNBQWMsa0RBQWtELENBQUM7QUFDakUsY0FBYyxzREFBc0QsQ0FBQztBQUNyRSxjQUFjLGdFQUFnRSxDQUFDO0FBQy9FLGNBQWMsNERBQTRELENBQUM7QUFDM0UsY0FBYyxnREFBZ0QsQ0FBQztBQUMvRCxjQUFjLDJFQUEyRSxDQUFDO0FBQzFGLGNBQWMseUVBQXlFLENBQUM7QUFDeEYsY0FBYyw2RUFBNkUsQ0FBQztBQUM1RixjQUFjLDBFQUEwRSxDQUFDO0FBQ3pGLGNBQWMsb0RBQW9ELENBQUM7QUFDbkUsY0FBYywwREFBMEQsQ0FBQztBQUN6RSxjQUFjLHFGQUFxRixDQUFDO0FBQ3BHLGNBQWMsbUZBQW1GLENBQUM7QUFDbEcsY0FBYyxpRkFBaUYsQ0FBQztBQUNoRyxjQUFjLHVGQUF1RixDQUFDO0FBQ3RHLGNBQWMsb0ZBQW9GLENBQUM7QUFDbkcsY0FBYyw0Q0FBNEMsQ0FBQztBQUMzRCxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsOENBQThDLENBQUM7QUFDN0QsY0FBYyx3REFBd0QsQ0FBQztBQUN2RSxjQUFjLHdEQUF3RCxDQUFDO0FBQ3ZFLGNBQWMsa0RBQWtELENBQUM7QUFDakUsY0FBYyxvRUFBb0UsQ0FBQztBQUNuRixjQUFjLHdFQUF3RSxDQUFDO0FBQ3ZGLGNBQWMsb0VBQW9FLENBQUM7QUFDbkYsY0FBYywwREFBMEQsQ0FBQztBQUN6RSxjQUFjLDhEQUE4RCxDQUFDO0FBQzdFLGNBQWMsc0RBQXNELENBQUM7QUFDckUsY0FBYyxnRUFBZ0UsQ0FBQztBQUMvRSxjQUFjLHdEQUF3RCxDQUFDO0FBQ3ZFLGNBQWMsMERBQTBELENBQUM7QUFDekUsY0FBYywwREFBMEQsQ0FBQztBQUN6RSxjQUFjLDREQUE0RCxDQUFDO0FBRTNFLGNBQWMsd0NBQXdDLENBQUM7QUFFdkQsY0FBYyw4Q0FBOEMsQ0FBQztBQUM3RCxjQUFjLG1EQUFtRCxDQUFDO0FBQ2xFLGNBQWMsZ0RBQWdELENBQUM7QUFFL0QsY0FBYywwREFBMEQsQ0FBQztBQUN6RSxjQUFjLCtEQUErRCxDQUFDO0FBRTlFLGNBQWMsMEJBQTBCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIGNwcy11aS1raXRcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1pY29uL2Nwcy1pY29uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1pbnB1dC9jcHMtaW5wdXQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXNlbGVjdC9jcHMtc2VsZWN0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy10cmVlLXNlbGVjdC9jcHMtdHJlZS1zZWxlY3QuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLWF1dG9jb21wbGV0ZS9jcHMtYXV0b2NvbXBsZXRlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy10cmVlLWF1dG9jb21wbGV0ZS9jcHMtdHJlZS1hdXRvY29tcGxldGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLWluZm8tY2lyY2xlL2Nwcy1pbmZvLWNpcmNsZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtYnV0dG9uL2Nwcy1idXR0b24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLWNoZWNrYm94L2Nwcy1jaGVja2JveC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtcmFkaW8tZ3JvdXAvY3BzLXJhZGlvL2Nwcy1yYWRpby5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtcmFkaW8tZ3JvdXAvY3BzLXJhZGlvLWdyb3VwLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy10YWJsZS9jcHMtdGFibGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXRhYmxlL2RpcmVjdGl2ZXMvY3BzLXRhYmxlLWNvbHVtbi1zb3J0YWJsZS5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdGFibGUvZGlyZWN0aXZlcy9jcHMtdGFibGUtY29sdW1uLWZpbHRlci5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdGFibGUvZGlyZWN0aXZlcy9jcHMtdGFibGUtaGVhZGVyLXNlbGVjdGFibGUuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXRhYmxlL2RpcmVjdGl2ZXMvY3BzLXRhYmxlLXJvdy1zZWxlY3RhYmxlLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy10YWJsZS9jcHMtY29sdW1uLWZpbHRlci10eXBlcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy10cmVlLXRhYmxlL2Nwcy10cmVlLXRhYmxlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy10cmVlLXRhYmxlL2RpcmVjdGl2ZXMvY3BzLXRyZWUtdGFibGUtY29sdW1uLXNvcnRhYmxlLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy10cmVlLXRhYmxlL2RpcmVjdGl2ZXMvY3BzLXRyZWUtdGFibGUtY29sdW1uLWZpbHRlci5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdHJlZS10YWJsZS9kaXJlY3RpdmVzL2Nwcy10cmVlLXRhYmxlLXJvdy10b2dnbGVyLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy10cmVlLXRhYmxlL2RpcmVjdGl2ZXMvY3BzLXRyZWUtdGFibGUtaGVhZGVyLXNlbGVjdGFibGUuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXRyZWUtdGFibGUvZGlyZWN0aXZlcy9jcHMtdHJlZS10YWJsZS1yb3ctc2VsZWN0YWJsZS5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdGFnL2Nwcy10YWcuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLWNoaXAvY3BzLWNoaXAuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLW1lbnUvY3BzLW1lbnUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXBhZ2luYXRvci9jcHMtcGFnaW5hdG9yLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1wYWdpbmF0b3IvcGlwZXMvY3BzLXBhZ2luYXRlLnBpcGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtbG9hZGVyL2Nwcy1sb2FkZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLWV4cGFuc2lvbi1wYW5lbC9jcHMtZXhwYW5zaW9uLXBhbmVsLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1wcm9ncmVzcy1jaXJjdWxhci9jcHMtcHJvZ3Jlc3MtY2lyY3VsYXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXByb2dyZXNzLWxpbmVhci9jcHMtcHJvZ3Jlc3MtbGluZWFyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1kYXRlcGlja2VyL2Nwcy1kYXRlcGlja2VyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1zaWRlYmFyLW1lbnUvY3BzLXNpZGViYXItbWVudS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdGV4dGFyZWEvY3BzLXRleHRhcmVhLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1idXR0b24tdG9nZ2xlL2Nwcy1idXR0b24tdG9nZ2xlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy10YWItZ3JvdXAvY3BzLXRhYi1ncm91cC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdGFiLWdyb3VwL2Nwcy10YWIvY3BzLXRhYi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdGltZXBpY2tlci9jcHMtdGltZXBpY2tlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtZmlsZS11cGxvYWQvY3BzLWZpbGUtdXBsb2FkLmNvbXBvbmVudCc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpcmVjdGl2ZXMvY3BzLXRvb2x0aXAuZGlyZWN0aXZlJztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZXMvY3BzLWRpYWxvZy9jcHMtZGlhbG9nLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZXMvY3BzLWRpYWxvZy91dGlscy9jcHMtZGlhbG9nLWNvbmZpZyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZXJ2aWNlcy9jcHMtZGlhbG9nL3V0aWxzL2Nwcy1kaWFsb2ctcmVmJztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZXMvY3BzLW5vdGlmaWNhdGlvbi9jcHMtbm90aWZpY2F0aW9uLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZXMvY3BzLW5vdGlmaWNhdGlvbi91dGlscy9jcHMtbm90aWZpY2F0aW9uLWNvbmZpZyc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL3V0aWxzL2NvbG9ycy11dGlscyc7XG4iXX0=
51
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2Nwcy11aS1raXQvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsZ0RBQWdELENBQUM7QUFDL0QsY0FBYyxrREFBa0QsQ0FBQztBQUNqRSxjQUFjLDREQUE0RCxDQUFDO0FBQzNFLGNBQWMsOERBQThELENBQUM7QUFDN0UsY0FBYyx3RUFBd0UsQ0FBQztBQUN2RixjQUFjLDREQUE0RCxDQUFDO0FBQzNFLGNBQWMsa0RBQWtELENBQUM7QUFDakUsY0FBYyxzREFBc0QsQ0FBQztBQUNyRSxjQUFjLGdFQUFnRSxDQUFDO0FBQy9FLGNBQWMsNERBQTRELENBQUM7QUFDM0UsY0FBYyxnREFBZ0QsQ0FBQztBQUMvRCxjQUFjLDJFQUEyRSxDQUFDO0FBQzFGLGNBQWMseUVBQXlFLENBQUM7QUFDeEYsY0FBYyw2RUFBNkUsQ0FBQztBQUM1RixjQUFjLDBFQUEwRSxDQUFDO0FBQ3pGLGNBQWMsb0RBQW9ELENBQUM7QUFDbkUsY0FBYywwREFBMEQsQ0FBQztBQUN6RSxjQUFjLHFGQUFxRixDQUFDO0FBQ3BHLGNBQWMsbUZBQW1GLENBQUM7QUFDbEcsY0FBYyxpRkFBaUYsQ0FBQztBQUNoRyxjQUFjLHVGQUF1RixDQUFDO0FBQ3RHLGNBQWMsb0ZBQW9GLENBQUM7QUFDbkcsY0FBYyw0Q0FBNEMsQ0FBQztBQUMzRCxjQUFjLDhDQUE4QyxDQUFDO0FBQzdELGNBQWMsOENBQThDLENBQUM7QUFDN0QsY0FBYyx3REFBd0QsQ0FBQztBQUN2RSxjQUFjLHdEQUF3RCxDQUFDO0FBQ3ZFLGNBQWMsa0RBQWtELENBQUM7QUFDakUsY0FBYyxvRUFBb0UsQ0FBQztBQUNuRixjQUFjLHdFQUF3RSxDQUFDO0FBQ3ZGLGNBQWMsb0VBQW9FLENBQUM7QUFDbkYsY0FBYywwREFBMEQsQ0FBQztBQUN6RSxjQUFjLDhEQUE4RCxDQUFDO0FBQzdFLGNBQWMsc0RBQXNELENBQUM7QUFDckUsY0FBYyxnRUFBZ0UsQ0FBQztBQUMvRSxjQUFjLHdEQUF3RCxDQUFDO0FBQ3ZFLGNBQWMsMERBQTBELENBQUM7QUFDekUsY0FBYywwREFBMEQsQ0FBQztBQUN6RSxjQUFjLDREQUE0RCxDQUFDO0FBRTNFLGNBQWMsb0RBQW9ELENBQUM7QUFFbkUsY0FBYyw4Q0FBOEMsQ0FBQztBQUM3RCxjQUFjLG1EQUFtRCxDQUFDO0FBQ2xFLGNBQWMsZ0RBQWdELENBQUM7QUFFL0QsY0FBYywwREFBMEQsQ0FBQztBQUN6RSxjQUFjLCtEQUErRCxDQUFDO0FBRTlFLGNBQWMsMEJBQTBCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIGNwcy11aS1raXRcbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1pY29uL2Nwcy1pY29uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1pbnB1dC9jcHMtaW5wdXQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXNlbGVjdC9jcHMtc2VsZWN0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy10cmVlLXNlbGVjdC9jcHMtdHJlZS1zZWxlY3QuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLWF1dG9jb21wbGV0ZS9jcHMtYXV0b2NvbXBsZXRlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy10cmVlLWF1dG9jb21wbGV0ZS9jcHMtdHJlZS1hdXRvY29tcGxldGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLWluZm8tY2lyY2xlL2Nwcy1pbmZvLWNpcmNsZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtYnV0dG9uL2Nwcy1idXR0b24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLWNoZWNrYm94L2Nwcy1jaGVja2JveC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtcmFkaW8tZ3JvdXAvY3BzLXJhZGlvL2Nwcy1yYWRpby5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtcmFkaW8tZ3JvdXAvY3BzLXJhZGlvLWdyb3VwLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy10YWJsZS9jcHMtdGFibGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXRhYmxlL2RpcmVjdGl2ZXMvY3BzLXRhYmxlLWNvbHVtbi1zb3J0YWJsZS5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdGFibGUvZGlyZWN0aXZlcy9jcHMtdGFibGUtY29sdW1uLWZpbHRlci5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdGFibGUvZGlyZWN0aXZlcy9jcHMtdGFibGUtaGVhZGVyLXNlbGVjdGFibGUuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXRhYmxlL2RpcmVjdGl2ZXMvY3BzLXRhYmxlLXJvdy1zZWxlY3RhYmxlLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy10YWJsZS9jcHMtY29sdW1uLWZpbHRlci10eXBlcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy10cmVlLXRhYmxlL2Nwcy10cmVlLXRhYmxlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy10cmVlLXRhYmxlL2RpcmVjdGl2ZXMvY3BzLXRyZWUtdGFibGUtY29sdW1uLXNvcnRhYmxlLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy10cmVlLXRhYmxlL2RpcmVjdGl2ZXMvY3BzLXRyZWUtdGFibGUtY29sdW1uLWZpbHRlci5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdHJlZS10YWJsZS9kaXJlY3RpdmVzL2Nwcy10cmVlLXRhYmxlLXJvdy10b2dnbGVyLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy10cmVlLXRhYmxlL2RpcmVjdGl2ZXMvY3BzLXRyZWUtdGFibGUtaGVhZGVyLXNlbGVjdGFibGUuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXRyZWUtdGFibGUvZGlyZWN0aXZlcy9jcHMtdHJlZS10YWJsZS1yb3ctc2VsZWN0YWJsZS5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdGFnL2Nwcy10YWcuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLWNoaXAvY3BzLWNoaXAuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLW1lbnUvY3BzLW1lbnUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXBhZ2luYXRvci9jcHMtcGFnaW5hdG9yLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1wYWdpbmF0b3IvcGlwZXMvY3BzLXBhZ2luYXRlLnBpcGUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtbG9hZGVyL2Nwcy1sb2FkZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLWV4cGFuc2lvbi1wYW5lbC9jcHMtZXhwYW5zaW9uLXBhbmVsLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1wcm9ncmVzcy1jaXJjdWxhci9jcHMtcHJvZ3Jlc3MtY2lyY3VsYXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMvY3BzLXByb2dyZXNzLWxpbmVhci9jcHMtcHJvZ3Jlc3MtbGluZWFyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1kYXRlcGlja2VyL2Nwcy1kYXRlcGlja2VyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1zaWRlYmFyLW1lbnUvY3BzLXNpZGViYXItbWVudS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdGV4dGFyZWEvY3BzLXRleHRhcmVhLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy1idXR0b24tdG9nZ2xlL2Nwcy1idXR0b24tdG9nZ2xlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jb21wb25lbnRzL2Nwcy10YWItZ3JvdXAvY3BzLXRhYi1ncm91cC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdGFiLWdyb3VwL2Nwcy10YWIvY3BzLXRhYi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtdGltZXBpY2tlci9jcHMtdGltZXBpY2tlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvY29tcG9uZW50cy9jcHMtZmlsZS11cGxvYWQvY3BzLWZpbGUtdXBsb2FkLmNvbXBvbmVudCc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL2RpcmVjdGl2ZXMvY3BzLXRvb2x0aXAvY3BzLXRvb2x0aXAuZGlyZWN0aXZlJztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZXMvY3BzLWRpYWxvZy9jcHMtZGlhbG9nLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZXMvY3BzLWRpYWxvZy91dGlscy9jcHMtZGlhbG9nLWNvbmZpZyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9zZXJ2aWNlcy9jcHMtZGlhbG9nL3V0aWxzL2Nwcy1kaWFsb2ctcmVmJztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZXMvY3BzLW5vdGlmaWNhdGlvbi9jcHMtbm90aWZpY2F0aW9uLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvc2VydmljZXMvY3BzLW5vdGlmaWNhdGlvbi91dGlscy9jcHMtbm90aWZpY2F0aW9uLWNvbmZpZyc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL3V0aWxzL2NvbG9ycy11dGlscyc7XG4iXX0=