@agorapulse/ui-components 0.0.1

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 (144) hide show
  1. package/agorapulse-ui-components-0.0.1.tgz +0 -0
  2. package/agorapulse-ui-components.d.ts +9 -0
  3. package/agorapulse-ui-components.metadata.json +1 -0
  4. package/assets/lib-ui/icons/facebook-icon.png +0 -0
  5. package/assets/lib-ui/icons/google-icon.png +0 -0
  6. package/assets/lib-ui/icons/instagram-icon.png +0 -0
  7. package/assets/lib-ui/icons/linkedin-icon.png +0 -0
  8. package/assets/lib-ui/icons/pinterest-icon.png +0 -0
  9. package/assets/lib-ui/icons/twitter-icon.png +0 -0
  10. package/assets/lib-ui/icons/youtube-icon.png +0 -0
  11. package/assets/lib-ui/img/default-avatar-organization.png +0 -0
  12. package/assets/lib-ui/img/default-avatar-user.png +0 -0
  13. package/assets/lib-ui/img/default-avatar.png +0 -0
  14. package/assets/lib-ui/img/spinner_animation.gif +0 -0
  15. package/bundles/agorapulse-ui-components.umd.js +4448 -0
  16. package/bundles/agorapulse-ui-components.umd.js.map +1 -0
  17. package/esm2015/agorapulse-ui-components.js +10 -0
  18. package/esm2015/index.js +57 -0
  19. package/esm2015/src/lib/add-comment/add-comment.component.js +54 -0
  20. package/esm2015/src/lib/agorapulse-ui-components.module.js +279 -0
  21. package/esm2015/src/lib/avatar/avatar.component.js +82 -0
  22. package/esm2015/src/lib/confirm-modal/confirm-modal-texts.model.js +2 -0
  23. package/esm2015/src/lib/confirm-modal/confirm-modal.component.js +59 -0
  24. package/esm2015/src/lib/datepicker/datepicker.component.js +213 -0
  25. package/esm2015/src/lib/directives/autosize-textarea.directive.js +43 -0
  26. package/esm2015/src/lib/directives/default-image.directive.js +25 -0
  27. package/esm2015/src/lib/directives/ellipsis.directive.js +82 -0
  28. package/esm2015/src/lib/directives/equal-validator.directive.js +53 -0
  29. package/esm2015/src/lib/directives/frozen-gif.directive.js +113 -0
  30. package/esm2015/src/lib/directives/multi-style-text.directive.js +103 -0
  31. package/esm2015/src/lib/directives/truncate-tooltip.directive.js +36 -0
  32. package/esm2015/src/lib/dots-stepper/dots-stepper.component.js +41 -0
  33. package/esm2015/src/lib/edit-tag-modal/edit-tags-modal.component.js +129 -0
  34. package/esm2015/src/lib/edit-tag-modal/model/edit-tags-modal.model.js +2 -0
  35. package/esm2015/src/lib/feature-onboarding/feature-onboarding.component.js +35 -0
  36. package/esm2015/src/lib/image-carousel/image-carousel.component.js +143 -0
  37. package/esm2015/src/lib/lead-modal/lead-info.model.js +2 -0
  38. package/esm2015/src/lib/lead-modal/lead-modal.component.js +47 -0
  39. package/esm2015/src/lib/media-display-overlay/media-display-overlay-dialog.component.js +87 -0
  40. package/esm2015/src/lib/modal/modal.component.js +88 -0
  41. package/esm2015/src/lib/notification/notification.component.js +18 -0
  42. package/esm2015/src/lib/overlay/overlay-dialog-service.component.js +62 -0
  43. package/esm2015/src/lib/overlay/overlay-dialog.component.js +33 -0
  44. package/esm2015/src/lib/overlay-in-div/overlay-in-div.component.js +23 -0
  45. package/esm2015/src/lib/paginator/paginator-button/paginator-button.component.js +22 -0
  46. package/esm2015/src/lib/paginator/paginator.component.js +47 -0
  47. package/esm2015/src/lib/password-input/password-input.component.js +65 -0
  48. package/esm2015/src/lib/password-strength-bar/password-strength-bar.component.js +82 -0
  49. package/esm2015/src/lib/password-strength-display-bar/password-strength-display-bar.component.js +41 -0
  50. package/esm2015/src/lib/phone-number-input/phone-number-input.component.js +123 -0
  51. package/esm2015/src/lib/places/place-list.component.js +12 -0
  52. package/esm2015/src/lib/places/place.component.js +15 -0
  53. package/esm2015/src/lib/popmenu/options.js +16 -0
  54. package/esm2015/src/lib/popmenu/popmenu-options.interface.js +2 -0
  55. package/esm2015/src/lib/popmenu/popmenu-options.service.js +7 -0
  56. package/esm2015/src/lib/popmenu/popmenu.component.js +322 -0
  57. package/esm2015/src/lib/popmenu/popmenu.directive.js +215 -0
  58. package/esm2015/src/lib/popmenu/popmenu.module.js +38 -0
  59. package/esm2015/src/lib/slide-toggle/slide-toggle.component.js +59 -0
  60. package/esm2015/src/lib/snackbar/snackbar.component.js +22 -0
  61. package/esm2015/src/lib/snackbars-thread/component/snackbars-thread.component.js +50 -0
  62. package/esm2015/src/lib/snackbars-thread/model/snackbars-thread.model.js +41 -0
  63. package/esm2015/src/lib/snackbars-thread/service/snackbars-thread.service.js +44 -0
  64. package/esm2015/src/lib/snackbars-thread/utils/const/snackbars-thread.const.js +13 -0
  65. package/esm2015/src/lib/splashscreen/splashscreen.component.js +37 -0
  66. package/esm2015/src/lib/star-rating/star-rating.component.js +38 -0
  67. package/esm2015/src/lib/stepper/step.model.js +2 -0
  68. package/esm2015/src/lib/stepper/stepper.component.js +37 -0
  69. package/esm2015/src/lib/tags/tag-list.component.js +12 -0
  70. package/esm2015/src/lib/tags/tag.component.js +20 -0
  71. package/esm2015/src/lib/tags-selector/tags-selector.component.js +73 -0
  72. package/esm2015/src/lib/timepicker/timepicker.component.js +375 -0
  73. package/esm2015/src/lib/tooltip-neo/tooltip-neo.component.js +46 -0
  74. package/esm2015/src/lib/tooltip-neo/tooltip-neo.const.js +67 -0
  75. package/esm2015/src/lib/tooltip-neo/tooltip-neo.directive.js +107 -0
  76. package/esm2015/src/lib/tooltip-neo/tooltip-neo.model.js +2 -0
  77. package/esm2015/src/lib/tooltip-neo/tooltip-neo.service.js +15 -0
  78. package/esm2015/src/lib/try-popup/try-popup-texts.model.js +2 -0
  79. package/esm2015/src/lib/try-popup/try-popup.component.js +33 -0
  80. package/fesm2015/agorapulse-ui-components.js +3805 -0
  81. package/fesm2015/agorapulse-ui-components.js.map +1 -0
  82. package/index.d.ts +54 -0
  83. package/package.json +37 -0
  84. package/src/lib/add-comment/add-comment.component.d.ts +17 -0
  85. package/src/lib/agorapulse-ui-components.module.d.ts +2 -0
  86. package/src/lib/avatar/avatar.component.d.ts +23 -0
  87. package/src/lib/confirm-modal/confirm-modal-texts.model.d.ts +8 -0
  88. package/src/lib/confirm-modal/confirm-modal.component.d.ts +17 -0
  89. package/src/lib/datepicker/datepicker.component.d.ts +69 -0
  90. package/src/lib/directives/autosize-textarea.directive.d.ts +9 -0
  91. package/src/lib/directives/default-image.directive.d.ts +5 -0
  92. package/src/lib/directives/ellipsis.directive.d.ts +27 -0
  93. package/src/lib/directives/equal-validator.directive.d.ts +10 -0
  94. package/src/lib/directives/frozen-gif.directive.d.ts +27 -0
  95. package/src/lib/directives/multi-style-text.directive.d.ts +15 -0
  96. package/src/lib/directives/truncate-tooltip.directive.d.ts +13 -0
  97. package/src/lib/dots-stepper/dots-stepper.component.d.ts +13 -0
  98. package/src/lib/edit-tag-modal/edit-tags-modal.component.d.ts +29 -0
  99. package/src/lib/edit-tag-modal/model/edit-tags-modal.model.d.ts +21 -0
  100. package/src/lib/feature-onboarding/feature-onboarding.component.d.ts +15 -0
  101. package/src/lib/image-carousel/image-carousel.component.d.ts +45 -0
  102. package/src/lib/lead-modal/lead-info.model.d.ts +7 -0
  103. package/src/lib/lead-modal/lead-modal.component.d.ts +28 -0
  104. package/src/lib/media-display-overlay/media-display-overlay-dialog.component.d.ts +28 -0
  105. package/src/lib/modal/modal.component.d.ts +47 -0
  106. package/src/lib/notification/notification.component.d.ts +3 -0
  107. package/src/lib/overlay/overlay-dialog-service.component.d.ts +20 -0
  108. package/src/lib/overlay/overlay-dialog.component.d.ts +17 -0
  109. package/src/lib/overlay-in-div/overlay-in-div.component.d.ts +8 -0
  110. package/src/lib/paginator/paginator-button/paginator-button.component.d.ts +6 -0
  111. package/src/lib/paginator/paginator.component.d.ts +14 -0
  112. package/src/lib/password-input/password-input.component.d.ts +28 -0
  113. package/src/lib/password-strength-bar/password-strength-bar.component.d.ts +21 -0
  114. package/src/lib/password-strength-display-bar/password-strength-display-bar.component.d.ts +14 -0
  115. package/src/lib/phone-number-input/phone-number-input.component.d.ts +42 -0
  116. package/src/lib/places/place-list.component.d.ts +2 -0
  117. package/src/lib/places/place.component.d.ts +3 -0
  118. package/src/lib/popmenu/options.d.ts +15 -0
  119. package/src/lib/popmenu/popmenu-options.interface.d.ts +24 -0
  120. package/src/lib/popmenu/popmenu-options.service.d.ts +7 -0
  121. package/src/lib/popmenu/popmenu.component.d.ts +58 -0
  122. package/src/lib/popmenu/popmenu.directive.d.ts +69 -0
  123. package/src/lib/popmenu/popmenu.module.d.ts +5 -0
  124. package/src/lib/slide-toggle/slide-toggle.component.d.ts +16 -0
  125. package/src/lib/snackbar/snackbar.component.d.ts +6 -0
  126. package/src/lib/snackbars-thread/component/snackbars-thread.component.d.ts +18 -0
  127. package/src/lib/snackbars-thread/model/snackbars-thread.model.d.ts +32 -0
  128. package/src/lib/snackbars-thread/service/snackbars-thread.service.d.ts +12 -0
  129. package/src/lib/snackbars-thread/utils/const/snackbars-thread.const.d.ts +12 -0
  130. package/src/lib/splashscreen/splashscreen.component.d.ts +15 -0
  131. package/src/lib/star-rating/star-rating.component.d.ts +10 -0
  132. package/src/lib/stepper/step.model.d.ts +5 -0
  133. package/src/lib/stepper/stepper.component.d.ts +14 -0
  134. package/src/lib/tags/tag-list.component.d.ts +2 -0
  135. package/src/lib/tags/tag.component.d.ts +4 -0
  136. package/src/lib/tags-selector/tags-selector.component.d.ts +29 -0
  137. package/src/lib/timepicker/timepicker.component.d.ts +68 -0
  138. package/src/lib/tooltip-neo/tooltip-neo.component.d.ts +12 -0
  139. package/src/lib/tooltip-neo/tooltip-neo.const.d.ts +4 -0
  140. package/src/lib/tooltip-neo/tooltip-neo.directive.d.ts +29 -0
  141. package/src/lib/tooltip-neo/tooltip-neo.model.d.ts +12 -0
  142. package/src/lib/tooltip-neo/tooltip-neo.service.d.ts +4 -0
  143. package/src/lib/try-popup/try-popup-texts.model.d.ts +4 -0
  144. package/src/lib/try-popup/try-popup.component.d.ts +12 -0
@@ -0,0 +1,59 @@
1
+ import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
2
+ import { MatDialogRef } from '@angular/material/dialog';
3
+ import { ModalComponent } from '../modal/modal.component';
4
+ export class ConfirmModalComponent {
5
+ constructor(dialogRef) {
6
+ this.dialogRef = dialogRef;
7
+ this.contentText = '';
8
+ this.footerCancelButtonId = 'cancel';
9
+ this.footerCancelButtonLabel = '';
10
+ this.footerConfirmButtonId = 'confirm';
11
+ this.footerConfirmButtonLabel = '';
12
+ this.headerTitle = '';
13
+ dialogRef.disableClose = true;
14
+ }
15
+ onCancel() {
16
+ this.dialogRef.close(false);
17
+ }
18
+ onConfirm() {
19
+ this.dialogRef.close(true);
20
+ }
21
+ static open(dialog, confirmModalTexts, modalConfig = null) {
22
+ if (!modalConfig) {
23
+ modalConfig = {};
24
+ }
25
+ if (!modalConfig.matDialogConfig) {
26
+ modalConfig.matDialogConfig = {
27
+ width: '550px'
28
+ };
29
+ }
30
+ const confirmModal = ModalComponent.openWithComponent(dialog, modalConfig, ConfirmModalComponent);
31
+ confirmModal.componentInstance.contentText = confirmModalTexts.contentText;
32
+ confirmModal.componentInstance.footerConfirmButtonId = confirmModalTexts.footerConfirmButtonId;
33
+ confirmModal.componentInstance.footerConfirmButtonLabel = confirmModalTexts.footerConfirmButtonLabel;
34
+ confirmModal.componentInstance.footerCancelButtonId = confirmModalTexts.footerCancelButtonId;
35
+ confirmModal.componentInstance.footerCancelButtonLabel = confirmModalTexts.footerCancelButtonLabel;
36
+ confirmModal.componentInstance.headerTitle = confirmModalTexts.headerTitle;
37
+ return confirmModal;
38
+ }
39
+ }
40
+ ConfirmModalComponent.decorators = [
41
+ { type: Component, args: [{
42
+ changeDetection: ChangeDetectionStrategy.OnPush,
43
+ selector: 'ap-confirm-modal',
44
+ template: "<ng-template #headerTemplate>\n <h2>{{headerTitle}}</h2>\n</ng-template>\n\n<ng-template #mainTemplate>\n <p>{{contentText}}</p>\n</ng-template>\n\n<ng-template #footerTemplate>\n <button mat-flat-button (click)=\"onCancel()\" [id]=\"footerCancelButtonId\">\n {{ footerCancelButtonLabel }}\n </button>\n <button mat-flat-button color=\"primary\" cdkFocusInitial [id]=footerConfirmButtonId\n (click)=\"onConfirm()\">\n {{ footerConfirmButtonLabel }}\n </button>\n</ng-template>\n\n<ap-modal [closable]=\"true\"\n [headerTemplate]=\"headerTemplate\"\n [mainTemplate]=\"mainTemplate\"\n [footerTemplate]=\"footerTemplate\"\n></ap-modal>\n"
45
+ },] }
46
+ ];
47
+ /** @nocollapse */
48
+ ConfirmModalComponent.ctorParameters = () => [
49
+ { type: MatDialogRef }
50
+ ];
51
+ ConfirmModalComponent.propDecorators = {
52
+ contentText: [{ type: Input }],
53
+ footerCancelButtonId: [{ type: Input }],
54
+ footerCancelButtonLabel: [{ type: Input }],
55
+ footerConfirmButtonId: [{ type: Input }],
56
+ footerConfirmButtonLabel: [{ type: Input }],
57
+ headerTitle: [{ type: Input }]
58
+ };
59
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlybS1tb2RhbC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpLWNvbXBvbmVudHMvc3JjL2xpYi9jb25maXJtLW1vZGFsL2NvbmZpcm0tbW9kYWwuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRXhFLE9BQU8sRUFBWSxZQUFZLEVBQUMsTUFBTSwwQkFBMEIsQ0FBQztBQUNqRSxPQUFPLEVBQUMsY0FBYyxFQUFjLE1BQU0sMEJBQTBCLENBQUM7QUFRckUsTUFBTSxPQUFPLHFCQUFxQjtJQVM5QixZQUNXLFNBQTJDO1FBQTNDLGNBQVMsR0FBVCxTQUFTLENBQWtDO1FBUjdDLGdCQUFXLEdBQVcsRUFBRSxDQUFDO1FBQ3pCLHlCQUFvQixHQUFXLFFBQVEsQ0FBQztRQUN4Qyw0QkFBdUIsR0FBVyxFQUFFLENBQUM7UUFDckMsMEJBQXFCLEdBQVcsU0FBUyxDQUFDO1FBQzFDLDZCQUF3QixHQUFXLEVBQUUsQ0FBQztRQUN0QyxnQkFBVyxHQUFXLEVBQUUsQ0FBQztRQUk5QixTQUFTLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQztJQUNsQyxDQUFDO0lBRUQsUUFBUTtRQUNKLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2hDLENBQUM7SUFFRCxTQUFTO1FBQ0wsSUFBSSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDL0IsQ0FBQztJQUVELE1BQU0sQ0FBQyxJQUFJLENBQUMsTUFBaUIsRUFBRSxpQkFBb0MsRUFBRSxjQUEyQixJQUFJO1FBQ2hHLElBQUksQ0FBQyxXQUFXLEVBQUU7WUFDZCxXQUFXLEdBQUcsRUFBRSxDQUFDO1NBQ3BCO1FBQ0QsSUFBSSxDQUFDLFdBQVcsQ0FBQyxlQUFlLEVBQUU7WUFDOUIsV0FBVyxDQUFDLGVBQWUsR0FBRztnQkFDMUIsS0FBSyxFQUFFLE9BQU87YUFDakIsQ0FBQztTQUNMO1FBQ0QsTUFBTSxZQUFZLEdBQUcsY0FBYyxDQUFDLGlCQUFpQixDQUFDLE1BQU0sRUFBRSxXQUFXLEVBQUUscUJBQXFCLENBQUMsQ0FBQztRQUNsRyxZQUFZLENBQUMsaUJBQWlCLENBQUMsV0FBVyxHQUFHLGlCQUFpQixDQUFDLFdBQVcsQ0FBQztRQUMzRSxZQUFZLENBQUMsaUJBQWlCLENBQUMscUJBQXFCLEdBQUcsaUJBQWlCLENBQUMscUJBQXFCLENBQUM7UUFDL0YsWUFBWSxDQUFDLGlCQUFpQixDQUFDLHdCQUF3QixHQUFHLGlCQUFpQixDQUFDLHdCQUF3QixDQUFDO1FBQ3JHLFlBQVksQ0FBQyxpQkFBaUIsQ0FBQyxvQkFBb0IsR0FBRyxpQkFBaUIsQ0FBQyxvQkFBb0IsQ0FBQztRQUM3RixZQUFZLENBQUMsaUJBQWlCLENBQUMsdUJBQXVCLEdBQUcsaUJBQWlCLENBQUMsdUJBQXVCLENBQUM7UUFDbkcsWUFBWSxDQUFDLGlCQUFpQixDQUFDLFdBQVcsR0FBRyxpQkFBaUIsQ0FBQyxXQUFXLENBQUM7UUFDM0UsT0FBTyxZQUFZLENBQUM7SUFDeEIsQ0FBQzs7O1lBNUNKLFNBQVMsU0FBQztnQkFDUCxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtnQkFDL0MsUUFBUSxFQUFFLGtCQUFrQjtnQkFDNUIsNnNCQUEyQzthQUM5Qzs7OztZQVJrQixZQUFZOzs7MEJBVzFCLEtBQUs7bUNBQ0wsS0FBSztzQ0FDTCxLQUFLO29DQUNMLEtBQUs7dUNBQ0wsS0FBSzswQkFDTCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBJbnB1dH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0NvbXBvbmVudFR5cGV9IGZyb20gJ0Bhbmd1bGFyL2Nkay9wb3J0YWwnO1xuaW1wb3J0IHtNYXREaWFsb2csIE1hdERpYWxvZ1JlZn0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvZGlhbG9nJztcbmltcG9ydCB7TW9kYWxDb21wb25lbnQsIE1vZGFsQ29uZmlnfSBmcm9tICcuLi9tb2RhbC9tb2RhbC5jb21wb25lbnQnO1xuaW1wb3J0IHtDb25maXJtTW9kYWxUZXh0c30gZnJvbSAnLi9jb25maXJtLW1vZGFsLXRleHRzLm1vZGVsJztcblxuQENvbXBvbmVudCh7XG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gICAgc2VsZWN0b3I6ICdhcC1jb25maXJtLW1vZGFsJyxcbiAgICB0ZW1wbGF0ZVVybDogJ2NvbmZpcm0tbW9kYWwuY29tcG9uZW50Lmh0bWwnLFxufSlcbmV4cG9ydCBjbGFzcyBDb25maXJtTW9kYWxDb21wb25lbnQge1xuXG4gICAgQElucHV0KCkgY29udGVudFRleHQ6IHN0cmluZyA9ICcnO1xuICAgIEBJbnB1dCgpIGZvb3RlckNhbmNlbEJ1dHRvbklkOiBzdHJpbmcgPSAnY2FuY2VsJztcbiAgICBASW5wdXQoKSBmb290ZXJDYW5jZWxCdXR0b25MYWJlbDogc3RyaW5nID0gJyc7XG4gICAgQElucHV0KCkgZm9vdGVyQ29uZmlybUJ1dHRvbklkOiBzdHJpbmcgPSAnY29uZmlybSc7XG4gICAgQElucHV0KCkgZm9vdGVyQ29uZmlybUJ1dHRvbkxhYmVsOiBzdHJpbmcgPSAnJztcbiAgICBASW5wdXQoKSBoZWFkZXJUaXRsZTogc3RyaW5nID0gJyc7XG5cbiAgICBjb25zdHJ1Y3RvcihcbiAgICAgICAgcHVibGljIGRpYWxvZ1JlZjogTWF0RGlhbG9nUmVmPENvbXBvbmVudFR5cGU8YW55Pj4pIHtcbiAgICAgICAgZGlhbG9nUmVmLmRpc2FibGVDbG9zZSA9IHRydWU7XG4gICAgfVxuXG4gICAgb25DYW5jZWwoKSB7XG4gICAgICAgIHRoaXMuZGlhbG9nUmVmLmNsb3NlKGZhbHNlKTtcbiAgICB9XG5cbiAgICBvbkNvbmZpcm0oKSB7XG4gICAgICAgIHRoaXMuZGlhbG9nUmVmLmNsb3NlKHRydWUpO1xuICAgIH1cblxuICAgIHN0YXRpYyBvcGVuKGRpYWxvZzogTWF0RGlhbG9nLCBjb25maXJtTW9kYWxUZXh0czogQ29uZmlybU1vZGFsVGV4dHMsIG1vZGFsQ29uZmlnOiBNb2RhbENvbmZpZyA9IG51bGwpIHtcbiAgICAgICAgaWYgKCFtb2RhbENvbmZpZykge1xuICAgICAgICAgICAgbW9kYWxDb25maWcgPSB7fTtcbiAgICAgICAgfVxuICAgICAgICBpZiAoIW1vZGFsQ29uZmlnLm1hdERpYWxvZ0NvbmZpZykge1xuICAgICAgICAgICAgbW9kYWxDb25maWcubWF0RGlhbG9nQ29uZmlnID0ge1xuICAgICAgICAgICAgICAgIHdpZHRoOiAnNTUwcHgnXG4gICAgICAgICAgICB9O1xuICAgICAgICB9XG4gICAgICAgIGNvbnN0IGNvbmZpcm1Nb2RhbCA9IE1vZGFsQ29tcG9uZW50Lm9wZW5XaXRoQ29tcG9uZW50KGRpYWxvZywgbW9kYWxDb25maWcsIENvbmZpcm1Nb2RhbENvbXBvbmVudCk7XG4gICAgICAgIGNvbmZpcm1Nb2RhbC5jb21wb25lbnRJbnN0YW5jZS5jb250ZW50VGV4dCA9IGNvbmZpcm1Nb2RhbFRleHRzLmNvbnRlbnRUZXh0O1xuICAgICAgICBjb25maXJtTW9kYWwuY29tcG9uZW50SW5zdGFuY2UuZm9vdGVyQ29uZmlybUJ1dHRvbklkID0gY29uZmlybU1vZGFsVGV4dHMuZm9vdGVyQ29uZmlybUJ1dHRvbklkO1xuICAgICAgICBjb25maXJtTW9kYWwuY29tcG9uZW50SW5zdGFuY2UuZm9vdGVyQ29uZmlybUJ1dHRvbkxhYmVsID0gY29uZmlybU1vZGFsVGV4dHMuZm9vdGVyQ29uZmlybUJ1dHRvbkxhYmVsO1xuICAgICAgICBjb25maXJtTW9kYWwuY29tcG9uZW50SW5zdGFuY2UuZm9vdGVyQ2FuY2VsQnV0dG9uSWQgPSBjb25maXJtTW9kYWxUZXh0cy5mb290ZXJDYW5jZWxCdXR0b25JZDtcbiAgICAgICAgY29uZmlybU1vZGFsLmNvbXBvbmVudEluc3RhbmNlLmZvb3RlckNhbmNlbEJ1dHRvbkxhYmVsID0gY29uZmlybU1vZGFsVGV4dHMuZm9vdGVyQ2FuY2VsQnV0dG9uTGFiZWw7XG4gICAgICAgIGNvbmZpcm1Nb2RhbC5jb21wb25lbnRJbnN0YW5jZS5oZWFkZXJUaXRsZSA9IGNvbmZpcm1Nb2RhbFRleHRzLmhlYWRlclRpdGxlO1xuICAgICAgICByZXR1cm4gY29uZmlybU1vZGFsO1xuICAgIH1cbn1cbiJdfQ==
@@ -0,0 +1,213 @@
1
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
2
+ import { DaterangepickerComponent } from "ngx-daterangepicker-material";
3
+ import moment from 'moment';
4
+ export var DatepickerMode;
5
+ (function (DatepickerMode) {
6
+ DatepickerMode["Single"] = "Single";
7
+ DatepickerMode["Multiple"] = "Multiple";
8
+ DatepickerMode["Range"] = "Range";
9
+ })(DatepickerMode || (DatepickerMode = {}));
10
+ var SideEnum;
11
+ (function (SideEnum) {
12
+ SideEnum["left"] = "left";
13
+ SideEnum["right"] = "right";
14
+ })(SideEnum || (SideEnum = {}));
15
+ // TODO fix css for range mode (more lateral padding)
16
+ export class DatepickerComponent {
17
+ constructor(changeDetectorRef) {
18
+ this.changeDetectorRef = changeDetectorRef;
19
+ this.i18n = {
20
+ ranges: {
21
+ yesterday: 'Yesterday',
22
+ lastWeek: 'Last Week',
23
+ last30Days: 'Last 30 days',
24
+ lastMonth: 'Previous month',
25
+ thisMonth: 'This Month',
26
+ }
27
+ };
28
+ this.selectedDates = [];
29
+ this.selectedPeriod = { startDate: null, endDate: null };
30
+ this.dateSelected = new EventEmitter();
31
+ this.periodSelected = new EventEmitter();
32
+ this.DatepickerMode = DatepickerMode;
33
+ this.doubleCalendarWidth = 528; // 231px calendar table * 2 = 462 (+ 16px x-padding * 4 = 64)
34
+ this.ranges = {};
35
+ this.rangePickerWidth = 150;
36
+ this.pageSet = false;
37
+ this.isCustomDate = (date) => {
38
+ var _a, _b;
39
+ const classes = [];
40
+ if (this.mode === DatepickerMode.Multiple) {
41
+ classes.push(this.isSelected(date) ? 'active' : 'force-inactive');
42
+ }
43
+ else if (this.mode === DatepickerMode.Single) {
44
+ classes.push(this.selectedDate && this.selectedDate.isSame(date, 'day') ? 'active' : 'force-inactive');
45
+ }
46
+ else if (this.mode === DatepickerMode.Range) {
47
+ classes.push('range-picker-mode');
48
+ // Workaround to fix the auto-active today date when no date is selected
49
+ if (moment().isSame(date, 'day')
50
+ && !((_a = this.selectedPeriod) === null || _a === void 0 ? void 0 : _a.startDate)
51
+ && !((_b = this.selectedPeriod) === null || _b === void 0 ? void 0 : _b.endDate)) {
52
+ classes.push('force-inactive');
53
+ }
54
+ }
55
+ return classes;
56
+ };
57
+ }
58
+ ngOnInit() {
59
+ this.initRanges();
60
+ this.initDatePickerLocale();
61
+ }
62
+ ngOnChanges(changes) {
63
+ var _a, _b;
64
+ this.setWidth();
65
+ if (this.datepickerRef) {
66
+ setTimeout(() => {
67
+ this.datepickerRef.updateCalendars();
68
+ this.changeDetectorRef.detectChanges();
69
+ }, 100);
70
+ }
71
+ if (((_a = changes.selectedPeriod) === null || _a === void 0 ? void 0 : _a.currentValue) && this.datepickerRef) {
72
+ if (this.selectedPeriod.startDate === null && this.selectedPeriod.endDate === null) {
73
+ this.datepickerRef.clear();
74
+ }
75
+ else {
76
+ this.datepickerRef.setStartDate(this.selectedPeriod.startDate);
77
+ this.datepickerRef.setEndDate(this.selectedPeriod.endDate);
78
+ }
79
+ }
80
+ if (((_b = changes.mode) === null || _b === void 0 ? void 0 : _b.currentValue) === DatepickerMode.Single && this.datepickerRef) {
81
+ this.setCalendarCurrentPage();
82
+ }
83
+ }
84
+ ngAfterViewInit() {
85
+ if (this.datepickerRef) {
86
+ setTimeout(() => {
87
+ this.datepickerRef.updateCalendars();
88
+ this.setCalendarCurrentPage();
89
+ }, 100);
90
+ }
91
+ }
92
+ initDatePickerLocale() {
93
+ if (this.locale) {
94
+ moment.locale(this.locale);
95
+ }
96
+ let firstDayOfWeekIndex;
97
+ if (this.firstDayOfWeek === "sunday") {
98
+ firstDayOfWeekIndex = 0;
99
+ }
100
+ else if (this.firstDayOfWeek === "monday") {
101
+ firstDayOfWeekIndex = 1;
102
+ }
103
+ else {
104
+ firstDayOfWeekIndex = moment.localeData().firstDayOfWeek();
105
+ }
106
+ this.localeConfig = {
107
+ customRangeLabel: 'custom',
108
+ daysOfWeek: moment.weekdaysMin(),
109
+ monthNames: moment.months(),
110
+ firstDay: firstDayOfWeekIndex
111
+ };
112
+ }
113
+ initRanges() {
114
+ this.ranges[this.i18n.ranges.yesterday] = [moment().subtract(1, 'days'), moment().subtract(1, 'days')];
115
+ this.ranges[this.i18n.ranges.lastWeek] = [moment().subtract(7, 'days'), moment().subtract(1, 'days')];
116
+ this.ranges[this.i18n.ranges.last30Days] = [moment().subtract(30, 'days'), moment().subtract(1, 'days')];
117
+ this.ranges[this.i18n.ranges.lastMonth] = [moment().subtract(1, 'month').startOf('month'), moment().subtract(1, 'month').endOf('month')];
118
+ this.ranges[this.i18n.ranges.thisMonth] = [moment().startOf('month'), moment().endOf('month')];
119
+ }
120
+ isSelected(date) {
121
+ return this.selectedDates && this.selectedDates.some(selectedDate => selectedDate.isSame(date, 'day'));
122
+ }
123
+ onStartDateChanged(event) {
124
+ const date = event.startDate;
125
+ if (this.mode !== DatepickerMode.Range) {
126
+ this.selectedDate = date;
127
+ this.datepickerRef.setEndDate(date);
128
+ if (this.pageSet) {
129
+ this.pageSet = false;
130
+ }
131
+ else {
132
+ this.dateSelected.emit(date.clone());
133
+ if (this.mode === DatepickerMode.Multiple) {
134
+ this.selectedDates.push(date);
135
+ }
136
+ }
137
+ if (this.datepickerRef) {
138
+ this.datepickerRef.updateCalendars();
139
+ }
140
+ }
141
+ }
142
+ onDatesUpdated(event) {
143
+ var _a, _b;
144
+ if (this.mode === DatepickerMode.Range) {
145
+ this.periodSelected.emit({
146
+ startDate: (_a = event.startDate) === null || _a === void 0 ? void 0 : _a.clone(),
147
+ endDate: (_b = event.endDate) === null || _b === void 0 ? void 0 : _b.clone()
148
+ });
149
+ }
150
+ if (this.datepickerRef) {
151
+ this.datepickerRef.updateCalendars();
152
+ }
153
+ }
154
+ onNextMonth() {
155
+ this.datepickerRef.leftCalendar.month = this.datepickerRef.leftCalendar.month.add(1, 'months').clone();
156
+ this.datepickerRef.rightCalendar.month = this.datepickerRef.rightCalendar.month.add(1, 'months').clone();
157
+ this.datepickerRef.clickNext(SideEnum.left);
158
+ this.datepickerRef.clickNext(SideEnum.right);
159
+ }
160
+ onPreviousMonth() {
161
+ this.datepickerRef.leftCalendar.month = this.datepickerRef.leftCalendar.month.subtract(1, 'months').clone();
162
+ this.datepickerRef.rightCalendar.month = this.datepickerRef.rightCalendar.month.subtract(1, 'months').clone();
163
+ this.datepickerRef.clickPrev(SideEnum.left);
164
+ this.datepickerRef.clickPrev(SideEnum.right);
165
+ }
166
+ /**
167
+ * Ugly hack used here to open the calendar on the right day if they are selected dates
168
+ * * https://github.com/fetrarij/ngx-daterangepicker-material/issues/139
169
+ */
170
+ setCalendarCurrentPage() {
171
+ const selectedFirstDate = this.selectedDates.length > 0 ? this.selectedDates[0] : this.selectedDate;
172
+ if (selectedFirstDate && selectedFirstDate.isValid() && this.mode !== DatepickerMode.Range) {
173
+ const endDate = selectedFirstDate.clone();
174
+ endDate.add(1, 'month');
175
+ this.pageSet = true;
176
+ this.datepickerRef.setStartDate(selectedFirstDate);
177
+ this.datepickerRef.setEndDate(endDate);
178
+ this.datepickerRef.updateView();
179
+ }
180
+ this.changeDetectorRef.detectChanges();
181
+ }
182
+ setWidth() {
183
+ this.width = this.showRanges && this.mode === DatepickerMode.Range ? this.doubleCalendarWidth + this.rangePickerWidth : this.doubleCalendarWidth;
184
+ }
185
+ }
186
+ DatepickerComponent.decorators = [
187
+ { type: Component, args: [{
188
+ changeDetection: ChangeDetectionStrategy.OnPush,
189
+ selector: 'ap-datepicker',
190
+ template: "<div class=\"custom-calendar\" [style.width]=\"width + 'px'\">\n <div class=\"custom-header\">\n <div class=\"month-header\"\n *ngIf=\"this.datepickerRef.leftCalendar.month\">\n <div class=\"month-arrow-button\" (click)=\"onPreviousMonth()\">\n <ap-symbol\n [symbolId]=\"'arrow-left-1'\"\n [color]=\"'#858FA1'\"\n [size]=\"'14'\"></ap-symbol>\n </div>\n <div class=\"month-label\">\n {{ this.datepickerRef.leftCalendar.month.locale(locale).format('MMMM YYYY') }}\n </div>\n </div>\n <div class=\"month-header\"\n *ngIf=\"this.datepickerRef.rightCalendar.month\">\n <div class=\"month-label\">\n {{ this.datepickerRef.rightCalendar.month.locale(locale).format('MMMM YYYY') }}\n </div>\n <div class=\"month-arrow-button\" (click)=\"onNextMonth()\">\n <ap-symbol\n [symbolId]=\"'arrow-right-1'\"\n [color]=\"'#858FA1'\"\n [size]=\"'14'\"></ap-symbol>\n </div>\n </div>\n <div class=\"header-filler\" *ngIf=\"showRanges && mode === DatepickerMode.Range\">\n </div>\n </div>\n <ngx-daterangepicker-material\n #datepickerRef\n [class.hide-ranges]=\"!showRanges\"\n [alwaysShowCalendars]=\"true\"\n [autoApply]=\"true\"\n [customRangeDirection]=\"true\"\n [isCustomDate]=\"isCustomDate\"\n [locale]=\"localeConfig\"\n [maxDate]=\"maxDate\"\n [minDate]=\"minDate\"\n [ranges]=\"showRanges && mode === DatepickerMode.Range ? ranges : null\"\n (datesUpdated)=\"onDatesUpdated($event)\"\n (startDateChanged)=\"onStartDateChanged($event)\">\n </ngx-daterangepicker-material>\n</div>\n",
191
+ styles: ["[color=facebook]{color:#1877f2}[bgcolor=facebook],[hcolor=facebook]:hover{background-color:#1877f2}[border=facebook]{border:1px solid #1877f2}[color=google]{color:#4e85e8}[bgcolor=google],[hcolor=google]:hover{background-color:#4e85e8}[border=google]{border:1px solid #4e85e8}[color=instagram]{color:#e1306c}[bgcolor=instagram],[hcolor=instagram]:hover{background-color:#e1306c}[border=instagram]{border:1px solid #e1306c}[color=instagrammagenta]{color:#c13584}[bgcolor=instagrammagenta],[hcolor=instagrammagenta]:hover{background-color:#c13584}[border=instagrammagenta]{border:1px solid #c13584}[color=instagramblue]{color:#5851db}[bgcolor=instagramblue],[hcolor=instagramblue]:hover{background-color:#5851db}[border=instagramblue]{border:1px solid #5851db}[color=instagrampurple]{color:#833ab4}[bgcolor=instagrampurple],[hcolor=instagrampurple]:hover{background-color:#833ab4}[border=instagrampurple]{border:1px solid #833ab4}[color=instagramorange]{color:#f56040}[bgcolor=instagramorange],[hcolor=instagramorange]:hover{background-color:#f56040}[border=instagramorange]{border:1px solid #f56040}[color=instagramyellow]{color:#ffdc80}[bgcolor=instagramyellow],[hcolor=instagramyellow]:hover{background-color:#ffdc80}[border=instagramyellow]{border:1px solid #ffdc80}[color=linkedin]{color:#2c67bc}[bgcolor=linkedin],[hcolor=linkedin]:hover{background-color:#2c67bc}[border=linkedin]{border:1px solid #2c67bc}[color=twitter]{color:#55acee}[bgcolor=twitter],[hcolor=twitter]:hover{background-color:#55acee}[border=twitter]{border:1px solid #55acee}[color=youtube]{color:red}[bgcolor=youtube],[hcolor=youtube]:hover{background-color:red}[border=youtube]{border:1px solid red}[color=blood-orange]{color:#ff4d00}[bgcolor=blood-orange],[hcolor=blood-orange]:hover{background-color:#ff4d00}[border=blood-orange]{border:1px solid #ff4d00}[color=pinkish-orange]{color:#ff7b49}[bgcolor=pinkish-orange],[hcolor=pinkish-orange]:hover{background-color:#ff7b49}[border=pinkish-orange]{border:1px solid #ff7b49}[color=charcoal-grey]{color:#2a2f34}[bgcolor=charcoal-grey],[hcolor=charcoal-grey]:hover{background-color:#2a2f34}[border=charcoal-grey]{border:1px solid #2a2f34}[color=azure]{color:#00aeef}[bgcolor=azure],[hcolor=azure]:hover{background-color:#00aeef}[border=azure]{border:1px solid #00aeef}[color=light-azure]{color:#eaf5fd}[bgcolor=light-azure],[hcolor=light-azure]:hover{background-color:#eaf5fd}[border=light-azure]{border:1px solid #eaf5fd}[color=blue-grey]{color:#8d98a9}[bgcolor=blue-grey],[hcolor=blue-grey]:hover{background-color:#8d98a9}[border=blue-grey]{border:1px solid #8d98a9}[color=silver]{color:#ced0da}[bgcolor=silver],[hcolor=silver]:hover{background-color:#ced0da}[border=silver]{border:1px solid #ced0da}[color=pale-grey]{color:#dfe3e9}[bgcolor=pale-grey],[hcolor=pale-grey]:hover{background-color:#dfe3e9}[border=pale-grey]{border:1px solid #dfe3e9}[color=grey-white]{color:#f5f7f8}[bgcolor=grey-white],[hcolor=grey-white]:hover{background-color:#f5f7f8}[border=grey-white]{border:1px solid #f5f7f8}[color=cool-grey]{color:#b4bbc6}[bgcolor=cool-grey],[hcolor=cool-grey]:hover{background-color:#b4bbc6}[border=cool-grey]{border:1px solid #b4bbc6}[color=black]{color:#344563}[bgcolor=black],[hcolor=black]:hover{background-color:#344563}[border=black]{border:1px solid #344563}[color=grey-blue]{color:#68768c}[bgcolor=grey-blue],[hcolor=grey-blue]:hover{background-color:#68768c}[border=grey-blue]{border:1px solid #68768c}[color=strawberry]{color:#f4282d}[bgcolor=strawberry],[hcolor=strawberry]:hover{background-color:#f4282d}[border=strawberry]{border:1px solid #f4282d}[color=light-strawberry]{color:#f8eded}[bgcolor=light-strawberry],[hcolor=light-strawberry]:hover{background-color:#f8eded}[border=light-strawberry]{border:1px solid #f8eded}[color=white]{color:#fff}[bgcolor=white],[hcolor=white]:hover{background-color:#fff}[border=white]{border:1px solid #fff}[color=cool-green]{color:#33c15d}[bgcolor=cool-green],[hcolor=cool-green]:hover{background-color:#33c15d}[border=cool-green]{border:1px solid #33c15d}[color=light-green]{color:#ebfaef}[bgcolor=light-green],[hcolor=light-green]:hover{background-color:#ebfaef}[border=light-green]{border:1px solid #ebfaef}[color=transparent]{color:#0000}[bgcolor=transparent],[hcolor=transparent]:hover{background-color:initial}[border=transparent]{border:1px solid #0000}[color=c0]{color:#a566a5}[bgcolor=c0],[hcolor=c0]:hover{background-color:#a566a5}[border=c0]{border:1px solid #a566a5}[color=c1]{color:#c7ab82}[bgcolor=c1],[hcolor=c1]:hover{background-color:#c7ab82}[border=c1]{border:1px solid #c7ab82}[color=c2]{color:#f2713c}[bgcolor=c2],[hcolor=c2]:hover{background-color:#f2713c}[border=c2]{border:1px solid #f2713c}[color=c3]{color:#ffd006}[bgcolor=c3],[hcolor=c3]:hover{background-color:#ffd006}[border=c3]{border:1px solid #ffd006}[color=c4]{color:#94c5aa}[bgcolor=c4],[hcolor=c4]:hover{background-color:#94c5aa}[border=c4]{border:1px solid #94c5aa}[color=c5]{color:#2a9d8f}[bgcolor=c5],[hcolor=c5]:hover{background-color:#2a9d8f}[border=c5]{border:1px solid #2a9d8f}[color=c6]{color:#78acd8}[bgcolor=c6],[hcolor=c6]:hover{background-color:#78acd8}[border=c6]{border:1px solid #78acd8}[color=c7]{color:#525a9e}[bgcolor=c7],[hcolor=c7]:hover{background-color:#525a9e}[border=c7]{border:1px solid #525a9e}[color=c8]{color:#6a2459}[bgcolor=c8],[hcolor=c8]:hover{background-color:#6a2459}[border=c8]{border:1px solid #6a2459}[color=c9]{color:#74729e}[bgcolor=c9],[hcolor=c9]:hover{background-color:#74729e}[border=c9]{border:1px solid #74729e}::ng-deep .custom-calendar{background-color:#fff;display:flex;flex-direction:column;justify-content:center;border-radius:4px;height:-moz-fit-content;height:fit-content}::ng-deep .custom-calendar .custom-header{display:flex;align-items:center;justify-content:center;color:#344563;font-size:12px;font-weight:700;height:55px;text-transform:capitalize}::ng-deep .custom-calendar .custom-header .month-header{height:30px;width:255px;display:flex;align-items:center}::ng-deep .custom-calendar .custom-header .month-header .month-arrow-button{padding:10px;border-radius:2em;cursor:pointer}::ng-deep .custom-calendar .custom-header .month-header .month-arrow-button:hover{background-color:#eaecef}::ng-deep .custom-calendar .custom-header .month-header .month-label{flex:1;text-align:center}::ng-deep .custom-calendar .custom-header .header-filler{width:150px}::ng-deep .custom-calendar .md-drppicker{font-family:Averta;width:unset;height:219px;padding:0;margin:0 0 16px;box-shadow:none!important;z-index:0!important}::ng-deep .custom-calendar .md-drppicker .ranges{border-left:1px solid #eaecef;float:right!important;max-width:150px;height:100%}::ng-deep .custom-calendar .md-drppicker .ranges ul li{margin-left:12px}::ng-deep .custom-calendar .md-drppicker .ranges ul li:hover{background:unset}::ng-deep .custom-calendar .md-drppicker .ranges ul li button{font-family:Averta;font-size:14px;border-radius:4px;color:#5d6a82}::ng-deep .custom-calendar .md-drppicker .ranges ul li button:hover:not(.active):not(:disabled){color:#178dfe;background:#e8f4ff}::ng-deep .custom-calendar .md-drppicker .ranges ul li button.active{color:#fff;background:#178dfe}::ng-deep .custom-calendar .md-drppicker .ranges ul li button.active:hover{background:#3a9efe}::ng-deep .custom-calendar .md-drppicker .ranges ul li button:disabled{color:#d6dae0;background:none;cursor:default}::ng-deep .custom-calendar .md-drppicker .month{cursor:auto}::ng-deep .custom-calendar .md-drppicker .calendar{margin:0!important;padding:0 16px}::ng-deep .custom-calendar .md-drppicker .calendar.left{border-right:1px solid #eaecef}::ng-deep .custom-calendar .md-drppicker .calendar-table{width:231px;padding:0!important;border:none!important}::ng-deep .custom-calendar .md-drppicker .calendar-table table{border-spacing:0 5px!important;height:184px}::ng-deep .custom-calendar .md-drppicker .calendar-table table td,::ng-deep .custom-calendar .md-drppicker .calendar-table table th{height:unset;border:none}::ng-deep .custom-calendar .md-drppicker .calendar-table table thead{line-height:10px}::ng-deep .custom-calendar .md-drppicker .calendar-table table thead tr:first-child{display:none}::ng-deep .custom-calendar .md-drppicker .calendar-table table thead tr th{color:#aeb5c1;font-weight:700;font-size:12px;text-transform:capitalize;padding-bottom:10px}::ng-deep .custom-calendar .md-drppicker .calendar-table table thead tr th.month,::ng-deep .custom-calendar .md-drppicker .calendar-table table thead tr th.next,::ng-deep .custom-calendar .md-drppicker .calendar-table table thead tr th.prev{color:#344563}::ng-deep .custom-calendar .md-drppicker .calendar-table table thead tr th.next,::ng-deep .custom-calendar .md-drppicker .calendar-table table thead tr th.prev{font-size:16px}::ng-deep .custom-calendar .md-drppicker .calendar-table table tbody tr td:last-child.in-range{border-radius:0 2em 2em 0}::ng-deep .custom-calendar .md-drppicker .calendar-table table tbody tr td:first-child.in-range{border-radius:2em 0 0 2em}::ng-deep .custom-calendar .md-drppicker .calendar-table table tbody td{opacity:1!important;border-spacing:0;height:27px}::ng-deep .custom-calendar .md-drppicker .calendar-table table tbody td span{width:27px!important;height:27px!important;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-left:3px}::ng-deep .custom-calendar .md-drppicker .calendar-table table tbody td.in-range:not(.off):not(.force-inactive){background-color:#e8f4ff!important;color:#344563!important}::ng-deep .custom-calendar .md-drppicker .calendar-table table tbody td.active.start-date:not(.end-date).range-picker-mode:not(.off){border-radius:2em 0 0 2em;background-color:#178dfe!important;color:#fff!important}::ng-deep .custom-calendar .md-drppicker .calendar-table table tbody td.active.end-date:not(.start-date).range-picker-mode:not(.off){border-radius:0 2em 2em 0;background-color:#178dfe!important;color:#fff!important}::ng-deep .custom-calendar .md-drppicker .calendar-table table tbody td.active:not(.force-inactive).start-date.end-date.range-picker-mode:not(.off){background-color:unset!important}::ng-deep .custom-calendar .md-drppicker .calendar-table table tbody td.active:not(.force-inactive).start-date.end-date.range-picker-mode:not(.off) span{border-radius:2em;background-color:#178dfe!important;color:#fff!important}::ng-deep .custom-calendar .md-drppicker .calendar-table table tbody td.available.today.force-inactive:hover span,::ng-deep .custom-calendar .md-drppicker .calendar-table table tbody td.available:not(.start-date):not(.end-date):hover span{background-color:#d1e8ff!important}::ng-deep .custom-calendar .md-drppicker .calendar-table table tbody td.available.today.force-inactive:hover:not(.in-range),::ng-deep .custom-calendar .md-drppicker .calendar-table table tbody td.available:not(.start-date):not(.end-date):hover:not(.in-range){background-color:unset!important}::ng-deep .custom-calendar .md-drppicker .calendar-table table tbody td.available.in-range:not(.start-date):not(.end-date):hover{border-radius:unset!important}::ng-deep .custom-calendar .md-drppicker .calendar-table table tbody td.off{background-color:unset!important;color:#d6dae0!important}::ng-deep .custom-calendar .md-drppicker .calendar-table table tbody td.active:hover:not(.off):not(.range-picker-mode),::ng-deep .custom-calendar .md-drppicker .calendar-table table tbody td.active:not(.off):not(.range-picker-mode):not(.force-inactive){background-color:unset!important}::ng-deep .custom-calendar .md-drppicker .calendar-table table tbody td.active:hover:not(.off):not(.range-picker-mode) span,::ng-deep .custom-calendar .md-drppicker .calendar-table table tbody td.active:not(.off):not(.range-picker-mode):not(.force-inactive) span{background-color:#178dfe!important;color:#fff!important}::ng-deep .custom-calendar .md-drppicker .calendar-table table tbody td.force-inactive{background-color:unset!important;color:#5d6a82}::ng-deep .custom-calendar .md-drppicker .calendar-table table tbody td.today:not(.off) span{border:1px solid #178dfe;color:#5d6a82;height:25px!important;width:25px!important}::ng-deep .custom-calendar .md-drppicker .calendar-table table tbody td.today:not(.off).end-date:not(.force-inactive) span,::ng-deep .custom-calendar .md-drppicker .calendar-table table tbody td.today:not(.off).start-date:not(.force-inactive) span{color:#fff}.hide-ranges ::ng-deep.ranges{display:none}"]
192
+ },] }
193
+ ];
194
+ /** @nocollapse */
195
+ DatepickerComponent.ctorParameters = () => [
196
+ { type: ChangeDetectorRef }
197
+ ];
198
+ DatepickerComponent.propDecorators = {
199
+ datepickerRef: [{ type: ViewChild, args: ['datepickerRef',] }],
200
+ firstDayOfWeek: [{ type: Input }],
201
+ i18n: [{ type: Input }],
202
+ locale: [{ type: Input }],
203
+ maxDate: [{ type: Input }],
204
+ minDate: [{ type: Input }],
205
+ mode: [{ type: Input }],
206
+ selectedDate: [{ type: Input }],
207
+ selectedDates: [{ type: Input }],
208
+ selectedPeriod: [{ type: Input }],
209
+ showRanges: [{ type: Input }],
210
+ dateSelected: [{ type: Output }],
211
+ periodSelected: [{ type: Output }]
212
+ };
213
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"","sources":["../../../../../../libs/ui-components/src/lib/datepicker/datepicker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    EventEmitter,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    ViewChild\n} from '@angular/core';\nimport {DaterangepickerComponent} from \"ngx-daterangepicker-material\";\nimport moment from 'moment';\nimport {Moment} from 'moment';\n\nexport enum DatepickerMode {\n    Single = 'Single',\n    Multiple = 'Multiple',\n    Range = 'Range'\n}\n\nexport interface Period {\n    startDate: Moment;\n    endDate: Moment;\n}\n\nexport interface I18nDatePicker {\n    ranges: {\n        yesterday: string;\n        lastWeek: string;\n        last30Days: string;\n        lastMonth: string;\n        thisMonth: string;\n    }\n}\n\nenum SideEnum {\n    left = \"left\",\n    right = \"right\"\n}\n\n// TODO fix css for range mode (more lateral padding)\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    selector: 'ap-datepicker',\n    templateUrl: './datepicker.component.html',\n    styleUrls: ['./datepicker.component.scss']\n})\nexport class DatepickerComponent implements OnInit, OnChanges, AfterViewInit {\n    @ViewChild('datepickerRef') datepickerRef: DaterangepickerComponent;\n\n    @Input() firstDayOfWeek: string;\n    @Input() i18n: I18nDatePicker = {\n        ranges: {\n            yesterday: 'Yesterday',\n            lastWeek: 'Last Week',\n            last30Days: 'Last 30 days',\n            lastMonth: 'Previous month',\n            thisMonth: 'This Month',\n        }\n    };\n    @Input() locale;\n    @Input() maxDate: Moment;\n    @Input() minDate: Moment;\n    @Input() mode: DatepickerMode;\n    @Input() selectedDate: Moment;\n    @Input() selectedDates: Moment[] = [];\n    @Input() selectedPeriod: Period = {startDate: null, endDate: null};\n    @Input() showRanges: boolean;\n\n    @Output() dateSelected = new EventEmitter<any>();\n    @Output() periodSelected = new EventEmitter<Period>();\n\n    DatepickerMode = DatepickerMode;\n    doubleCalendarWidth = 528; // 231px calendar table * 2 = 462 (+ 16px x-padding * 4 = 64)\n    localeConfig: {\n        customRangeLabel: string;\n        daysOfWeek: string[];\n        monthNames: string[];\n        firstDay: number;\n    };\n    ranges: {[period: string]: [Moment, Moment]} = {};\n    rangePickerWidth = 150;\n    width: number;\n    pageSet = false;\n\n    constructor(public changeDetectorRef: ChangeDetectorRef) {}\n\n    ngOnInit() {\n        this.initRanges();\n        this.initDatePickerLocale();\n    }\n\n    ngOnChanges(changes) {\n        this.setWidth();\n        if (this.datepickerRef) {\n            setTimeout(() => {\n                this.datepickerRef.updateCalendars();\n                this.changeDetectorRef.detectChanges();\n            }, 100);\n        }\n        if (changes.selectedPeriod?.currentValue && this.datepickerRef) {\n            if (this.selectedPeriod.startDate === null && this.selectedPeriod.endDate === null) {\n                this.datepickerRef.clear();\n            } else {\n                this.datepickerRef.setStartDate(this.selectedPeriod.startDate);\n                this.datepickerRef.setEndDate(this.selectedPeriod.endDate);\n            }\n        }\n        if (changes.mode?.currentValue === DatepickerMode.Single && this.datepickerRef) {\n            this.setCalendarCurrentPage();\n        }\n    }\n    ngAfterViewInit(): void {\n        if (this.datepickerRef) {\n            setTimeout(() => {\n                this.datepickerRef.updateCalendars();\n                this.setCalendarCurrentPage();\n            }, 100);\n        }\n    }\n\n    initDatePickerLocale() {\n        if (this.locale) {\n            moment.locale(this.locale);\n        }\n        let firstDayOfWeekIndex: number;\n        if (this.firstDayOfWeek === \"sunday\") {\n            firstDayOfWeekIndex = 0;\n        } else if (this.firstDayOfWeek === \"monday\") {\n            firstDayOfWeekIndex = 1;\n        } else {\n            firstDayOfWeekIndex = moment.localeData().firstDayOfWeek();\n        }\n        this.localeConfig = {\n            customRangeLabel: 'custom',\n            daysOfWeek: moment.weekdaysMin(),\n            monthNames: moment.months(),\n            firstDay: firstDayOfWeekIndex\n        };\n    }\n\n    initRanges() {\n        this.ranges[this.i18n.ranges.yesterday] = [moment().subtract(1, 'days'), moment().subtract(1, 'days')];\n        this.ranges[this.i18n.ranges.lastWeek] = [moment().subtract(7, 'days'), moment().subtract(1, 'days')];\n        this.ranges[this.i18n.ranges.last30Days] = [moment().subtract(30, 'days'), moment().subtract(1, 'days')];\n        this.ranges[this.i18n.ranges.lastMonth] = [moment().subtract(1, 'month').startOf('month'), moment().subtract(1, 'month').endOf('month')];\n        this.ranges[this.i18n.ranges.thisMonth] = [moment().startOf('month'), moment().endOf('month')];\n    }\n\n    isCustomDate = (date: any) => {\n        const classes: string[] = [];\n        if (this.mode === DatepickerMode.Multiple) {\n            classes.push(this.isSelected(date) ? 'active' : 'force-inactive');\n        } else if (this.mode === DatepickerMode.Single) {\n            classes.push(this.selectedDate && this.selectedDate.isSame(date, 'day') ? 'active' : 'force-inactive');\n        } else if (this.mode === DatepickerMode.Range) {\n            classes.push('range-picker-mode');\n            // Workaround to fix the auto-active today date when no date is selected\n            if (moment().isSame(date, 'day')\n                && !this.selectedPeriod?.startDate\n                && !this.selectedPeriod?.endDate) {\n                classes.push('force-inactive');\n            }\n        }\n        return classes;\n    }\n\n    private isSelected(date: any) {\n        return this.selectedDates && this.selectedDates.some(selectedDate => selectedDate.isSame(date, 'day'));\n    }\n\n    onStartDateChanged(event: any) {\n        const date = event.startDate;\n        if (this.mode !== DatepickerMode.Range) {\n            this.selectedDate = date;\n            this.datepickerRef.setEndDate(date);\n            if (this.pageSet) {\n                this.pageSet = false;\n            } else {\n                this.dateSelected.emit(date.clone());\n                if (this.mode === DatepickerMode.Multiple) {\n                    this.selectedDates.push(date);\n                }\n            }\n            if (this.datepickerRef) {\n                this.datepickerRef.updateCalendars();\n            }\n        }\n    }\n\n    onDatesUpdated(event: any) {\n        if (this.mode === DatepickerMode.Range) {\n            this.periodSelected.emit({\n                startDate: event.startDate?.clone(),\n                endDate: event.endDate?.clone()\n            });\n        }\n        if (this.datepickerRef) {\n            this.datepickerRef.updateCalendars();\n        }\n    }\n\n    onNextMonth() {\n        this.datepickerRef.leftCalendar.month = this.datepickerRef.leftCalendar.month.add(1, 'months').clone();\n        this.datepickerRef.rightCalendar.month = this.datepickerRef.rightCalendar.month.add(1, 'months').clone();\n        this.datepickerRef.clickNext(SideEnum.left);\n        this.datepickerRef.clickNext(SideEnum.right);\n    }\n\n    onPreviousMonth() {\n        this.datepickerRef.leftCalendar.month = this.datepickerRef.leftCalendar.month.subtract(1, 'months').clone();\n        this.datepickerRef.rightCalendar.month = this.datepickerRef.rightCalendar.month.subtract(1, 'months').clone();\n        this.datepickerRef.clickPrev(SideEnum.left);\n        this.datepickerRef.clickPrev(SideEnum.right);\n    }\n\n    /**\n     * Ugly hack used here to open the calendar on the right day if they are selected dates\n     *      * https://github.com/fetrarij/ngx-daterangepicker-material/issues/139\n     */\n    setCalendarCurrentPage(): void {\n        const selectedFirstDate = this.selectedDates.length > 0 ? this.selectedDates[0] : this.selectedDate;\n        if (selectedFirstDate && selectedFirstDate.isValid() && this.mode !== DatepickerMode.Range) {\n            const endDate = selectedFirstDate.clone();\n            endDate.add(1, 'month');\n            this.pageSet = true;\n            this.datepickerRef.setStartDate(selectedFirstDate);\n            this.datepickerRef.setEndDate(endDate);\n            this.datepickerRef.updateView();\n        }\n        this.changeDetectorRef.detectChanges();\n    }\n\n\n    setWidth() {\n        this.width = this.showRanges && this.mode === DatepickerMode.Range ? this.doubleCalendarWidth + this.rangePickerWidth : this.doubleCalendarWidth;\n    }\n\n}\n"]}
@@ -0,0 +1,43 @@
1
+ import { Directive, ElementRef, HostListener } from '@angular/core';
2
+ /**
3
+ * expand textarea to fit content. Doesn't shrink.
4
+ */
5
+ export class AutosizeTextareaDirective {
6
+ constructor(element) {
7
+ this.element = element;
8
+ }
9
+ onInput() {
10
+ this.resize();
11
+ }
12
+ ngAfterContentChecked() {
13
+ this.resize();
14
+ }
15
+ resize() {
16
+ const style = this.element.nativeElement.style;
17
+ const scrollHeight = this.element.nativeElement.scrollHeight;
18
+ const actualHeight = this.element.nativeElement.offsetHeight;
19
+ if (AutosizeTextareaDirective.maxHeight < scrollHeight) {
20
+ // we arrived at the max
21
+ style.overflow = 'auto';
22
+ style.height = `${AutosizeTextareaDirective.maxHeight}px`;
23
+ }
24
+ else if (actualHeight < scrollHeight) {
25
+ style.overflow = 'hidden';
26
+ style.height = `${scrollHeight}px`;
27
+ }
28
+ }
29
+ }
30
+ AutosizeTextareaDirective.maxHeight = 200;
31
+ AutosizeTextareaDirective.decorators = [
32
+ { type: Directive, args: [{
33
+ selector: 'textarea[ap-autosize]'
34
+ },] }
35
+ ];
36
+ /** @nocollapse */
37
+ AutosizeTextareaDirective.ctorParameters = () => [
38
+ { type: ElementRef }
39
+ ];
40
+ AutosizeTextareaDirective.propDecorators = {
41
+ onInput: [{ type: HostListener, args: ['input',] }]
42
+ };
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0b3NpemUtdGV4dGFyZWEuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy91aS1jb21wb25lbnRzL3NyYy9saWIvZGlyZWN0aXZlcy9hdXRvc2l6ZS10ZXh0YXJlYS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUF1QixTQUFTLEVBQUUsVUFBVSxFQUFFLFlBQVksRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUt6Rjs7R0FFRztBQUNILE1BQU0sT0FBTyx5QkFBeUI7SUFJbEMsWUFBbUIsT0FBbUI7UUFBbkIsWUFBTyxHQUFQLE9BQU8sQ0FBWTtJQUFHLENBQUM7SUFHbkMsT0FBTztRQUNWLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztJQUNsQixDQUFDO0lBRU0scUJBQXFCO1FBQ3hCLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztJQUNsQixDQUFDO0lBRU0sTUFBTTtRQUNULE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQztRQUMvQyxNQUFNLFlBQVksR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxZQUFZLENBQUM7UUFDN0QsTUFBTSxZQUFZLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUMsWUFBWSxDQUFDO1FBQzdELElBQUkseUJBQXlCLENBQUMsU0FBUyxHQUFHLFlBQVksRUFBRTtZQUNwRCx3QkFBd0I7WUFDeEIsS0FBSyxDQUFDLFFBQVEsR0FBRyxNQUFNLENBQUM7WUFDeEIsS0FBSyxDQUFDLE1BQU0sR0FBRyxHQUFHLHlCQUF5QixDQUFDLFNBQVMsSUFBSSxDQUFDO1NBQzdEO2FBQU0sSUFBSSxZQUFZLEdBQUcsWUFBWSxFQUFFO1lBQ3BDLEtBQUssQ0FBQyxRQUFRLEdBQUcsUUFBUSxDQUFDO1lBQzFCLEtBQUssQ0FBQyxNQUFNLEdBQUcsR0FBRyxZQUFZLElBQUksQ0FBQztTQUN0QztJQUNMLENBQUM7O0FBekJNLG1DQUFTLEdBQVcsR0FBRyxDQUFDOztZQVJsQyxTQUFTLFNBQUM7Z0JBQ1AsUUFBUSxFQUFFLHVCQUF1QjthQUNwQzs7OztZQUp3QyxVQUFVOzs7c0JBYzlDLFlBQVksU0FBQyxPQUFPIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQWZ0ZXJDb250ZW50Q2hlY2tlZCwgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBIb3N0TGlzdGVuZXIgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICd0ZXh0YXJlYVthcC1hdXRvc2l6ZV0nXG59KVxuLyoqXG4gKiBleHBhbmQgdGV4dGFyZWEgdG8gZml0IGNvbnRlbnQuIERvZXNuJ3Qgc2hyaW5rLlxuICovXG5leHBvcnQgY2xhc3MgQXV0b3NpemVUZXh0YXJlYURpcmVjdGl2ZSBpbXBsZW1lbnRzIEFmdGVyQ29udGVudENoZWNrZWQge1xuXG4gICAgc3RhdGljIG1heEhlaWdodDogbnVtYmVyID0gMjAwO1xuXG4gICAgY29uc3RydWN0b3IocHVibGljIGVsZW1lbnQ6IEVsZW1lbnRSZWYpIHt9XG5cbiAgICBASG9zdExpc3RlbmVyKCdpbnB1dCcpXG4gICAgcHVibGljIG9uSW5wdXQoKSB7XG4gICAgICAgIHRoaXMucmVzaXplKCk7XG4gICAgfVxuXG4gICAgcHVibGljIG5nQWZ0ZXJDb250ZW50Q2hlY2tlZCgpIHtcbiAgICAgICAgdGhpcy5yZXNpemUoKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgcmVzaXplKCkge1xuICAgICAgICBjb25zdCBzdHlsZSA9IHRoaXMuZWxlbWVudC5uYXRpdmVFbGVtZW50LnN0eWxlO1xuICAgICAgICBjb25zdCBzY3JvbGxIZWlnaHQgPSB0aGlzLmVsZW1lbnQubmF0aXZlRWxlbWVudC5zY3JvbGxIZWlnaHQ7XG4gICAgICAgIGNvbnN0IGFjdHVhbEhlaWdodCA9IHRoaXMuZWxlbWVudC5uYXRpdmVFbGVtZW50Lm9mZnNldEhlaWdodDtcbiAgICAgICAgaWYgKEF1dG9zaXplVGV4dGFyZWFEaXJlY3RpdmUubWF4SGVpZ2h0IDwgc2Nyb2xsSGVpZ2h0KSB7XG4gICAgICAgICAgICAvLyB3ZSBhcnJpdmVkIGF0IHRoZSBtYXhcbiAgICAgICAgICAgIHN0eWxlLm92ZXJmbG93ID0gJ2F1dG8nO1xuICAgICAgICAgICAgc3R5bGUuaGVpZ2h0ID0gYCR7QXV0b3NpemVUZXh0YXJlYURpcmVjdGl2ZS5tYXhIZWlnaHR9cHhgO1xuICAgICAgICB9IGVsc2UgaWYgKGFjdHVhbEhlaWdodCA8IHNjcm9sbEhlaWdodCkge1xuICAgICAgICAgICAgc3R5bGUub3ZlcmZsb3cgPSAnaGlkZGVuJztcbiAgICAgICAgICAgIHN0eWxlLmhlaWdodCA9IGAke3Njcm9sbEhlaWdodH1weGA7XG4gICAgICAgIH1cbiAgICB9XG5cbn1cbiJdfQ==
@@ -0,0 +1,25 @@
1
+ import { Directive, Input } from '@angular/core';
2
+ export class DefaultImageDirective {
3
+ updateUrl() {
4
+ if (this.default) {
5
+ this.src = this.default;
6
+ }
7
+ else {
8
+ this.src = 'assets/lib-ui/img/default-avatar.png';
9
+ }
10
+ }
11
+ }
12
+ DefaultImageDirective.decorators = [
13
+ { type: Directive, args: [{
14
+ selector: 'img[default]',
15
+ host: {
16
+ '(error)': 'updateUrl()',
17
+ '[src]': 'src'
18
+ }
19
+ },] }
20
+ ];
21
+ DefaultImageDirective.propDecorators = {
22
+ src: [{ type: Input }],
23
+ default: [{ type: Input }]
24
+ };
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVmYXVsdC1pbWFnZS5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3VpLWNvbXBvbmVudHMvc3JjL2xpYi9kaXJlY3RpdmVzL2RlZmF1bHQtaW1hZ2UuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsS0FBSyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBUy9DLE1BQU0sT0FBTyxxQkFBcUI7SUFJOUIsU0FBUztRQUNMLElBQUksSUFBSSxDQUFDLE9BQU8sRUFBRTtZQUNkLElBQUksQ0FBQyxHQUFHLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQztTQUMzQjthQUFNO1lBQ0gsSUFBSSxDQUFDLEdBQUcsR0FBRyxzQ0FBc0MsQ0FBQztTQUNyRDtJQUNMLENBQUM7OztZQWpCSixTQUFTLFNBQUM7Z0JBQ1AsUUFBUSxFQUFFLGNBQWM7Z0JBQ3hCLElBQUksRUFBRTtvQkFDRixTQUFTLEVBQUUsYUFBYTtvQkFDeEIsT0FBTyxFQUFFLEtBQUs7aUJBQ2pCO2FBQ0o7OztrQkFFSSxLQUFLO3NCQUNMLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0RpcmVjdGl2ZSwgSW5wdXR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogJ2ltZ1tkZWZhdWx0XScsXG4gICAgaG9zdDoge1xuICAgICAgICAnKGVycm9yKSc6ICd1cGRhdGVVcmwoKScsXG4gICAgICAgICdbc3JjXSc6ICdzcmMnXG4gICAgfVxufSlcbmV4cG9ydCBjbGFzcyBEZWZhdWx0SW1hZ2VEaXJlY3RpdmUge1xuICAgIEBJbnB1dCgpIHNyYzogc3RyaW5nO1xuICAgIEBJbnB1dCgpIGRlZmF1bHQ6IHN0cmluZztcblxuICAgIHVwZGF0ZVVybCgpIHtcbiAgICAgICAgaWYgKHRoaXMuZGVmYXVsdCkge1xuICAgICAgICAgICAgdGhpcy5zcmMgPSB0aGlzLmRlZmF1bHQ7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB0aGlzLnNyYyA9ICdhc3NldHMvbGliLXVpL2ltZy9kZWZhdWx0LWF2YXRhci5wbmcnO1xuICAgICAgICB9XG4gICAgfVxufVxuIl19
@@ -0,0 +1,82 @@
1
+ import { Directive, ElementRef, EventEmitter, Input, Output, } from '@angular/core';
2
+ /**
3
+ * Removes excess text from element until it fits in elements
4
+ * and appends a ellipsis symbol to end of text. This requires that
5
+ * the elements height be fixed
6
+ *
7
+ * @example
8
+ * ```html
9
+ * <p apEllipsis>Ullamco esse laborum</p>
10
+ * ```
11
+ *
12
+ */
13
+ export class EllipsisDirective {
14
+ constructor(el) {
15
+ this.el = el;
16
+ this.apEllipsisClip = false;
17
+ this.apEllipsisChar = '...';
18
+ this.apEllipsisClickable = false;
19
+ this.apEllipsisRemovedElementsCount = new EventEmitter();
20
+ this.apEllipsisRemovedText = new EventEmitter();
21
+ }
22
+ get hasOverflow() {
23
+ const el = this.el.nativeElement;
24
+ return (el.scrollHeight > el.offsetHeight) || (el.scrollWidth > el.offsetWidth);
25
+ }
26
+ ngAfterContentChecked() {
27
+ this.clipText();
28
+ }
29
+ clipText() {
30
+ const el = this.el.nativeElement;
31
+ let text = el.innerText;
32
+ let removedText = '';
33
+ if (this.apEllipsisIndex > -1) {
34
+ removedText = text.substring(this.apEllipsisIndex, text.length - 1) + removedText;
35
+ text = text.substring(0, this.apEllipsisIndex);
36
+ el.innerText = `${text}${this.apEllipsisChar}`;
37
+ if (this.apEllipsisClickable) {
38
+ el.addEventListener('click', () => {
39
+ el.innerText = `${text}${removedText}`;
40
+ });
41
+ }
42
+ }
43
+ else {
44
+ while (this.hasOverflow && text.length > 0) {
45
+ removedText = text[text.length - 1] + removedText;
46
+ text = text.substring(0, text.length - 1);
47
+ el.innerText = `${text}${this.apEllipsisChar}`;
48
+ }
49
+ }
50
+ if (this.apEllipsisSeparator) {
51
+ const removedElementsCount = removedText.split(this.apEllipsisSeparator)
52
+ .filter(element => !!element && element.length > 0).length;
53
+ if (removedElementsCount > 0) {
54
+ this.apEllipsisRemovedElementsCount.emit(removedElementsCount);
55
+ }
56
+ }
57
+ if (removedText && removedText.length > 0) {
58
+ this.apEllipsisRemovedText.emit(removedText);
59
+ }
60
+ }
61
+ handleReadmore() {
62
+ }
63
+ }
64
+ EllipsisDirective.decorators = [
65
+ { type: Directive, args: [{
66
+ selector: '[apEllipsis]',
67
+ },] }
68
+ ];
69
+ /** @nocollapse */
70
+ EllipsisDirective.ctorParameters = () => [
71
+ { type: ElementRef }
72
+ ];
73
+ EllipsisDirective.propDecorators = {
74
+ apEllipsisSeparator: [{ type: Input }],
75
+ apEllipsisClip: [{ type: Input }],
76
+ apEllipsisIndex: [{ type: Input }],
77
+ apEllipsisChar: [{ type: Input }],
78
+ apEllipsisClickable: [{ type: Input }],
79
+ apEllipsisRemovedElementsCount: [{ type: Output }],
80
+ apEllipsisRemovedText: [{ type: Output }]
81
+ };
82
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxsaXBzaXMuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy91aS1jb21wb25lbnRzL3NyYy9saWIvZGlyZWN0aXZlcy9lbGxpcHNpcy5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFzQixTQUFTLEVBQUUsVUFBVSxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxHQUFFLE1BQU0sZUFBZSxDQUFDO0FBRXZHOzs7Ozs7Ozs7O0dBVUc7QUFJSCxNQUFNLE9BQU8saUJBQWlCO0lBZ0IxQixZQUFvQixFQUFjO1FBQWQsT0FBRSxHQUFGLEVBQUUsQ0FBWTtRQWJ6QixtQkFBYyxHQUFZLEtBQUssQ0FBQztRQUVoQyxtQkFBYyxHQUFXLEtBQUssQ0FBQztRQUMvQix3QkFBbUIsR0FBWSxLQUFLLENBQUM7UUFFcEMsbUNBQThCLEdBQUcsSUFBSSxZQUFZLEVBQVUsQ0FBQztRQUM1RCwwQkFBcUIsR0FBRyxJQUFJLFlBQVksRUFBVSxDQUFDO0lBT3ZCLENBQUM7SUFMdkMsSUFBWSxXQUFXO1FBQ25CLE1BQU0sRUFBRSxHQUFnQixJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQztRQUM5QyxPQUFPLENBQUMsRUFBRSxDQUFDLFlBQVksR0FBRyxFQUFFLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsV0FBVyxHQUFHLEVBQUUsQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUNwRixDQUFDO0lBSUQscUJBQXFCO1FBQ2pCLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQztJQUNwQixDQUFDO0lBRU8sUUFBUTtRQUNaLE1BQU0sRUFBRSxHQUFnQixJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQztRQUM5QyxJQUFJLElBQUksR0FBRyxFQUFFLENBQUMsU0FBUyxDQUFDO1FBQ3hCLElBQUksV0FBVyxHQUFHLEVBQUUsQ0FBQztRQUNyQixJQUFJLElBQUksQ0FBQyxlQUFlLEdBQUcsQ0FBQyxDQUFDLEVBQUU7WUFDM0IsV0FBVyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLGVBQWUsRUFBRSxJQUFJLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxHQUFHLFdBQVcsQ0FBQztZQUNsRixJQUFJLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLEVBQUUsSUFBSSxDQUFDLGVBQWUsQ0FBQyxDQUFDO1lBQy9DLEVBQUUsQ0FBQyxTQUFTLEdBQUcsR0FBRyxJQUFJLEdBQUcsSUFBSSxDQUFDLGNBQWMsRUFBRSxDQUFDO1lBRS9DLElBQUksSUFBSSxDQUFDLG1CQUFtQixFQUFFO2dCQUMxQixFQUFFLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxFQUFFLEdBQUcsRUFBRTtvQkFDOUIsRUFBRSxDQUFDLFNBQVMsR0FBRyxHQUFHLElBQUksR0FBRyxXQUFXLEVBQUUsQ0FBQztnQkFDM0MsQ0FBQyxDQUFDLENBQUM7YUFDTjtTQUNKO2FBQU07WUFDSCxPQUFPLElBQUksQ0FBQyxXQUFXLElBQUksSUFBSSxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUU7Z0JBQ3hDLFdBQVcsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUMsR0FBRyxXQUFXLENBQUM7Z0JBQ2xELElBQUksR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsRUFBRSxJQUFJLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDO2dCQUMxQyxFQUFFLENBQUMsU0FBUyxHQUFHLEdBQUcsSUFBSSxHQUFHLElBQUksQ0FBQyxjQUFjLEVBQUUsQ0FBQzthQUNsRDtTQUNKO1FBRUQsSUFBSSxJQUFJLENBQUMsbUJBQW1CLEVBQUU7WUFDMUIsTUFBTSxvQkFBb0IsR0FBRyxXQUFXLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxtQkFBbUIsQ0FBQztpQkFDbkUsTUFBTSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLE9BQU8sSUFBSSxPQUFPLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQztZQUMvRCxJQUFJLG9CQUFvQixHQUFHLENBQUMsRUFBRTtnQkFDMUIsSUFBSSxDQUFDLDhCQUE4QixDQUFDLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO2FBQ2xFO1NBQ0o7UUFDRCxJQUFJLFdBQVcsSUFBSSxXQUFXLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRTtZQUN2QyxJQUFJLENBQUMscUJBQXFCLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1NBQ2hEO0lBQ0wsQ0FBQztJQUVPLGNBQWM7SUFFdEIsQ0FBQzs7O1lBN0RKLFNBQVMsU0FBQztnQkFDUCxRQUFRLEVBQUUsY0FBYzthQUMzQjs7OztZQWZ1QyxVQUFVOzs7a0NBa0I3QyxLQUFLOzZCQUNMLEtBQUs7OEJBQ0wsS0FBSzs2QkFDTCxLQUFLO2tDQUNMLEtBQUs7NkNBRUwsTUFBTTtvQ0FDTixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtBZnRlckNvbnRlbnRDaGVja2VkLCBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCx9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIFJlbW92ZXMgZXhjZXNzIHRleHQgZnJvbSBlbGVtZW50IHVudGlsIGl0IGZpdHMgaW4gZWxlbWVudHNcbiAqIGFuZCBhcHBlbmRzIGEgZWxsaXBzaXMgc3ltYm9sIHRvIGVuZCBvZiB0ZXh0LiBUaGlzIHJlcXVpcmVzIHRoYXRcbiAqIHRoZSBlbGVtZW50cyBoZWlnaHQgYmUgZml4ZWRcbiAqXG4gKiBAZXhhbXBsZVxuICogYGBgaHRtbFxuICogPHAgYXBFbGxpcHNpcz5VbGxhbWNvIGVzc2UgbGFib3J1bTwvcD5cbiAqIGBgYFxuICpcbiAqL1xuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICdbYXBFbGxpcHNpc10nLFxufSlcbmV4cG9ydCBjbGFzcyBFbGxpcHNpc0RpcmVjdGl2ZSBpbXBsZW1lbnRzIEFmdGVyQ29udGVudENoZWNrZWQge1xuXG4gICAgQElucHV0KCkgYXBFbGxpcHNpc1NlcGFyYXRvcjogc3RyaW5nO1xuICAgIEBJbnB1dCgpIGFwRWxsaXBzaXNDbGlwOiBib29sZWFuID0gZmFsc2U7XG4gICAgQElucHV0KCkgYXBFbGxpcHNpc0luZGV4OiBudW1iZXI7XG4gICAgQElucHV0KCkgYXBFbGxpcHNpc0NoYXI6IHN0cmluZyA9ICcuLi4nO1xuICAgIEBJbnB1dCgpIGFwRWxsaXBzaXNDbGlja2FibGU6IGJvb2xlYW4gPSBmYWxzZTtcblxuICAgIEBPdXRwdXQoKSBhcEVsbGlwc2lzUmVtb3ZlZEVsZW1lbnRzQ291bnQgPSBuZXcgRXZlbnRFbWl0dGVyPG51bWJlcj4oKTtcbiAgICBAT3V0cHV0KCkgYXBFbGxpcHNpc1JlbW92ZWRUZXh0ID0gbmV3IEV2ZW50RW1pdHRlcjxzdHJpbmc+KCk7XG5cbiAgICBwcml2YXRlIGdldCBoYXNPdmVyZmxvdygpOiBib29sZWFuIHtcbiAgICAgICAgY29uc3QgZWw6IEhUTUxFbGVtZW50ID0gdGhpcy5lbC5uYXRpdmVFbGVtZW50O1xuICAgICAgICByZXR1cm4gKGVsLnNjcm9sbEhlaWdodCA+IGVsLm9mZnNldEhlaWdodCkgfHwgKGVsLnNjcm9sbFdpZHRoID4gZWwub2Zmc2V0V2lkdGgpO1xuICAgIH1cblxuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgZWw6IEVsZW1lbnRSZWYpIHsgfVxuXG4gICAgbmdBZnRlckNvbnRlbnRDaGVja2VkKCkge1xuICAgICAgICB0aGlzLmNsaXBUZXh0KCk7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBjbGlwVGV4dCgpOiB2b2lkIHtcbiAgICAgICAgY29uc3QgZWw6IEhUTUxFbGVtZW50ID0gdGhpcy5lbC5uYXRpdmVFbGVtZW50O1xuICAgICAgICBsZXQgdGV4dCA9IGVsLmlubmVyVGV4dDtcbiAgICAgICAgbGV0IHJlbW92ZWRUZXh0ID0gJyc7XG4gICAgICAgIGlmICh0aGlzLmFwRWxsaXBzaXNJbmRleCA+IC0xKSB7XG4gICAgICAgICAgICByZW1vdmVkVGV4dCA9IHRleHQuc3Vic3RyaW5nKHRoaXMuYXBFbGxpcHNpc0luZGV4LCB0ZXh0Lmxlbmd0aCAtIDEpICsgcmVtb3ZlZFRleHQ7XG4gICAgICAgICAgICB0ZXh0ID0gdGV4dC5zdWJzdHJpbmcoMCwgdGhpcy5hcEVsbGlwc2lzSW5kZXgpO1xuICAgICAgICAgICAgZWwuaW5uZXJUZXh0ID0gYCR7dGV4dH0ke3RoaXMuYXBFbGxpcHNpc0NoYXJ9YDtcblxuICAgICAgICAgICAgaWYgKHRoaXMuYXBFbGxpcHNpc0NsaWNrYWJsZSkge1xuICAgICAgICAgICAgICAgIGVsLmFkZEV2ZW50TGlzdGVuZXIoJ2NsaWNrJywgKCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICBlbC5pbm5lclRleHQgPSBgJHt0ZXh0fSR7cmVtb3ZlZFRleHR9YDtcbiAgICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHdoaWxlICh0aGlzLmhhc092ZXJmbG93ICYmIHRleHQubGVuZ3RoID4gMCkge1xuICAgICAgICAgICAgICAgIHJlbW92ZWRUZXh0ID0gdGV4dFt0ZXh0Lmxlbmd0aCAtIDFdICsgcmVtb3ZlZFRleHQ7XG4gICAgICAgICAgICAgICAgdGV4dCA9IHRleHQuc3Vic3RyaW5nKDAsIHRleHQubGVuZ3RoIC0gMSk7XG4gICAgICAgICAgICAgICAgZWwuaW5uZXJUZXh0ID0gYCR7dGV4dH0ke3RoaXMuYXBFbGxpcHNpc0NoYXJ9YDtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuXG4gICAgICAgIGlmICh0aGlzLmFwRWxsaXBzaXNTZXBhcmF0b3IpIHtcbiAgICAgICAgICAgIGNvbnN0IHJlbW92ZWRFbGVtZW50c0NvdW50ID0gcmVtb3ZlZFRleHQuc3BsaXQodGhpcy5hcEVsbGlwc2lzU2VwYXJhdG9yKVxuICAgICAgICAgICAgICAgIC5maWx0ZXIoZWxlbWVudCA9PiAhIWVsZW1lbnQgJiYgZWxlbWVudC5sZW5ndGggPiAwKS5sZW5ndGg7XG4gICAgICAgICAgICBpZiAocmVtb3ZlZEVsZW1lbnRzQ291bnQgPiAwKSB7XG4gICAgICAgICAgICAgICAgdGhpcy5hcEVsbGlwc2lzUmVtb3ZlZEVsZW1lbnRzQ291bnQuZW1pdChyZW1vdmVkRWxlbWVudHNDb3VudCk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgICAgaWYgKHJlbW92ZWRUZXh0ICYmIHJlbW92ZWRUZXh0Lmxlbmd0aCA+IDApIHtcbiAgICAgICAgICAgIHRoaXMuYXBFbGxpcHNpc1JlbW92ZWRUZXh0LmVtaXQocmVtb3ZlZFRleHQpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBoYW5kbGVSZWFkbW9yZSgpOiB2b2lkIHtcblxuICAgIH1cbn1cbiJdfQ==
@@ -0,0 +1,53 @@
1
+ // Based on https://scotch.io/tutorials/how-to-implement-a-custom-validator-directive-confirm-password-in-angular-2
2
+ import { Directive, forwardRef, Attribute } from '@angular/core';
3
+ import { NG_VALIDATORS } from '@angular/forms';
4
+ export class EqualValidatorDirective {
5
+ constructor(validateEqual, validateEqualReference) {
6
+ this.validateEqual = validateEqual;
7
+ this.validateEqualReference = validateEqualReference;
8
+ }
9
+ validate(self) {
10
+ let other = self.root.get(this.validateEqual);
11
+ if (other) {
12
+ if (this.isReference()) {
13
+ if (self.value === other.value) {
14
+ delete other.errors['validateEqual'];
15
+ if (!Object.keys(other.errors).length) {
16
+ other.setErrors(null);
17
+ }
18
+ }
19
+ else {
20
+ other.setErrors({ validateEqual: false });
21
+ }
22
+ }
23
+ else if (self.value !== other.value) {
24
+ return { validateEqual: false };
25
+ }
26
+ }
27
+ return null;
28
+ }
29
+ isReference() {
30
+ if (!this.validateEqualReference) {
31
+ return false;
32
+ }
33
+ return this.validateEqualReference === 'true';
34
+ }
35
+ }
36
+ EqualValidatorDirective.decorators = [
37
+ { type: Directive, args: [{
38
+ selector: '[validateEqual][formControlName],[validateEqual][formControl],[validateEqual][ngModel]',
39
+ providers: [
40
+ {
41
+ provide: NG_VALIDATORS,
42
+ useExisting: forwardRef(() => EqualValidatorDirective),
43
+ multi: true
44
+ }
45
+ ]
46
+ },] }
47
+ ];
48
+ /** @nocollapse */
49
+ EqualValidatorDirective.ctorParameters = () => [
50
+ { type: String, decorators: [{ type: Attribute, args: ['validateEqual',] }] },
51
+ { type: String, decorators: [{ type: Attribute, args: ['validateEqualReference',] }] }
52
+ ];
53
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXF1YWwtdmFsaWRhdG9yLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvdWktY29tcG9uZW50cy9zcmMvbGliL2RpcmVjdGl2ZXMvZXF1YWwtdmFsaWRhdG9yLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxtSEFBbUg7QUFDbkgsT0FBTyxFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2pFLE9BQU8sRUFBOEIsYUFBYSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFZM0UsTUFBTSxPQUFPLHVCQUF1QjtJQUVoQyxZQUErQyxhQUFxQixFQUNaLHNCQUE4QjtRQUR2QyxrQkFBYSxHQUFiLGFBQWEsQ0FBUTtRQUNaLDJCQUFzQixHQUF0QixzQkFBc0IsQ0FBUTtJQUFHLENBQUM7SUFFMUYsUUFBUSxDQUFDLElBQXFCO1FBQzFCLElBQUksS0FBSyxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUM5QyxJQUFJLEtBQUssRUFBRTtZQUNQLElBQUksSUFBSSxDQUFDLFdBQVcsRUFBRSxFQUFFO2dCQUNwQixJQUFJLElBQUksQ0FBQyxLQUFLLEtBQUssS0FBSyxDQUFDLEtBQUssRUFBRTtvQkFDNUIsT0FBTyxLQUFLLENBQUMsTUFBTSxDQUFDLGVBQWUsQ0FBQyxDQUFDO29CQUNyQyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUMsTUFBTSxFQUFFO3dCQUNuQyxLQUFLLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxDQUFDO3FCQUN6QjtpQkFDSjtxQkFBTTtvQkFDSCxLQUFLLENBQUMsU0FBUyxDQUFDLEVBQUUsYUFBYSxFQUFFLEtBQUssRUFBRSxDQUFDLENBQUM7aUJBQzdDO2FBQ0o7aUJBQU0sSUFBSSxJQUFJLENBQUMsS0FBSyxLQUFLLEtBQUssQ0FBQyxLQUFLLEVBQUU7Z0JBQ25DLE9BQU8sRUFBRSxhQUFhLEVBQUUsS0FBSyxFQUFFLENBQUM7YUFDbkM7U0FDSjtRQUNELE9BQU8sSUFBSSxDQUFDO0lBQ2hCLENBQUM7SUFFTyxXQUFXO1FBQ2YsSUFBSSxDQUFDLElBQUksQ0FBQyxzQkFBc0IsRUFBRTtZQUM5QixPQUFPLEtBQUssQ0FBQztTQUNoQjtRQUNELE9BQU8sSUFBSSxDQUFDLHNCQUFzQixLQUFLLE1BQU0sQ0FBQztJQUNsRCxDQUFDOzs7WUF2Q0osU0FBUyxTQUFDO2dCQUNQLFFBQVEsRUFBRSx3RkFBd0Y7Z0JBQ2xHLFNBQVMsRUFBRTtvQkFDUDt3QkFDSSxPQUFPLEVBQUUsYUFBYTt3QkFDdEIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyx1QkFBdUIsQ0FBQzt3QkFDdEQsS0FBSyxFQUFFLElBQUk7cUJBQ2Q7aUJBQ0o7YUFDSjs7Ozt5Q0FHZ0IsU0FBUyxTQUFDLGVBQWU7eUNBQ3pCLFNBQVMsU0FBQyx3QkFBd0IiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBCYXNlZCBvbiBodHRwczovL3Njb3RjaC5pby90dXRvcmlhbHMvaG93LXRvLWltcGxlbWVudC1hLWN1c3RvbS12YWxpZGF0b3ItZGlyZWN0aXZlLWNvbmZpcm0tcGFzc3dvcmQtaW4tYW5ndWxhci0yXG5pbXBvcnQgeyBEaXJlY3RpdmUsIGZvcndhcmRSZWYsIEF0dHJpYnV0ZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgVmFsaWRhdG9yLCBBYnN0cmFjdENvbnRyb2wsIE5HX1ZBTElEQVRPUlMgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAnW3ZhbGlkYXRlRXF1YWxdW2Zvcm1Db250cm9sTmFtZV0sW3ZhbGlkYXRlRXF1YWxdW2Zvcm1Db250cm9sXSxbdmFsaWRhdGVFcXVhbF1bbmdNb2RlbF0nLFxuICAgIHByb3ZpZGVyczogW1xuICAgICAgICB7XG4gICAgICAgICAgICBwcm92aWRlOiBOR19WQUxJREFUT1JTLFxuICAgICAgICAgICAgdXNlRXhpc3Rpbmc6IGZvcndhcmRSZWYoKCkgPT4gRXF1YWxWYWxpZGF0b3JEaXJlY3RpdmUpLFxuICAgICAgICAgICAgbXVsdGk6IHRydWVcbiAgICAgICAgfVxuICAgIF1cbn0pXG5leHBvcnQgY2xhc3MgRXF1YWxWYWxpZGF0b3JEaXJlY3RpdmUgaW1wbGVtZW50cyBWYWxpZGF0b3Ige1xuXG4gICAgY29uc3RydWN0b3IoQEF0dHJpYnV0ZSgndmFsaWRhdGVFcXVhbCcpIHB1YmxpYyB2YWxpZGF0ZUVxdWFsOiBzdHJpbmcsXG4gICAgICAgICAgICAgICAgQEF0dHJpYnV0ZSgndmFsaWRhdGVFcXVhbFJlZmVyZW5jZScpIHB1YmxpYyB2YWxpZGF0ZUVxdWFsUmVmZXJlbmNlOiBzdHJpbmcpIHt9XG5cbiAgICB2YWxpZGF0ZShzZWxmOiBBYnN0cmFjdENvbnRyb2wpOiB7IFtrZXk6IHN0cmluZ106IGFueSB9IHtcbiAgICAgICAgbGV0IG90aGVyID0gc2VsZi5yb290LmdldCh0aGlzLnZhbGlkYXRlRXF1YWwpO1xuICAgICAgICBpZiAob3RoZXIpIHtcbiAgICAgICAgICAgIGlmICh0aGlzLmlzUmVmZXJlbmNlKCkpIHtcbiAgICAgICAgICAgICAgICBpZiAoc2VsZi52YWx1ZSA9PT0gb3RoZXIudmFsdWUpIHtcbiAgICAgICAgICAgICAgICAgICAgZGVsZXRlIG90aGVyLmVycm9yc1sndmFsaWRhdGVFcXVhbCddO1xuICAgICAgICAgICAgICAgICAgICBpZiAoIU9iamVjdC5rZXlzKG90aGVyLmVycm9ycykubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICBvdGhlci5zZXRFcnJvcnMobnVsbCk7XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgICAgICBvdGhlci5zZXRFcnJvcnMoeyB2YWxpZGF0ZUVxdWFsOiBmYWxzZSB9KTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9IGVsc2UgaWYgKHNlbGYudmFsdWUgIT09IG90aGVyLnZhbHVlKSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIHsgdmFsaWRhdGVFcXVhbDogZmFsc2UgfTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gbnVsbDtcbiAgICB9XG5cbiAgICBwcml2YXRlIGlzUmVmZXJlbmNlKCk6IGJvb2xlYW4ge1xuICAgICAgICBpZiAoIXRoaXMudmFsaWRhdGVFcXVhbFJlZmVyZW5jZSkge1xuICAgICAgICAgICAgcmV0dXJuIGZhbHNlO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiB0aGlzLnZhbGlkYXRlRXF1YWxSZWZlcmVuY2UgPT09ICd0cnVlJztcbiAgICB9XG5cbn1cbiJdfQ==