@enigmatry/entry-components 15.2.1-preview.1 → 16.0.0-preview

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 (170) hide show
  1. package/common/directives/auto-disable-button.directive.d.ts +1 -1
  2. package/dialog/dialogs/entry-dialog.component.d.ts +1 -1
  3. package/{esm2020 → esm2022}/button/entry-button.directive.mjs +4 -4
  4. package/{esm2020 → esm2022}/button/entry-button.module.mjs +7 -7
  5. package/{esm2020 → esm2022}/common/common.module.mjs +7 -7
  6. package/{esm2020 → esm2022}/common/date-time/entry-date-time-adapter.mjs +4 -4
  7. package/{esm2020 → esm2022}/common/directives/auto-disable-button.directive.mjs +4 -4
  8. package/{esm2020 → esm2022}/common/directives/scroll-to-invalid-control.directive.mjs +4 -4
  9. package/{esm2020 → esm2022}/common/event-plugins/debounce.plugin.mjs +4 -4
  10. package/{esm2020 → esm2022}/common/event-plugins/throttle.plugin.mjs +4 -4
  11. package/{esm2020 → esm2022}/common/interceptors/accept-language.interceptor.mjs +4 -4
  12. package/{esm2020 → esm2022}/dialog/dialogs/alert/entry-alert-dialog.component.mjs +4 -4
  13. package/{esm2020 → esm2022}/dialog/dialogs/confirm/entry-confirm-dialog.component.mjs +4 -4
  14. package/{esm2020 → esm2022}/dialog/dialogs/entry-dialog.component.mjs +4 -4
  15. package/{esm2020 → esm2022}/dialog/dialogs/error/entry-error-dialog.component.mjs +4 -4
  16. package/{esm2020 → esm2022}/dialog/entry-dialog.module.mjs +19 -19
  17. package/esm2022/dialog/entry-dialog.service.mjs +86 -0
  18. package/esm2022/file-input/entry-file-input.component.mjs +201 -0
  19. package/{esm2020 → esm2022}/file-input/entry-file-input.module.mjs +13 -13
  20. package/{esm2020 → esm2022}/modules/entry-components.module.mjs +21 -21
  21. package/{esm2020 → esm2022}/permissions/permission.directive.mjs +4 -4
  22. package/{esm2020 → esm2022}/permissions/permission.module.mjs +7 -7
  23. package/{esm2020 → esm2022}/permissions/permission.pipe.mjs +4 -4
  24. package/{esm2020 → esm2022}/search-filter/autocomplete/autocomplete-search-filter.component.mjs +4 -4
  25. package/esm2022/search-filter/date/date-search-filter.component.mjs +19 -0
  26. package/{esm2020 → esm2022}/search-filter/date-time/date-time-search-filter.component.mjs +7 -7
  27. package/{esm2020 → esm2022}/search-filter/entry-search-filter.component.mjs +4 -4
  28. package/{esm2020 → esm2022}/search-filter/entry-search-filter.module.mjs +28 -28
  29. package/{esm2020 → esm2022}/search-filter/select/select-search-filter.component.mjs +4 -4
  30. package/{esm2020 → esm2022}/search-filter/text/text-search-filter.component.mjs +4 -4
  31. package/{esm2020 → esm2022}/spinner/entry-spinner/spinner.component.mjs +10 -10
  32. package/{esm2020 → esm2022}/spinner/spinner-overlay-container.mjs +4 -4
  33. package/{esm2020 → esm2022}/spinner/spinner.module.mjs +9 -9
  34. package/{esm2020 → esm2022}/table/components/entry-cell/entry-cell.component.mjs +4 -4
  35. package/esm2022/table/components/entry-cell-context-menu/entry-cell-context-menu.component.mjs +33 -0
  36. package/{esm2020 → esm2022}/table/components/entry-cell-formatted-value/entry-cell-formatted-value.component.mjs +4 -4
  37. package/esm2022/table/components/entry-table/entry-table.component.mjs +248 -0
  38. package/{esm2020 → esm2022}/table/entry-table.module.mjs +33 -33
  39. package/{esm2020 → esm2022}/table/interfaces/entry-table-config.mjs +1 -2
  40. package/{esm2020 → esm2022}/validation/entry-display-control-validation.directive.mjs +4 -4
  41. package/{esm2020 → esm2022}/validation/entry-form-errors.component.mjs +6 -6
  42. package/{esm2020 → esm2022}/validation/entry-validation.module.mjs +13 -13
  43. package/{fesm2020 → fesm2022}/enigmatry-entry-components-button.mjs +9 -9
  44. package/{fesm2020 → fesm2022}/enigmatry-entry-components-button.mjs.map +1 -1
  45. package/{fesm2020 → fesm2022}/enigmatry-entry-components-common.mjs +24 -24
  46. package/{fesm2015 → fesm2022}/enigmatry-entry-components-common.mjs.map +1 -1
  47. package/{fesm2020 → fesm2022}/enigmatry-entry-components-dialog.mjs +33 -33
  48. package/{fesm2020 → fesm2022}/enigmatry-entry-components-dialog.mjs.map +1 -1
  49. package/{fesm2020 → fesm2022}/enigmatry-entry-components-file-input.mjs +21 -17
  50. package/fesm2022/enigmatry-entry-components-file-input.mjs.map +1 -0
  51. package/{fesm2020 → fesm2022}/enigmatry-entry-components-permissions.mjs +12 -12
  52. package/{fesm2020 → fesm2022}/enigmatry-entry-components-permissions.mjs.map +1 -1
  53. package/fesm2022/enigmatry-entry-components-search-filter.mjs +387 -0
  54. package/{fesm2020 → fesm2022}/enigmatry-entry-components-search-filter.mjs.map +1 -1
  55. package/{fesm2020 → fesm2022}/enigmatry-entry-components-spinner.mjs +20 -20
  56. package/{fesm2020 → fesm2022}/enigmatry-entry-components-spinner.mjs.map +1 -1
  57. package/{fesm2020 → fesm2022}/enigmatry-entry-components-table.mjs +45 -46
  58. package/fesm2022/enigmatry-entry-components-table.mjs.map +1 -0
  59. package/{fesm2020 → fesm2022}/enigmatry-entry-components-validation.mjs +20 -20
  60. package/{fesm2020 → fesm2022}/enigmatry-entry-components-validation.mjs.map +1 -1
  61. package/{fesm2020 → fesm2022}/enigmatry-entry-components.mjs +20 -20
  62. package/{fesm2020 → fesm2022}/enigmatry-entry-components.mjs.map +1 -1
  63. package/file-input/entry-file-input.component.d.ts +1 -1
  64. package/package.json +39 -63
  65. package/permissions/permission.directive.d.ts +1 -1
  66. package/search-filter/autocomplete/autocomplete-search-filter.component.d.ts +1 -1
  67. package/search-filter/date/date-search-filter.component.d.ts +1 -1
  68. package/search-filter/date-time/date-time-search-filter.component.d.ts +1 -1
  69. package/search-filter/entry-search-filter.component.d.ts +1 -1
  70. package/search-filter/select/select-search-filter.component.d.ts +1 -1
  71. package/search-filter/text/text-search-filter.component.d.ts +1 -1
  72. package/spinner/entry-spinner/spinner.component.d.ts +1 -1
  73. package/table/components/entry-cell/entry-cell.component.d.ts +1 -1
  74. package/table/components/entry-cell-context-menu/entry-cell-context-menu.component.d.ts +1 -1
  75. package/table/components/entry-cell-formatted-value/entry-cell-formatted-value.component.d.ts +1 -1
  76. package/table/components/entry-table/entry-table.component.d.ts +1 -1
  77. package/validation/entry-display-control-validation.directive.d.ts +1 -1
  78. package/validation/entry-form-errors.component.d.ts +1 -1
  79. package/esm2020/dialog/entry-dialog.service.mjs +0 -86
  80. package/esm2020/file-input/entry-file-input.component.mjs +0 -197
  81. package/esm2020/search-filter/date/date-search-filter.component.mjs +0 -19
  82. package/esm2020/table/components/entry-cell-context-menu/entry-cell-context-menu.component.mjs +0 -33
  83. package/esm2020/table/components/entry-table/entry-table.component.mjs +0 -248
  84. package/fesm2015/enigmatry-entry-components-button.mjs +0 -114
  85. package/fesm2015/enigmatry-entry-components-button.mjs.map +0 -1
  86. package/fesm2015/enigmatry-entry-components-common.mjs +0 -405
  87. package/fesm2015/enigmatry-entry-components-dialog.mjs +0 -333
  88. package/fesm2015/enigmatry-entry-components-dialog.mjs.map +0 -1
  89. package/fesm2015/enigmatry-entry-components-file-input.mjs +0 -237
  90. package/fesm2015/enigmatry-entry-components-file-input.mjs.map +0 -1
  91. package/fesm2015/enigmatry-entry-components-permissions.mjs +0 -98
  92. package/fesm2015/enigmatry-entry-components-permissions.mjs.map +0 -1
  93. package/fesm2015/enigmatry-entry-components-search-filter.mjs +0 -394
  94. package/fesm2015/enigmatry-entry-components-search-filter.mjs.map +0 -1
  95. package/fesm2015/enigmatry-entry-components-spinner.mjs +0 -156
  96. package/fesm2015/enigmatry-entry-components-spinner.mjs.map +0 -1
  97. package/fesm2015/enigmatry-entry-components-table.mjs +0 -462
  98. package/fesm2015/enigmatry-entry-components-table.mjs.map +0 -1
  99. package/fesm2015/enigmatry-entry-components-validation.mjs +0 -219
  100. package/fesm2015/enigmatry-entry-components-validation.mjs.map +0 -1
  101. package/fesm2015/enigmatry-entry-components.mjs +0 -87
  102. package/fesm2015/enigmatry-entry-components.mjs.map +0 -1
  103. package/fesm2020/enigmatry-entry-components-common.mjs.map +0 -1
  104. package/fesm2020/enigmatry-entry-components-file-input.mjs.map +0 -1
  105. package/fesm2020/enigmatry-entry-components-search-filter.mjs +0 -387
  106. package/fesm2020/enigmatry-entry-components-table.mjs.map +0 -1
  107. /package/{esm2020 → esm2022}/button/enigmatry-entry-components-button.mjs +0 -0
  108. /package/{esm2020 → esm2022}/button/entry-button-config.mjs +0 -0
  109. /package/{esm2020 → esm2022}/button/public-api.mjs +0 -0
  110. /package/{esm2020 → esm2022}/common/constants.mjs +0 -0
  111. /package/{esm2020 → esm2022}/common/date-time/entry-date-time.mjs +0 -0
  112. /package/{esm2020 → esm2022}/common/date-time/index.mjs +0 -0
  113. /package/{esm2020 → esm2022}/common/directives/index.mjs +0 -0
  114. /package/{esm2020 → esm2022}/common/enigmatry-entry-components-common.mjs +0 -0
  115. /package/{esm2020 → esm2022}/common/event-plugins/abstract.plugin.mjs +0 -0
  116. /package/{esm2020 → esm2022}/common/event-plugins/index.mjs +0 -0
  117. /package/{esm2020 → esm2022}/common/interceptors/index.mjs +0 -0
  118. /package/{esm2020 → esm2022}/common/public-api.mjs +0 -0
  119. /package/{esm2020 → esm2022}/common/utils/index.mjs +0 -0
  120. /package/{esm2020 → esm2022}/common/utils/provide-config.mjs +0 -0
  121. /package/{esm2020 → esm2022}/dialog/dialogs/alert/entry-alert-dialog-data.interface.mjs +0 -0
  122. /package/{esm2020 → esm2022}/dialog/dialogs/confirm/entry-confirm-dialog-data.interface.mjs +0 -0
  123. /package/{esm2020 → esm2022}/dialog/dialogs/error/entry-error-dialog-data.interface.mjs +0 -0
  124. /package/{esm2020 → esm2022}/dialog/enigmatry-entry-components-dialog.mjs +0 -0
  125. /package/{esm2020 → esm2022}/dialog/entry-dialog-buttons-alignment.type.mjs +0 -0
  126. /package/{esm2020 → esm2022}/dialog/entry-dialog-config.model.mjs +0 -0
  127. /package/{esm2020 → esm2022}/dialog/public-api.mjs +0 -0
  128. /package/{esm2020 → esm2022}/enigmatry-entry-components.mjs +0 -0
  129. /package/{esm2020 → esm2022}/file-input/enigmatry-entry-components-file-input.mjs +0 -0
  130. /package/{esm2020 → esm2022}/file-input/public-api.mjs +0 -0
  131. /package/{esm2020 → esm2022}/permissions/enigmatry-entry-components-permissions.mjs +0 -0
  132. /package/{esm2020 → esm2022}/permissions/permission-type.mjs +0 -0
  133. /package/{esm2020 → esm2022}/permissions/permission.guard.mjs +0 -0
  134. /package/{esm2020 → esm2022}/permissions/permission.service.mjs +0 -0
  135. /package/{esm2020 → esm2022}/permissions/public-api.mjs +0 -0
  136. /package/{esm2020 → esm2022}/public-api.mjs +0 -0
  137. /package/{esm2020 → esm2022}/search-filter/autocomplete/autocomplete-search-filter.model.mjs +0 -0
  138. /package/{esm2020 → esm2022}/search-filter/control-type.mjs +0 -0
  139. /package/{esm2020 → esm2022}/search-filter/date/date-search-filter.model.mjs +0 -0
  140. /package/{esm2020 → esm2022}/search-filter/date-time/date-time-search-filter.model.mjs +0 -0
  141. /package/{esm2020 → esm2022}/search-filter/enigmatry-entry-components-search-filter.mjs +0 -0
  142. /package/{esm2020 → esm2022}/search-filter/public-api.mjs +0 -0
  143. /package/{esm2020 → esm2022}/search-filter/search-filter-base.model.mjs +0 -0
  144. /package/{esm2020 → esm2022}/search-filter/search-filter-config.model.mjs +0 -0
  145. /package/{esm2020 → esm2022}/search-filter/search-filter-params.type.mjs +0 -0
  146. /package/{esm2020 → esm2022}/search-filter/select/select-search-filter.model.mjs +0 -0
  147. /package/{esm2020 → esm2022}/search-filter/select-option.model.mjs +0 -0
  148. /package/{esm2020 → esm2022}/search-filter/text/text-search-filter.model.mjs +0 -0
  149. /package/{esm2020 → esm2022}/spinner/enigmatry-entry-components-spinner.mjs +0 -0
  150. /package/{esm2020 → esm2022}/spinner/public-api.mjs +0 -0
  151. /package/{esm2020 → esm2022}/table/components/index.mjs +0 -0
  152. /package/{esm2020 → esm2022}/table/enigmatry-entry-components-table.mjs +0 -0
  153. /package/{esm2020 → esm2022}/table/interfaces/cell-template.mjs +0 -0
  154. /package/{esm2020 → esm2022}/table/interfaces/column-def.mjs +0 -0
  155. /package/{esm2020 → esm2022}/table/interfaces/column-sort-prop.mjs +0 -0
  156. /package/{esm2020 → esm2022}/table/interfaces/column-type-parameter.mjs +0 -0
  157. /package/{esm2020 → esm2022}/table/interfaces/column-type.mjs +0 -0
  158. /package/{esm2020 → esm2022}/table/interfaces/context-menu-item.mjs +0 -0
  159. /package/{esm2020 → esm2022}/table/interfaces/index.mjs +0 -0
  160. /package/{esm2020 → esm2022}/table/interfaces/paged-query.mjs +0 -0
  161. /package/{esm2020 → esm2022}/table/interfaces/pagination.mjs +0 -0
  162. /package/{esm2020 → esm2022}/table/interfaces/row-class-formatter.mjs +0 -0
  163. /package/{esm2020 → esm2022}/table/interfaces/row-context-menu-formatter.mjs +0 -0
  164. /package/{esm2020 → esm2022}/table/interfaces/row-selection-formatter.mjs +0 -0
  165. /package/{esm2020 → esm2022}/table/public-api.mjs +0 -0
  166. /package/{esm2020 → esm2022}/validation/enigmatry-entry-components-validation.mjs +0 -0
  167. /package/{esm2020 → esm2022}/validation/entry-validation-config.model.mjs +0 -0
  168. /package/{esm2020 → esm2022}/validation/entry-validation.mjs +0 -0
  169. /package/{esm2020 → esm2022}/validation/public-api.mjs +0 -0
  170. /package/{esm2020 → esm2022}/validation/validation-problem-details.interface.mjs +0 -0
@@ -6,5 +6,5 @@ export declare class EntryCellFormattedValueComponent {
6
6
  typeParameter: any | undefined;
7
7
  constructor(defaultPercentageMultiplier: number);
8
8
  static ɵfac: i0.ɵɵFactoryDeclaration<EntryCellFormattedValueComponent, never>;
9
- static ɵcmp: i0.ɵɵComponentDeclaration<EntryCellFormattedValueComponent, "entry-cell-formatted-value", never, { "value": "value"; "type": "type"; "typeParameter": "typeParameter"; }, {}, never, never, false, never>;
9
+ static ɵcmp: i0.ɵɵComponentDeclaration<EntryCellFormattedValueComponent, "entry-cell-formatted-value", never, { "value": { "alias": "value"; "required": false; }; "type": { "alias": "type"; "required": false; }; "typeParameter": { "alias": "typeParameter"; "required": false; }; }, {}, never, never, false, never>;
10
10
  }
@@ -77,5 +77,5 @@ export declare class EntryTableComponent<T> implements OnChanges {
77
77
  scrollToTop(): void;
78
78
  private convertToKebabCase;
79
79
  static ɵfac: i0.ɵɵFactoryDeclaration<EntryTableComponent<any>, never>;
80
- static ɵcmp: i0.ɵɵComponentDeclaration<EntryTableComponent<any>, "entry-table", never, { "displayedColumns": "displayedColumns"; "columns": "columns"; "data": "data"; "total": "total"; "loading": "loading"; "showPaginator": "showPaginator"; "pageDisabled": "pageDisabled"; "showFirstLastButtons": "showFirstLastButtons"; "pageIndex": "pageIndex"; "pageSize": "pageSize"; "pageSizeOptions": "pageSizeOptions"; "hidePageSize": "hidePageSize"; "paginationTemplate": "paginationTemplate"; "sortActive": "sortActive"; "sortDirection": "sortDirection"; "sortDisableClear": "sortDisableClear"; "sortDisabled": "sortDisabled"; "sortStart": "sortStart"; "rowHover": "rowHover"; "rowStriped": "rowStriped"; "rowFocusVisible": "rowFocusVisible"; "multiSelectable": "multiSelectable"; "rowSelected": "rowSelected"; "rowSelectable": "rowSelectable"; "showSelectAllCheckbox": "showSelectAllCheckbox"; "rowSelectionFormatter": "rowSelectionFormatter"; "rowClassFormatter": "rowClassFormatter"; "showContextMenu": "showContextMenu"; "contextMenuItems": "contextMenuItems"; "contextMenuTemplate": "contextMenuTemplate"; "rowContextMenuFormatter": "rowContextMenuFormatter"; "noResultText": "noResultText"; "noResultTemplate": "noResultTemplate"; "headerTemplate": "headerTemplate"; "cellTemplate": "cellTemplate"; }, { "pageChange": "pageChange"; "sortChange": "sortChange"; "rowClick": "rowClick"; "rowSelectionChange": "rowSelectionChange"; "contextMenuItemSelected": "contextMenuItemSelected"; }, never, never, false, never>;
80
+ static ɵcmp: i0.ɵɵComponentDeclaration<EntryTableComponent<any>, "entry-table", never, { "displayedColumns": { "alias": "displayedColumns"; "required": false; }; "columns": { "alias": "columns"; "required": false; }; "data": { "alias": "data"; "required": false; }; "total": { "alias": "total"; "required": false; }; "loading": { "alias": "loading"; "required": false; }; "showPaginator": { "alias": "showPaginator"; "required": false; }; "pageDisabled": { "alias": "pageDisabled"; "required": false; }; "showFirstLastButtons": { "alias": "showFirstLastButtons"; "required": false; }; "pageIndex": { "alias": "pageIndex"; "required": false; }; "pageSize": { "alias": "pageSize"; "required": false; }; "pageSizeOptions": { "alias": "pageSizeOptions"; "required": false; }; "hidePageSize": { "alias": "hidePageSize"; "required": false; }; "paginationTemplate": { "alias": "paginationTemplate"; "required": false; }; "sortActive": { "alias": "sortActive"; "required": false; }; "sortDirection": { "alias": "sortDirection"; "required": false; }; "sortDisableClear": { "alias": "sortDisableClear"; "required": false; }; "sortDisabled": { "alias": "sortDisabled"; "required": false; }; "sortStart": { "alias": "sortStart"; "required": false; }; "rowHover": { "alias": "rowHover"; "required": false; }; "rowStriped": { "alias": "rowStriped"; "required": false; }; "rowFocusVisible": { "alias": "rowFocusVisible"; "required": false; }; "multiSelectable": { "alias": "multiSelectable"; "required": false; }; "rowSelected": { "alias": "rowSelected"; "required": false; }; "rowSelectable": { "alias": "rowSelectable"; "required": false; }; "showSelectAllCheckbox": { "alias": "showSelectAllCheckbox"; "required": false; }; "rowSelectionFormatter": { "alias": "rowSelectionFormatter"; "required": false; }; "rowClassFormatter": { "alias": "rowClassFormatter"; "required": false; }; "showContextMenu": { "alias": "showContextMenu"; "required": false; }; "contextMenuItems": { "alias": "contextMenuItems"; "required": false; }; "contextMenuTemplate": { "alias": "contextMenuTemplate"; "required": false; }; "rowContextMenuFormatter": { "alias": "rowContextMenuFormatter"; "required": false; }; "noResultText": { "alias": "noResultText"; "required": false; }; "noResultTemplate": { "alias": "noResultTemplate"; "required": false; }; "headerTemplate": { "alias": "headerTemplate"; "required": false; }; "cellTemplate": { "alias": "cellTemplate"; "required": false; }; }, { "pageChange": "pageChange"; "sortChange": "sortChange"; "rowClick": "rowClick"; "rowSelectionChange": "rowSelectionChange"; "contextMenuItemSelected": "contextMenuItemSelected"; }, never, never, false, never>;
81
81
  }
@@ -23,5 +23,5 @@ export declare class EntryDisplayControlValidationDirective implements OnInit, O
23
23
  ngOnDestroy(): void;
24
24
  private extractValidationMessages;
25
25
  static ɵfac: i0.ɵɵFactoryDeclaration<EntryDisplayControlValidationDirective, never>;
26
- static ɵdir: i0.ɵɵDirectiveDeclaration<EntryDisplayControlValidationDirective, "[entryDisplayControlValidation]", never, { "control": "control"; }, {}, never, never, false, never>;
26
+ static ɵdir: i0.ɵɵDirectiveDeclaration<EntryDisplayControlValidationDirective, "[entryDisplayControlValidation]", never, { "control": { "alias": "control"; "required": false; }; }, {}, never, never, false, never>;
27
27
  }
@@ -14,5 +14,5 @@ export declare class EntryFormErrorsComponent {
14
14
  /** A form group for which the validation errors are being displayed. */
15
15
  form: UntypedFormGroup;
16
16
  static ɵfac: i0.ɵɵFactoryDeclaration<EntryFormErrorsComponent, never>;
17
- static ɵcmp: i0.ɵɵComponentDeclaration<EntryFormErrorsComponent, "entry-form-errors", never, { "form": "form"; }, {}, never, never, false, never>;
17
+ static ɵcmp: i0.ɵɵComponentDeclaration<EntryFormErrorsComponent, "entry-form-errors", never, { "form": { "alias": "form"; "required": false; }; }, {}, never, never, false, never>;
18
18
  }
@@ -1,86 +0,0 @@
1
- import { Inject, Injectable } from '@angular/core';
2
- import { MatDialogConfig } from '@angular/material/dialog';
3
- import { take } from 'rxjs/operators';
4
- import { EntryAlertDialogComponent } from './dialogs/alert/entry-alert-dialog.component';
5
- import { EntryConfirmDialogComponent } from './dialogs/confirm/entry-confirm-dialog.component';
6
- import { ENTRY_DIALOG_CONFIG } from './entry-dialog-config.model';
7
- import { EntryErrorDialogComponent } from './dialogs/error/entry-error-dialog.component';
8
- import * as i0 from "@angular/core";
9
- import * as i1 from "@angular/material/dialog";
10
- import * as i2 from "./entry-dialog-config.model";
11
- /**
12
- * Used to open built-in and custom entry dialogs.
13
- */
14
- export class EntryDialogService {
15
- constructor(config, matDialog) {
16
- this.config = config;
17
- this.matDialog = matDialog;
18
- /**
19
- * Opens alert dialog.
20
- *
21
- * @param data - Contains title, message and optional confirm button text
22
- * @returns `true` if confirmed, `undefined` if closed by clicking on backdrop or pressing escape
23
- */
24
- this.openAlert = (data) => {
25
- data.disableClose = data.disableClose === undefined ? this.config.disableClose : data.disableClose;
26
- return this.open(EntryAlertDialogComponent, data, data.disableClose);
27
- };
28
- /**
29
- * Opens confirm dialog.
30
- *
31
- * @param data - Contains title, message and optional confirm/cancel buttons text
32
- * @returns `true` if confirmed, `false` if canceled or closed, `undefined` if closed by clicking on backdrop or pressing escape
33
- */
34
- this.openConfirm = (data) => {
35
- data.disableClose = data.disableClose === undefined ? this.config.disableClose : data.disableClose;
36
- return this.open(EntryConfirmDialogComponent, data, data.disableClose);
37
- };
38
- /**
39
- * Opens error dialog.
40
- *
41
- * @param data - Contains title, errors and optional confirm button text
42
- * @returns `true` if confirmed, `undefined` if closed by clicking on backdrop or pressing escape
43
- */
44
- this.openError = (data) => {
45
- data.disableClose = data.disableClose === undefined ? this.config.disableClose : data.disableClose;
46
- return this.open(EntryErrorDialogComponent, data, data.disableClose);
47
- };
48
- /**
49
- * Opens dialog with custom component.
50
- *
51
- * @param component - Dialog custom component implementation
52
- * @param data - Optional parameter used to supply component with input parameters
53
- * @param disableClose - Optional parameter that disable closing dialog when pressing escape or clicking on backdrop
54
- * @param cssClass - Optional parameter used to set custom class to Material overlay pane
55
- * @returns Any result custom implementation provides
56
- */
57
- this.open = (component, data = undefined, disableClose = undefined, cssClass = '') => {
58
- const configuration = new MatDialogConfig();
59
- configuration.data = data;
60
- configuration.disableClose = disableClose === undefined
61
- ? this.config.disableClose
62
- : disableClose;
63
- this.setPanelClassFor(configuration, cssClass);
64
- return this.matDialog
65
- .open(component, configuration)
66
- .afterClosed()
67
- .pipe(take(1));
68
- };
69
- /**
70
- * Closes all opened dialogs.
71
- */
72
- this.closeAll = () => this.matDialog.closeAll();
73
- this.setPanelClassFor = (configuration, cssClass) => {
74
- configuration.panelClass = ['dialog-container', cssClass];
75
- };
76
- }
77
- }
78
- EntryDialogService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: EntryDialogService, deps: [{ token: ENTRY_DIALOG_CONFIG }, { token: i1.MatDialog }], target: i0.ɵɵFactoryTarget.Injectable });
79
- EntryDialogService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: EntryDialogService });
80
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: EntryDialogService, decorators: [{
81
- type: Injectable
82
- }], ctorParameters: function () { return [{ type: i2.EntryDialogConfig, decorators: [{
83
- type: Inject,
84
- args: [ENTRY_DIALOG_CONFIG]
85
- }] }, { type: i1.MatDialog }]; } });
86
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entry-dialog.service.js","sourceRoot":"","sources":["../../../../../libs/entry-components/dialog/entry-dialog.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,UAAU,EAAQ,MAAM,eAAe,CAAC;AACzD,OAAO,EAAa,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAEtE,OAAO,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AAEtC,OAAO,EAAE,yBAAyB,EAAE,MAAM,8CAA8C,CAAC;AAEzF,OAAO,EAAE,2BAA2B,EAAE,MAAM,kDAAkD,CAAC;AAE/F,OAAO,EAAE,mBAAmB,EAAqB,MAAM,6BAA6B,CAAC;AAErF,OAAO,EAAE,yBAAyB,EAAE,MAAM,8CAA8C,CAAC;;;;AAEzF;;GAEG;AAEH,MAAM,OAAO,kBAAkB;IAC7B,YACkD,MAAyB,EACxD,SAAoB;QADW,WAAM,GAAN,MAAM,CAAmB;QACxD,cAAS,GAAT,SAAS,CAAW;QAEvC;;;;;WAKG;QACH,cAAS,GAAG,CAAC,IAAoC,EAAgC,EAAE;YACjF,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,KAAK,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC;YACnG,OAAO,IAAI,CAAC,IAAI,CAAC,yBAAyB,EAAE,IAAI,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;QACvE,CAAC,CAAC;QAEF;;;;;WAKG;QACH,gBAAW,GAAG,CAAC,IAAsC,EAAmC,EAAE;YACxF,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,KAAK,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC;YACnG,OAAO,IAAI,CAAC,IAAI,CAAC,2BAA2B,EAAE,IAAI,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;QACzE,CAAC,CAAC;QAEF;;;;;WAKG;QACH,cAAS,GAAG,CAAC,IAAoC,EAAgC,EAAE;YACjF,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,KAAK,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC;YACnG,OAAO,IAAI,CAAC,IAAI,CAAC,yBAAyB,EAAE,IAAI,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;QACvE,CAAC,CAAC;QAEF;;;;;;;;WAQG;QACH,SAAI,GAAG,CACL,SAAqC,EACrC,OAAgB,SAAS,EACzB,eAAoC,SAAS,EAC7C,WAAmB,EAAE,EAAmB,EAAE;YAC1C,MAAM,aAAa,GAAG,IAAI,eAAe,EAAW,CAAC;YACrD,aAAa,CAAC,IAAI,GAAG,IAAI,CAAC;YAC1B,aAAa,CAAC,YAAY,GAAG,YAAY,KAAK,SAAS;gBACrD,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,YAAY;gBAC1B,CAAC,CAAC,YAAY,CAAC;YACjB,IAAI,CAAC,gBAAgB,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAC;YAE/C,OAAO,IAAI,CAAC,SAAS;iBAClB,IAAI,CAAC,SAAS,EAAE,aAAa,CAAC;iBAC9B,WAAW,EAAE;iBACb,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QACnB,CAAC,CAAC;QAEF;;WAEG;QACH,aAAQ,GAAG,GAAS,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;QAEzC,qBAAgB,GAAG,CAAI,aAAiC,EAAE,QAAgB,EAAE,EAAE;YACpF,aAAa,CAAC,UAAU,GAAG,CAAC,kBAAkB,EAAE,QAAQ,CAAC,CAAC;QAC5D,CAAC,CAAC;IArEyC,CAAC;;gHAHjC,kBAAkB,kBAEnB,mBAAmB;oHAFlB,kBAAkB;4FAAlB,kBAAkB;kBAD9B,UAAU;;0BAGN,MAAM;2BAAC,mBAAmB","sourcesContent":["import { Inject, Injectable, Type } from '@angular/core';\nimport { MatDialog, MatDialogConfig } from '@angular/material/dialog';\nimport { EntryDialogComponent } from './dialogs/entry-dialog.component';\nimport { take } from 'rxjs/operators';\nimport { IEntryAlertDialogData } from './dialogs/alert/entry-alert-dialog-data.interface';\nimport { EntryAlertDialogComponent } from './dialogs/alert/entry-alert-dialog.component';\nimport { Observable } from 'rxjs';\nimport { EntryConfirmDialogComponent } from './dialogs/confirm/entry-confirm-dialog.component';\nimport { IEntryConfirmDialogData } from './dialogs/confirm/entry-confirm-dialog-data.interface';\nimport { ENTRY_DIALOG_CONFIG, EntryDialogConfig } from './entry-dialog-config.model';\nimport { IEntryErrorDialogData } from './dialogs/error/entry-error-dialog-data.interface';\nimport { EntryErrorDialogComponent } from './dialogs/error/entry-error-dialog.component';\n\n/**\n * Used to open built-in and custom entry dialogs.\n */\n@Injectable()\nexport class EntryDialogService {\n  constructor(\n    @Inject(ENTRY_DIALOG_CONFIG) protected readonly config: EntryDialogConfig,\n    private readonly matDialog: MatDialog) { }\n\n  /**\n   * Opens alert dialog.\n   *\n   * @param data - Contains title, message and optional confirm button text\n   * @returns `true` if confirmed, `undefined` if closed by clicking on backdrop or pressing escape\n   */\n  openAlert = (data: Partial<IEntryAlertDialogData>): Observable<true | undefined> => {\n    data.disableClose = data.disableClose === undefined ? this.config.disableClose : data.disableClose;\n    return this.open(EntryAlertDialogComponent, data, data.disableClose);\n  };\n\n  /**\n   * Opens confirm dialog.\n   *\n   * @param data - Contains title, message and optional confirm/cancel buttons text\n   * @returns `true` if confirmed, `false` if canceled or closed, `undefined` if closed by clicking on backdrop or pressing escape\n   */\n  openConfirm = (data: Partial<IEntryConfirmDialogData>): Observable<boolean | undefined> => {\n    data.disableClose = data.disableClose === undefined ? this.config.disableClose : data.disableClose;\n    return this.open(EntryConfirmDialogComponent, data, data.disableClose);\n  };\n\n  /**\n   * Opens error dialog.\n   *\n   * @param data - Contains title, errors and optional confirm button text\n   * @returns `true` if confirmed, `undefined` if closed by clicking on backdrop or pressing escape\n   */\n  openError = (data: Partial<IEntryErrorDialogData>): Observable<true | undefined> => {\n    data.disableClose = data.disableClose === undefined ? this.config.disableClose : data.disableClose;\n    return this.open(EntryErrorDialogComponent, data, data.disableClose);\n  };\n\n  /**\n   * Opens dialog with custom component.\n   *\n   * @param component - Dialog custom component implementation\n   * @param data - Optional parameter used to supply component with input parameters\n   * @param disableClose - Optional parameter that disable closing dialog when pressing escape or clicking on backdrop\n   * @param cssClass - Optional parameter used to set custom class to Material overlay pane\n   * @returns Any result custom implementation provides\n   */\n  open = (\n    component: Type<EntryDialogComponent>,\n    data: unknown = undefined,\n    disableClose: boolean | undefined = undefined,\n    cssClass: string = ''): Observable<any> => {\n    const configuration = new MatDialogConfig<unknown>();\n    configuration.data = data;\n    configuration.disableClose = disableClose === undefined\n      ? this.config.disableClose\n      : disableClose;\n    this.setPanelClassFor(configuration, cssClass);\n\n    return this.matDialog\n      .open(component, configuration)\n      .afterClosed()\n      .pipe(take(1));\n  };\n\n  /**\n   * Closes all opened dialogs.\n   */\n  closeAll = (): void => this.matDialog.closeAll();\n\n  private setPanelClassFor = <T>(configuration: MatDialogConfig<T>, cssClass: string) => {\n    configuration.panelClass = ['dialog-container', cssClass];\n  };\n}\n"]}
@@ -1,197 +0,0 @@
1
- /* eslint-disable @typescript-eslint/member-ordering */
2
- import { coerceBooleanProperty } from '@angular/cdk/coercion';
3
- import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, Input, Output, ViewChild, forwardRef } from '@angular/core';
4
- import { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms';
5
- import { Subject, fromEvent } from 'rxjs';
6
- import { takeUntil } from 'rxjs/operators';
7
- import * as i0 from "@angular/core";
8
- import * as i1 from "@angular/common";
9
- import * as i2 from "@angular/material/icon";
10
- import * as i3 from "@angular/material/button";
11
- import * as i4 from "@enigmatry/entry-components/button";
12
- const providers = [
13
- {
14
- provide: NG_VALUE_ACCESSOR,
15
- useExisting: forwardRef(() => EntryFileInputComponent),
16
- multi: true
17
- },
18
- {
19
- provide: NG_VALIDATORS,
20
- useExisting: forwardRef(() => EntryFileInputComponent),
21
- multi: true
22
- }
23
- ];
24
- export class EntryFileInputComponent {
25
- /**
26
- * Same as 'multiple' attribute in <input/> element.
27
- */
28
- set multiple(multiple) {
29
- this._multiple = coerceBooleanProperty(multiple);
30
- }
31
- get multiple() {
32
- return this._multiple;
33
- }
34
- /**
35
- * Same as 'disabled' attribute in <input/> element.
36
- */
37
- set disabled(disabled) {
38
- this._disabled = coerceBooleanProperty(disabled);
39
- }
40
- get disabled() {
41
- return this._disabled;
42
- }
43
- /**
44
- * Same as 'readonly' attribute in <input/> element.
45
- */
46
- set readonly(readonly) {
47
- this._readonly = coerceBooleanProperty(readonly);
48
- }
49
- get readonly() {
50
- return this._readonly;
51
- }
52
- constructor(_ngZone, _renderer) {
53
- this._ngZone = _ngZone;
54
- this._renderer = _renderer;
55
- /**
56
- * Label for the select file button. Defaults to 'Choose file...'
57
- */
58
- this.label = 'Choose file...';
59
- /**
60
- * MatIcon for the select file button. Defaults to 'insert_drive_file' (optional)
61
- */
62
- this.matIcon = 'insert_drive_file';
63
- this._multiple = false;
64
- this._disabled = false;
65
- this._readonly = false;
66
- /**
67
- * Size limit per file in KB (kilobytes)
68
- */
69
- this.maxFileSizeInKb = undefined;
70
- /**
71
- * Number of files allowed when multiple=true
72
- */
73
- this.maxFileCount = undefined;
74
- /**
75
- * Event emitted when a file is selected. Emits a [File | FileList] object.
76
- */
77
- this.selectedFile = new EventEmitter();
78
- this._destroy$ = new Subject();
79
- // implements ControlValueAccessor interface
80
- this.onChange = (_) => { };
81
- this.onTouched = () => { };
82
- }
83
- get fileNames() {
84
- if (this.value instanceof File) {
85
- return this.value.name;
86
- }
87
- if (this.value instanceof FileList) {
88
- return `${this.value.length} files`;
89
- }
90
- return '';
91
- }
92
- ngOnInit() {
93
- // Handle click event on custom file button and trigger click on native file input
94
- this._ngZone.runOutsideAngular(() => {
95
- fromEvent(this._fileButton.nativeElement, 'click')
96
- .pipe(takeUntil(this._destroy$))
97
- .subscribe(() => {
98
- this._fileInput.nativeElement.click();
99
- });
100
- });
101
- }
102
- ngOnDestroy() {
103
- this._destroy$.next();
104
- }
105
- onFileSelect(event) {
106
- const fileInputEl = event.target;
107
- const files = fileInputEl.files;
108
- const value = this._multiple
109
- ? files?.length > 1 ? files : files[0]
110
- : files[0];
111
- this.value = value;
112
- this.onChange(value);
113
- this.onTouched();
114
- if (value) {
115
- this.selectedFile.emit(value);
116
- }
117
- }
118
- clear() {
119
- this.value = undefined;
120
- this.onChange(undefined);
121
- this._renderer.setProperty(this._fileInput.nativeElement, 'value', '');
122
- }
123
- writeValue(value) {
124
- this.value = value;
125
- }
126
- registerOnChange(fn) {
127
- this.onChange = fn;
128
- }
129
- registerOnTouched(fn) {
130
- this.onTouched = fn;
131
- }
132
- setDisabledState(isDisabled) {
133
- this._disabled = isDisabled;
134
- }
135
- // implements Validator interface
136
- validate(control) {
137
- const isSizeLimitExceeded = this.isFileSizeLimitExceeded(control.value);
138
- const isCountLimitExceeded = this.isFileCountLimitExceeded(control.value);
139
- if (!isSizeLimitExceeded && !isCountLimitExceeded) {
140
- return null;
141
- }
142
- return {
143
- ...(isSizeLimitExceeded ? { maxFileSize: true } : {}),
144
- ...(isCountLimitExceeded ? { maxFileCount: true } : {})
145
- };
146
- }
147
- isFileCountLimitExceeded(files) {
148
- const isMultiple = this.multiple && files instanceof FileList;
149
- const maxFileCount = this.maxFileCount;
150
- const actualFileCount = files?.length;
151
- return isMultiple && maxFileCount && actualFileCount > maxFileCount;
152
- }
153
- isFileSizeLimitExceeded(files) {
154
- if (!this.maxFileSizeInKb) {
155
- return false;
156
- }
157
- const maxFileSizeInBytes = this.maxFileSizeInKb * 1024;
158
- if (files instanceof File) {
159
- return files.size > maxFileSizeInBytes;
160
- }
161
- if (files instanceof FileList) {
162
- return Array.from(files).some(file => file.size > maxFileSizeInBytes);
163
- }
164
- return false;
165
- }
166
- }
167
- EntryFileInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: EntryFileInputComponent, deps: [{ token: i0.NgZone }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component });
168
- EntryFileInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: EntryFileInputComponent, selector: "entry-file-input", inputs: { label: "label", matIcon: "matIcon", accept: "accept", multiple: "multiple", disabled: "disabled", readonly: "readonly", maxFileSizeInKb: "maxFileSizeInKb", maxFileCount: "maxFileCount" }, outputs: { selectedFile: "selectedFile" }, providers: providers, viewQueries: [{ propertyName: "_fileButton", first: true, predicate: ["fileButton"], descendants: true, read: ElementRef, static: true }, { propertyName: "_fileInput", first: true, predicate: ["fileInput"], descendants: true, static: true }], ngImport: i0, template: "<button \r\n #fileButton \r\n mat-button \r\n entry-submit-button \r\n type=\"button\" \r\n [disabled]=\"disabled || readonly\">\r\n <mat-icon *ngIf=\"matIcon\">{{matIcon}}</mat-icon>\r\n <span>{{label}}</span>\r\n</button>\r\n<ng-container *ngIf=\"value\">\r\n {{fileNames}}\r\n</ng-container>\r\n<input\r\n #fileInput\r\n type=\"file\"\r\n class=\"file-input-hidden\"\r\n [accept]=\"accept\"\r\n [multiple]=\"multiple\"\r\n [disabled]=\"disabled\"\r\n [readonly]=\"readonly\"\r\n (change)=\"onFileSelect($event)\"\r\n/>", styles: [".file-input-hidden{display:none}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i3.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: i4.EntryButtonDirective, selector: "[mat-button][entry-submit-button],[mat-button][entry-cancel-button]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
169
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: EntryFileInputComponent, decorators: [{
170
- type: Component,
171
- args: [{ selector: 'entry-file-input', changeDetection: ChangeDetectionStrategy.OnPush, providers: providers, template: "<button \r\n #fileButton \r\n mat-button \r\n entry-submit-button \r\n type=\"button\" \r\n [disabled]=\"disabled || readonly\">\r\n <mat-icon *ngIf=\"matIcon\">{{matIcon}}</mat-icon>\r\n <span>{{label}}</span>\r\n</button>\r\n<ng-container *ngIf=\"value\">\r\n {{fileNames}}\r\n</ng-container>\r\n<input\r\n #fileInput\r\n type=\"file\"\r\n class=\"file-input-hidden\"\r\n [accept]=\"accept\"\r\n [multiple]=\"multiple\"\r\n [disabled]=\"disabled\"\r\n [readonly]=\"readonly\"\r\n (change)=\"onFileSelect($event)\"\r\n/>", styles: [".file-input-hidden{display:none}\n"] }]
172
- }], ctorParameters: function () { return [{ type: i0.NgZone }, { type: i0.Renderer2 }]; }, propDecorators: { label: [{
173
- type: Input
174
- }], matIcon: [{
175
- type: Input
176
- }], accept: [{
177
- type: Input
178
- }], multiple: [{
179
- type: Input
180
- }], disabled: [{
181
- type: Input
182
- }], readonly: [{
183
- type: Input
184
- }], maxFileSizeInKb: [{
185
- type: Input
186
- }], maxFileCount: [{
187
- type: Input
188
- }], selectedFile: [{
189
- type: Output
190
- }], _fileButton: [{
191
- type: ViewChild,
192
- args: ['fileButton', { static: true, read: ElementRef }]
193
- }], _fileInput: [{
194
- type: ViewChild,
195
- args: ['fileInput', { static: true }]
196
- }] } });
197
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"entry-file-input.component.js","sourceRoot":"","sources":["../../../../../libs/entry-components/file-input/entry-file-input.component.ts","../../../../../libs/entry-components/file-input/entry-file-input.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/member-ordering */\nimport { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\nimport {\n  ChangeDetectionStrategy,\n  Component, ElementRef, EventEmitter, Input, NgZone,\n  OnDestroy, OnInit, Output, Renderer2, ViewChild, forwardRef\n} from '@angular/core';\nimport {\n  AbstractControl, ControlValueAccessor, NG_VALIDATORS,\n  NG_VALUE_ACCESSOR, ValidationErrors, Validator\n} from '@angular/forms';\nimport { Subject, fromEvent } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nconst providers = [\n  {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => EntryFileInputComponent),\n    multi: true\n  },\n  {\n    provide: NG_VALIDATORS,\n    useExisting: forwardRef(() => EntryFileInputComponent),\n    multi: true\n  }\n];\n\n@Component({\n  selector: 'entry-file-input',\n  templateUrl: './entry-file-input.component.html',\n  styleUrls: ['./entry-file-input.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers\n})\nexport class EntryFileInputComponent implements OnInit, OnDestroy, ControlValueAccessor, Validator {\n\n  /**\n   * Label for the select file button. Defaults to 'Choose file...'\n   */\n  @Input() label = 'Choose file...';\n\n  /**\n   * MatIcon for the select file button. Defaults to 'insert_drive_file' (optional)\n   */\n  @Input() matIcon?= 'insert_drive_file';\n\n  /**\n   * Same as 'accept' attribute in <input/> element.\n   */\n  @Input() accept?: string;\n\n  /**\n   * Same as 'multiple' attribute in <input/> element.\n   */\n  @Input()\n  set multiple(multiple: BooleanInput) {\n    this._multiple = coerceBooleanProperty(multiple);\n  }\n  get multiple(): boolean {\n    return this._multiple;\n  }\n  private _multiple = false;\n\n  /**\n   * Same as 'disabled' attribute in <input/> element.\n   */\n  @Input()\n  set disabled(disabled: BooleanInput) {\n    this._disabled = coerceBooleanProperty(disabled);\n  }\n  get disabled(): boolean {\n    return this._disabled;\n  }\n  private _disabled = false;\n\n  /**\n   * Same as 'readonly' attribute in <input/> element.\n   */\n  @Input()\n  set readonly(readonly: BooleanInput) {\n    this._readonly = coerceBooleanProperty(readonly);\n  }\n  get readonly(): boolean {\n    return this._readonly;\n  }\n  private _readonly = false;\n\n  /**\n   * Size limit per file in KB (kilobytes)\n   */\n  @Input() maxFileSizeInKb?: number = undefined;\n\n  /**\n   * Number of files allowed when multiple=true\n   */\n  @Input() maxFileCount?: number = undefined;\n\n  /**\n   * Current selected [File | FileList] object.\n   */\n  value: File | FileList | undefined;\n\n  /**\n   * Event emitted when a file is selected. Emits a [File | FileList] object.\n   */\n  @Output() selectedFile = new EventEmitter<File | FileList>();\n\n\n  @ViewChild('fileButton', { static: true, read: ElementRef })\n  _fileButton!: ElementRef<HTMLElement>;\n\n  @ViewChild('fileInput', { static: true })\n  _fileInput!: ElementRef<HTMLInputElement>;\n\n  private _destroy$ = new Subject<void>();\n\n  constructor(\n    private readonly _ngZone: NgZone,\n    private readonly _renderer: Renderer2) {\n  }\n\n  get fileNames(): string {\n    if (this.value instanceof File) {\n      return this.value.name;\n    }\n    if (this.value instanceof FileList) {\n      return `${this.value.length} files`;\n    }\n    return '';\n  }\n\n  ngOnInit(): void {\n    // Handle click event on custom file button and trigger click on native file input\n    this._ngZone.runOutsideAngular(() => {\n      fromEvent(this._fileButton.nativeElement, 'click')\n        .pipe(takeUntil(this._destroy$))\n        .subscribe(() => {\n          this._fileInput.nativeElement.click();\n        });\n    });\n  }\n\n  ngOnDestroy(): void {\n    this._destroy$.next();\n  }\n\n  onFileSelect(event: Event): void {\n    const fileInputEl = event.target as HTMLInputElement;\n    const files: FileList = fileInputEl.files;\n\n    const value = this._multiple\n      ? files?.length > 1 ? files : files[0]\n      : files[0];\n\n    this.value = value;\n    this.onChange(value);\n    this.onTouched();\n\n    if (value) {\n      this.selectedFile.emit(value);\n    }\n  }\n\n  clear(): void {\n    this.value = undefined;\n    this.onChange(undefined);\n    this._renderer.setProperty(this._fileInput.nativeElement, 'value', '');\n  }\n\n  // implements ControlValueAccessor interface\n\n  onChange = (_: any) => { };\n\n  onTouched = () => { };\n\n  writeValue(value: any): void {\n    this.value = value;\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n\n  setDisabledState?(isDisabled: boolean): void {\n    this._disabled = isDisabled;\n  }\n\n  // implements Validator interface\n\n  validate(control: AbstractControl<File | FileList | undefined>): ValidationErrors {\n    const isSizeLimitExceeded = this.isFileSizeLimitExceeded(control.value);\n    const isCountLimitExceeded = this.isFileCountLimitExceeded(control.value);\n\n    if (!isSizeLimitExceeded && !isCountLimitExceeded) {\n      return null;\n    }\n    return {\n      ...(isSizeLimitExceeded ? { maxFileSize: true } : {}),\n      ...(isCountLimitExceeded ? { maxFileCount: true } : {})\n    };\n  }\n\n  private isFileCountLimitExceeded(files: File | FileList): boolean {\n    const isMultiple = this.multiple && files instanceof FileList;\n    const maxFileCount = this.maxFileCount;\n    const actualFileCount = (files as FileList)?.length;\n\n    return isMultiple && maxFileCount && actualFileCount > maxFileCount;\n  }\n\n  private isFileSizeLimitExceeded(files: File | FileList): boolean {\n    if (!this.maxFileSizeInKb) {\n      return false;\n    }\n    const maxFileSizeInBytes = this.maxFileSizeInKb * 1024;\n\n    if (files instanceof File) {\n      return files.size > maxFileSizeInBytes;\n    }\n    if (files instanceof FileList) {\n      return Array.from(files).some(file => file.size > maxFileSizeInBytes);\n    }\n    return false;\n  }\n}\n","<button \r\n #fileButton \r\n mat-button \r\n entry-submit-button \r\n type=\"button\" \r\n [disabled]=\"disabled || readonly\">\r\n  <mat-icon *ngIf=\"matIcon\">{{matIcon}}</mat-icon>\r\n  <span>{{label}}</span>\r\n</button>\r\n<ng-container *ngIf=\"value\">\r\n  {{fileNames}}\r\n</ng-container>\r\n<input\r\n #fileInput\r\n type=\"file\"\r\n class=\"file-input-hidden\"\r\n [accept]=\"accept\"\r\n [multiple]=\"multiple\"\r\n [disabled]=\"disabled\"\r\n [readonly]=\"readonly\"\r\n (change)=\"onFileSelect($event)\"\r\n/>"]}
@@ -1,19 +0,0 @@
1
- import { Component, Input } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- import * as i1 from "@angular/forms";
4
- import * as i2 from "@angular/material/input";
5
- import * as i3 from "@angular/material/form-field";
6
- import * as i4 from "@angular/material/datepicker";
7
- export class DateSearchFilterComponent {
8
- }
9
- DateSearchFilterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DateSearchFilterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
10
- DateSearchFilterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: DateSearchFilterComponent, selector: "entry-date-search-filter", inputs: { searchFilter: "searchFilter", form: "form" }, ngImport: i0, template: "<mat-form-field [formGroup]=\"form\" subscriptSizing=\"dynamic\">\n <mat-label [attr.for]=\"searchFilter.key\">{{searchFilter.label}}</mat-label>\n <input matInput [formControlName]=\"searchFilter.key\" [matDatepicker]=\"picker\" [id]=\"searchFilter.key\">\n <mat-datepicker-toggle matIconSuffix [for]=\"picker\"></mat-datepicker-toggle>\n <mat-datepicker #picker></mat-datepicker>\n</mat-form-field>", dependencies: [{ kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i2.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "directive", type: i3.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "component", type: i4.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i4.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i4.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }] });
11
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DateSearchFilterComponent, decorators: [{
12
- type: Component,
13
- args: [{ selector: 'entry-date-search-filter', template: "<mat-form-field [formGroup]=\"form\" subscriptSizing=\"dynamic\">\n <mat-label [attr.for]=\"searchFilter.key\">{{searchFilter.label}}</mat-label>\n <input matInput [formControlName]=\"searchFilter.key\" [matDatepicker]=\"picker\" [id]=\"searchFilter.key\">\n <mat-datepicker-toggle matIconSuffix [for]=\"picker\"></mat-datepicker-toggle>\n <mat-datepicker #picker></mat-datepicker>\n</mat-form-field>" }]
14
- }], propDecorators: { searchFilter: [{
15
- type: Input
16
- }], form: [{
17
- type: Input
18
- }] } });
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1zZWFyY2gtZmlsdGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvZW50cnktY29tcG9uZW50cy9zZWFyY2gtZmlsdGVyL2RhdGUvZGF0ZS1zZWFyY2gtZmlsdGVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvZW50cnktY29tcG9uZW50cy9zZWFyY2gtZmlsdGVyL2RhdGUvZGF0ZS1zZWFyY2gtZmlsdGVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7Ozs7QUFRakQsTUFBTSxPQUFPLHlCQUF5Qjs7dUhBQXpCLHlCQUF5QjsyR0FBekIseUJBQXlCLHdIQ1J0Qyw4WkFLaUI7NEZER0oseUJBQXlCO2tCQUpyQyxTQUFTOytCQUNFLDBCQUEwQjs4QkFJM0IsWUFBWTtzQkFBcEIsS0FBSztnQkFFRyxJQUFJO3NCQUFaLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBVbnR5cGVkRm9ybUdyb3VwIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgRGF0ZVNlYXJjaEZpbHRlciB9IGZyb20gJy4vZGF0ZS1zZWFyY2gtZmlsdGVyLm1vZGVsJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZW50cnktZGF0ZS1zZWFyY2gtZmlsdGVyJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2RhdGUtc2VhcmNoLWZpbHRlci5jb21wb25lbnQuaHRtbCdcbn0pXG5leHBvcnQgY2xhc3MgRGF0ZVNlYXJjaEZpbHRlckNvbXBvbmVudDxEPiB7XG4gIEBJbnB1dCgpIHNlYXJjaEZpbHRlcjogRGF0ZVNlYXJjaEZpbHRlcjxEPjtcbiAgLyoqIEZvcm0gZ3JvdXAgdG8gd2hpY2ggdGhlIHNlYXJjaC1maWx0ZXIgaW5wdXQgY29tcG9uZW50IHdpbGwgYmUgYWRkZWQuICovXG4gIEBJbnB1dCgpIGZvcm06IFVudHlwZWRGb3JtR3JvdXA7XG59XG4iLCI8bWF0LWZvcm0tZmllbGQgW2Zvcm1Hcm91cF09XCJmb3JtXCIgc3Vic2NyaXB0U2l6aW5nPVwiZHluYW1pY1wiPlxuICAgIDxtYXQtbGFiZWwgW2F0dHIuZm9yXT1cInNlYXJjaEZpbHRlci5rZXlcIj57e3NlYXJjaEZpbHRlci5sYWJlbH19PC9tYXQtbGFiZWw+XG4gICAgPGlucHV0IG1hdElucHV0IFtmb3JtQ29udHJvbE5hbWVdPVwic2VhcmNoRmlsdGVyLmtleVwiIFttYXREYXRlcGlja2VyXT1cInBpY2tlclwiIFtpZF09XCJzZWFyY2hGaWx0ZXIua2V5XCI+XG4gICAgPG1hdC1kYXRlcGlja2VyLXRvZ2dsZSBtYXRJY29uU3VmZml4IFtmb3JdPVwicGlja2VyXCI+PC9tYXQtZGF0ZXBpY2tlci10b2dnbGU+XG4gICAgPG1hdC1kYXRlcGlja2VyICNwaWNrZXI+PC9tYXQtZGF0ZXBpY2tlcj5cbjwvbWF0LWZvcm0tZmllbGQ+Il19
@@ -1,33 +0,0 @@
1
- import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- import * as i1 from "@angular/common";
4
- import * as i2 from "@angular/material/icon";
5
- import * as i3 from "@angular/material/menu";
6
- import * as i4 from "@angular/material/button";
7
- export class EntryCellContextMenuComponent {
8
- constructor() {
9
- this.items = [];
10
- this.selected = new EventEmitter();
11
- this.menuItems = [];
12
- }
13
- ngOnInit() {
14
- this.menuItems = this.rowMenuFormatter?.items
15
- ? this.rowMenuFormatter.items(this.rowData)
16
- : this.items;
17
- }
18
- }
19
- EntryCellContextMenuComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: EntryCellContextMenuComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
20
- EntryCellContextMenuComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: EntryCellContextMenuComponent, selector: "entry-cell-context-menu", inputs: { items: "items", rowMenuFormatter: "rowMenuFormatter", rowData: "rowData" }, outputs: { selected: "selected" }, ngImport: i0, template: "<button mat-icon-button [matMenuTriggerFor]=\"menu\" (click)=\"$event.stopPropagation()\">\n <mat-icon>more_vert</mat-icon>\n</button>\n<mat-menu #menu=\"matMenu\" class=\"entry-table-menu\">\n <button *ngFor=\"let item of menuItems\" mat-menu-item [disabled]=\"item.disabled\" (click)=\"selected.emit(item.id)\"\n class=\"context-menu-item\">\n <mat-icon class=\"icon\" *ngIf=\"item.icon\">{{item.icon}}</mat-icon>\n <span class=\"description\">{{item.name}}</span>\n </button>\n</mat-menu>", dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i3.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "component", type: i3.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i3.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { kind: "component", type: i4.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
21
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: EntryCellContextMenuComponent, decorators: [{
22
- type: Component,
23
- args: [{ selector: 'entry-cell-context-menu', changeDetection: ChangeDetectionStrategy.OnPush, template: "<button mat-icon-button [matMenuTriggerFor]=\"menu\" (click)=\"$event.stopPropagation()\">\n <mat-icon>more_vert</mat-icon>\n</button>\n<mat-menu #menu=\"matMenu\" class=\"entry-table-menu\">\n <button *ngFor=\"let item of menuItems\" mat-menu-item [disabled]=\"item.disabled\" (click)=\"selected.emit(item.id)\"\n class=\"context-menu-item\">\n <mat-icon class=\"icon\" *ngIf=\"item.icon\">{{item.icon}}</mat-icon>\n <span class=\"description\">{{item.name}}</span>\n </button>\n</mat-menu>" }]
24
- }], propDecorators: { items: [{
25
- type: Input
26
- }], rowMenuFormatter: [{
27
- type: Input
28
- }], rowData: [{
29
- type: Input
30
- }], selected: [{
31
- type: Output
32
- }] } });
33
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW50cnktY2VsbC1jb250ZXh0LW1lbnUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9lbnRyeS1jb21wb25lbnRzL3RhYmxlL2NvbXBvbmVudHMvZW50cnktY2VsbC1jb250ZXh0LW1lbnUvZW50cnktY2VsbC1jb250ZXh0LW1lbnUuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9lbnRyeS1jb21wb25lbnRzL3RhYmxlL2NvbXBvbmVudHMvZW50cnktY2VsbC1jb250ZXh0LW1lbnUvZW50cnktY2VsbC1jb250ZXh0LW1lbnUuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFVLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7O0FBU3hHLE1BQU0sT0FBTyw2QkFBNkI7SUFMMUM7UUFPVyxVQUFLLEdBQXNCLEVBQUUsQ0FBQztRQUc3QixhQUFRLEdBQUcsSUFBSSxZQUFZLEVBQVUsQ0FBQztRQUVoRCxjQUFTLEdBQXNCLEVBQUUsQ0FBQztLQU9uQztJQUxDLFFBQVE7UUFDTixJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxLQUFLO1lBQzNDLENBQUMsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUM7WUFDM0MsQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUM7SUFDakIsQ0FBQzs7MkhBYlUsNkJBQTZCOytHQUE3Qiw2QkFBNkIsd0xDVDFDLDJnQkFTVzs0RkRBRSw2QkFBNkI7a0JBTHpDLFNBQVM7K0JBQ0UseUJBQXlCLG1CQUVsQix1QkFBdUIsQ0FBQyxNQUFNOzhCQUl0QyxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csZ0JBQWdCO3NCQUF4QixLQUFLO2dCQUNHLE9BQU87c0JBQWYsS0FBSztnQkFDSSxRQUFRO3NCQUFqQixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25Jbml0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFJvd0NvbnRleHRNZW51Rm9ybWF0dGVyIH0gZnJvbSAnLi4vLi4vaW50ZXJmYWNlcy9yb3ctY29udGV4dC1tZW51LWZvcm1hdHRlcic7XG5pbXBvcnQgeyBDb250ZXh0TWVudUl0ZW0gfSBmcm9tICcuLi8uLi9pbnRlcmZhY2VzL2NvbnRleHQtbWVudS1pdGVtJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZW50cnktY2VsbC1jb250ZXh0LW1lbnUnLFxuICB0ZW1wbGF0ZVVybDogJy4vZW50cnktY2VsbC1jb250ZXh0LW1lbnUuY29tcG9uZW50Lmh0bWwnLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBFbnRyeUNlbGxDb250ZXh0TWVudUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG5cbiAgQElucHV0KCkgaXRlbXM6IENvbnRleHRNZW51SXRlbVtdID0gW107XG4gIEBJbnB1dCgpIHJvd01lbnVGb3JtYXR0ZXI6IFJvd0NvbnRleHRNZW51Rm9ybWF0dGVyO1xuICBASW5wdXQoKSByb3dEYXRhOiBhbnk7XG4gIEBPdXRwdXQoKSBzZWxlY3RlZCA9IG5ldyBFdmVudEVtaXR0ZXI8c3RyaW5nPigpO1xuXG4gIG1lbnVJdGVtczogQ29udGV4dE1lbnVJdGVtW10gPSBbXTtcblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLm1lbnVJdGVtcyA9IHRoaXMucm93TWVudUZvcm1hdHRlcj8uaXRlbXNcbiAgICAgID8gdGhpcy5yb3dNZW51Rm9ybWF0dGVyLml0ZW1zKHRoaXMucm93RGF0YSlcbiAgICAgIDogdGhpcy5pdGVtcztcbiAgfVxufVxuIiwiPGJ1dHRvbiBtYXQtaWNvbi1idXR0b24gW21hdE1lbnVUcmlnZ2VyRm9yXT1cIm1lbnVcIiAoY2xpY2spPVwiJGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpXCI+XG4gICAgPG1hdC1pY29uPm1vcmVfdmVydDwvbWF0LWljb24+XG48L2J1dHRvbj5cbjxtYXQtbWVudSAjbWVudT1cIm1hdE1lbnVcIiBjbGFzcz1cImVudHJ5LXRhYmxlLW1lbnVcIj5cbiAgICA8YnV0dG9uICpuZ0Zvcj1cImxldCBpdGVtIG9mIG1lbnVJdGVtc1wiIG1hdC1tZW51LWl0ZW0gW2Rpc2FibGVkXT1cIml0ZW0uZGlzYWJsZWRcIiAoY2xpY2spPVwic2VsZWN0ZWQuZW1pdChpdGVtLmlkKVwiXG4gICAgICAgIGNsYXNzPVwiY29udGV4dC1tZW51LWl0ZW1cIj5cbiAgICAgICAgPG1hdC1pY29uIGNsYXNzPVwiaWNvblwiICpuZ0lmPVwiaXRlbS5pY29uXCI+e3tpdGVtLmljb259fTwvbWF0LWljb24+XG4gICAgICAgIDxzcGFuIGNsYXNzPVwiZGVzY3JpcHRpb25cIj57e2l0ZW0ubmFtZX19PC9zcGFuPlxuICAgIDwvYnV0dG9uPlxuPC9tYXQtbWVudT4iXX0=