@dsivd/prestations-ng 15.2.2 → 15.2.3-beta11

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 (198) hide show
  1. package/CHANGELOG.md +31 -0
  2. package/dsivd-prestations-ng-v15.2.3-beta11.tgz +0 -0
  3. package/esm2020/abstract-page-component.mjs +4 -4
  4. package/esm2020/directives/currency-formatter.directive.mjs +4 -4
  5. package/esm2020/directives/formatter.module.mjs +5 -5
  6. package/esm2020/directives/iban-formatter.directive.mjs +4 -4
  7. package/esm2020/directives/ide-formatter.directive.mjs +4 -4
  8. package/esm2020/directives/ndc-formatter.directive.mjs +4 -4
  9. package/esm2020/foehn-address/foehn-address.module.mjs +5 -5
  10. package/esm2020/foehn-address/foehn-display-address.component.mjs +4 -4
  11. package/esm2020/foehn-address/foehn-input-address.component.mjs +4 -4
  12. package/esm2020/foehn-address/foehn-input-foreign-locality.component.mjs +4 -4
  13. package/esm2020/foehn-address/foehn-input-foreign-street.component.mjs +4 -4
  14. package/esm2020/foehn-agenda/foehn-agenda-navigation/foehn-agenda-navigation.component.mjs +4 -4
  15. package/esm2020/foehn-agenda/foehn-agenda-timeslot-panel/foehn-agenda-timeslot-panel.component.mjs +4 -4
  16. package/esm2020/foehn-agenda/foehn-agenda.component.mjs +4 -4
  17. package/esm2020/foehn-agenda/foehn-agenda.module.mjs +5 -5
  18. package/esm2020/foehn-autocomplete/foehn-autocomplete.component.mjs +4 -4
  19. package/esm2020/foehn-autocomplete/foehn-autocomplete.module.mjs +5 -5
  20. package/esm2020/foehn-boolean/foehn-boolean-checkbox.component.mjs +4 -4
  21. package/esm2020/foehn-boolean/foehn-boolean-radio.component.mjs +4 -4
  22. package/esm2020/foehn-boolean/foehn-boolean.module.mjs +5 -5
  23. package/esm2020/foehn-breadcrumb/breadcrumb-event.service.mjs +4 -4
  24. package/esm2020/foehn-breadcrumb/foehn-breadcrumb.component.mjs +4 -4
  25. package/esm2020/foehn-breadcrumb/foehn-breadcrumb.module.mjs +5 -5
  26. package/esm2020/foehn-checkables/foehn-checkable-group.component.mjs +4 -4
  27. package/esm2020/foehn-checkables/foehn-checkables.module.mjs +5 -5
  28. package/esm2020/foehn-checkables/foehn-checkbox.component.mjs +4 -4
  29. package/esm2020/foehn-checkables/foehn-radio.component.mjs +4 -4
  30. package/esm2020/foehn-checkables/foehn-select.component.mjs +4 -4
  31. package/esm2020/foehn-confirm-modal/foehn-confirm-modal.component.mjs +4 -4
  32. package/esm2020/foehn-confirm-modal/foehn-confirm-modal.module.mjs +5 -5
  33. package/esm2020/foehn-confirm-modal/foehn-confirm-modal.service.mjs +4 -4
  34. package/esm2020/foehn-date-picker/foehn-date-picker.component.mjs +4 -4
  35. package/esm2020/foehn-date-picker/foehn-date-picker.module.mjs +5 -5
  36. package/esm2020/foehn-date-picker-button/foehn-date-picker-button.component.mjs +4 -4
  37. package/esm2020/foehn-date-picker-button/foehn-date-picker-button.module.mjs +5 -5
  38. package/esm2020/foehn-debug-summary/foehn-debug-summary.component.mjs +4 -4
  39. package/esm2020/foehn-debug-summary/foehn-debug-summary.component.module.mjs +5 -5
  40. package/esm2020/foehn-decision-electronique/foehn-decision-electronique.component.mjs +4 -4
  41. package/esm2020/foehn-decision-electronique/foehn-decision-electronique.module.mjs +5 -5
  42. package/esm2020/foehn-footer/foehn-footer.component.mjs +4 -4
  43. package/esm2020/foehn-footer/foehn-footer.module.mjs +5 -5
  44. package/esm2020/foehn-form/foehn-form.component.mjs +4 -4
  45. package/esm2020/foehn-form/foehn-form.module.mjs +5 -5
  46. package/esm2020/foehn-growl/foehn-growl.component.mjs +4 -4
  47. package/esm2020/foehn-growl/foehn-growl.module.mjs +5 -5
  48. package/esm2020/foehn-growl/growl-broker.service.mjs +4 -4
  49. package/esm2020/foehn-header/foehn-header.component.mjs +4 -4
  50. package/esm2020/foehn-header/foehn-header.module.mjs +5 -5
  51. package/esm2020/foehn-header/foehn-skip-link.component.mjs +4 -4
  52. package/esm2020/foehn-help-modal/foehn-help-modal.component.mjs +4 -4
  53. package/esm2020/foehn-help-modal/foehn-help-modal.module.mjs +5 -5
  54. package/esm2020/foehn-icons/abstract-icon-component.mjs +4 -4
  55. package/esm2020/foehn-icons/foehn-icon-calendar.component.mjs +4 -4
  56. package/esm2020/foehn-icons/foehn-icon-check-square-o.component.mjs +4 -4
  57. package/esm2020/foehn-icons/foehn-icon-check.component.mjs +4 -4
  58. package/esm2020/foehn-icons/foehn-icon-chevron-down.component.mjs +4 -4
  59. package/esm2020/foehn-icons/foehn-icon-chevron-left.component.mjs +4 -4
  60. package/esm2020/foehn-icons/foehn-icon-chevron-right.component.mjs +4 -4
  61. package/esm2020/foehn-icons/foehn-icon-chevron-up.component.mjs +4 -4
  62. package/esm2020/foehn-icons/foehn-icon-clock.component.mjs +4 -4
  63. package/esm2020/foehn-icons/foehn-icon-comment-dots.component.mjs +4 -4
  64. package/esm2020/foehn-icons/foehn-icon-edit.component.mjs +4 -4
  65. package/esm2020/foehn-icons/foehn-icon-external-link-alt.component.mjs +4 -4
  66. package/esm2020/foehn-icons/foehn-icon-file-pdf.component.mjs +4 -4
  67. package/esm2020/foehn-icons/foehn-icon-info-circle.component.mjs +4 -4
  68. package/esm2020/foehn-icons/foehn-icon-lock.component.mjs +4 -4
  69. package/esm2020/foehn-icons/foehn-icon-map-marker.component.mjs +4 -4
  70. package/esm2020/foehn-icons/foehn-icon-minus-circle.component.mjs +4 -4
  71. package/esm2020/foehn-icons/foehn-icon-plus-circle.component.mjs +4 -4
  72. package/esm2020/foehn-icons/foehn-icon-plus-square.component.mjs +4 -4
  73. package/esm2020/foehn-icons/foehn-icon-search.component.mjs +4 -4
  74. package/esm2020/foehn-icons/foehn-icon-times.component.mjs +4 -4
  75. package/esm2020/foehn-icons/foehn-icon-trash-alt.component.mjs +4 -4
  76. package/esm2020/foehn-icons/foehn-icon-unlock-alt.component.mjs +4 -4
  77. package/esm2020/foehn-icons/foehn-icons.module.mjs +5 -5
  78. package/esm2020/foehn-input/foehn-input-email.component.mjs +4 -4
  79. package/esm2020/foehn-input/foehn-input-hidden.component.mjs +4 -4
  80. package/esm2020/foehn-input/foehn-input-number.component.mjs +60 -13
  81. package/esm2020/foehn-input/foehn-input-password.component.mjs +4 -4
  82. package/esm2020/foehn-input/foehn-input-phone.component.mjs +4 -4
  83. package/esm2020/foehn-input/foehn-input-string.component.mjs +4 -4
  84. package/esm2020/foehn-input/foehn-input-text.component.mjs +4 -4
  85. package/esm2020/foehn-input/foehn-input-textarea.component.mjs +4 -4
  86. package/esm2020/foehn-input/foehn-input.component.mjs +4 -4
  87. package/esm2020/foehn-input/foehn-input.module.mjs +5 -5
  88. package/esm2020/foehn-input-date/foehn-input-date.component.mjs +6 -6
  89. package/esm2020/foehn-input-time/foehn-input-time.component.mjs +6 -6
  90. package/esm2020/foehn-list/foehn-list.component.mjs +4 -4
  91. package/esm2020/foehn-list/foehn-list.module.mjs +5 -5
  92. package/esm2020/foehn-menu-prestation/abstract-list-item-detail-page.component.mjs +4 -4
  93. package/esm2020/foehn-menu-prestation/abstract-menu-page.component.mjs +4 -4
  94. package/esm2020/foehn-menu-prestation/abstract-page-from-menu.component.mjs +4 -4
  95. package/esm2020/foehn-menu-prestation/foehn-error-pill/foehn-error-pill.component.mjs +4 -4
  96. package/esm2020/foehn-menu-prestation/foehn-list-summary/foehn-list-summary.component.mjs +4 -4
  97. package/esm2020/foehn-menu-prestation/foehn-menu-items/foehn-menu-item/foehn-menu-item.component.mjs +4 -4
  98. package/esm2020/foehn-menu-prestation/foehn-menu-items/foehn-menu-item-transmit/foehn-menu-item-transmit.component.mjs +4 -4
  99. package/esm2020/foehn-menu-prestation/foehn-menu-prestation.module.mjs +5 -5
  100. package/esm2020/foehn-misc/foehn-abbr.component.mjs +4 -4
  101. package/esm2020/foehn-misc/foehn-misc.module.mjs +5 -5
  102. package/esm2020/foehn-modal/foehn-modal.component.mjs +4 -7
  103. package/esm2020/foehn-modal/foehn-modal.module.mjs +5 -5
  104. package/esm2020/foehn-multiselect-autocomplete/foehn-multiselect-autocomplete.component.mjs +4 -4
  105. package/esm2020/foehn-multiselect-autocomplete/foehn-multiselect-autocomplete.module.mjs +5 -5
  106. package/esm2020/foehn-nav13/foehn-input-nav13.component.mjs +6 -6
  107. package/esm2020/foehn-nav13/foehn-input-nav13.module.mjs +5 -5
  108. package/esm2020/foehn-navigation/foehn-navigation.component.mjs +4 -4
  109. package/esm2020/foehn-navigation/foehn-navigation.module.mjs +5 -5
  110. package/esm2020/foehn-navigation/foehn-navigation.service.mjs +4 -4
  111. package/esm2020/foehn-notfound/foehn-notfound.component.mjs +4 -4
  112. package/esm2020/foehn-notfound/foehn-notfound.module.mjs +5 -5
  113. package/esm2020/foehn-page/foehn-page-counter.component.mjs +4 -4
  114. package/esm2020/foehn-page/foehn-page-modal.component.mjs +4 -4
  115. package/esm2020/foehn-page/foehn-page-modal.service.mjs +4 -4
  116. package/esm2020/foehn-page/foehn-page.component.mjs +4 -4
  117. package/esm2020/foehn-page/foehn-page.module.mjs +5 -5
  118. package/esm2020/foehn-page/foehn-page.service.mjs +4 -4
  119. package/esm2020/foehn-recap-section/foehn-recap-section.component.mjs +4 -4
  120. package/esm2020/foehn-recap-section/foehn-recap-section.module.mjs +5 -5
  121. package/esm2020/foehn-remaining-alerts-summary/foehn-remaining-alerts-summary.component.mjs +4 -4
  122. package/esm2020/foehn-remaining-alerts-summary/foehn-remaining-alerts-summary.module.mjs +5 -5
  123. package/esm2020/foehn-status-progress-bar/foehn-status-progress-bar.component.mjs +4 -4
  124. package/esm2020/foehn-status-progress-bar/foehn-status-progress-bar.module.mjs +5 -5
  125. package/esm2020/foehn-table/foehn-table-column-configuration.mjs +1 -1
  126. package/esm2020/foehn-table/foehn-table.component.mjs +5 -5
  127. package/esm2020/foehn-table/foehn-table.module.mjs +5 -5
  128. package/esm2020/foehn-upload/abstract-foehn-uploader.component.mjs +4 -4
  129. package/esm2020/foehn-upload/foehn-bo-multi-upload/bo-multi-upload.service.mjs +4 -4
  130. package/esm2020/foehn-upload/foehn-bo-multi-upload/foehn-bo-multi-upload.component.mjs +4 -4
  131. package/esm2020/foehn-upload/foehn-bo-multi-upload/foehn-bo-multi-upload.module.mjs +5 -5
  132. package/esm2020/foehn-upload/foehn-multi-upload/foehn-multi-upload.component.mjs +4 -4
  133. package/esm2020/foehn-upload/foehn-multi-upload/foehn-multi-upload.module.mjs +5 -5
  134. package/esm2020/foehn-upload/foehn-multi-upload/multi-upload.service.mjs +4 -4
  135. package/esm2020/foehn-upload/foehn-multi-upload/pending-upload.service.mjs +4 -4
  136. package/esm2020/foehn-upload/foehn-picture-upload/foehn-picture-upload.component.mjs +4 -4
  137. package/esm2020/foehn-upload/foehn-picture-upload/foehn-picture-upload.module.mjs +5 -5
  138. package/esm2020/foehn-user-connected-as/foehn-user-connected-as.component.mjs +4 -4
  139. package/esm2020/foehn-user-connected-as/foehn-user-connected-as.module.mjs +5 -5
  140. package/esm2020/foehn-validation-alert-summary/foehn-validation-alert-summary.component.mjs +4 -4
  141. package/esm2020/foehn-validation-alert-summary/foehn-validation-alert-summary.module.mjs +5 -5
  142. package/esm2020/foehn-validation-alerts/foehn-validation-alerts.component.mjs +4 -4
  143. package/esm2020/foehn-validation-alerts/foehn-validation-alerts.module.mjs +5 -5
  144. package/esm2020/gesdem/gesdem-error-handler.service.mjs +4 -4
  145. package/esm2020/gesdem/gesdem-event.service.mjs +4 -4
  146. package/esm2020/gesdem/gesdem-handler.service.mjs +5 -4
  147. package/esm2020/gesdem/gesdem-loader.guard.mjs +4 -4
  148. package/esm2020/gesdem-action-recovery/gesdem-action-recovery-login/gesdem-action-recovery-login.component.mjs +4 -4
  149. package/esm2020/gesdem-action-recovery/gesdem-action-recovery-registration/gesdem-action-recovery-registration.component.mjs +4 -4
  150. package/esm2020/gesdem-action-recovery/gesdem-action-recovery.module.mjs +5 -5
  151. package/esm2020/gesdem-action-recovery/gesdem-action-recovery.service.mjs +4 -4
  152. package/esm2020/gesdem-confirmation/gesdem-confirmation.component.mjs +4 -4
  153. package/esm2020/gesdem-confirmation/gesdem-confirmation.module.mjs +5 -5
  154. package/esm2020/gesdem-error/gesdem-error.component.mjs +4 -4
  155. package/esm2020/gesdem-error/gesdem-error.module.mjs +5 -5
  156. package/esm2020/pipes/currency.pipe.mjs +4 -4
  157. package/esm2020/pipes/date.pipe.mjs +4 -4
  158. package/esm2020/pipes/formatIde.pipe.mjs +4 -4
  159. package/esm2020/pipes/pipes.module.mjs +5 -5
  160. package/esm2020/prestations-ng-core.module.mjs +5 -5
  161. package/esm2020/sdk-appinfo/application-info.service.mjs +4 -4
  162. package/esm2020/sdk-currency/currency.helper.mjs +4 -4
  163. package/esm2020/sdk-date/date.helper.mjs +4 -4
  164. package/esm2020/sdk-dictionary/default-dictionary.mjs +3 -1
  165. package/esm2020/sdk-dictionary/sdk-dictionary.module.mjs +5 -5
  166. package/esm2020/sdk-dictionary/sdk-dictionary.pipe.mjs +4 -4
  167. package/esm2020/sdk-dictionary/sdk-dictionary.service.mjs +6 -7
  168. package/esm2020/sdk-epayment/sdk-epayment.component.mjs +4 -4
  169. package/esm2020/sdk-epayment/sdk-epayment.module.mjs +5 -5
  170. package/esm2020/sdk-epayment/sdk-epayment.service.mjs +4 -4
  171. package/esm2020/sdk-recaptcha/grecaptcha/grecaptcha.component.mjs +4 -4
  172. package/esm2020/sdk-recaptcha/recaptcha.service.mjs +4 -4
  173. package/esm2020/sdk-recaptcha/sdk-recaptcha.component.mjs +4 -4
  174. package/esm2020/sdk-recaptcha/sdk-recaptcha.module.mjs +5 -5
  175. package/esm2020/sdk-redirect/iam-expired-interceptor.service.mjs +29 -19
  176. package/esm2020/sdk-redirect/redirect.component.mjs +12 -21
  177. package/esm2020/sdk-redirect/sdk-redirect.module.mjs +5 -5
  178. package/esm2020/sdk-session-info/session-info-with-application.service.mjs +4 -4
  179. package/esm2020/sdk-session-info/session-info.service.mjs +4 -4
  180. package/esm2020/sdk-statistics/sdk-statistics.service.mjs +4 -4
  181. package/esm2020/sdk-support-alert/support-alert-container.component.mjs +4 -4
  182. package/esm2020/sdk-support-alert/support-alert.component.mjs +4 -4
  183. package/esm2020/sdk-support-alert/support-alert.module.mjs +5 -5
  184. package/esm2020/sdk-support-alert/support-alert.service.mjs +4 -4
  185. package/esm2020/supported-browser.mjs +2 -2
  186. package/esm2020/validation/validation-handler.service.mjs +4 -4
  187. package/fesm2015/dsivd-prestations-ng.mjs +684 -639
  188. package/fesm2015/dsivd-prestations-ng.mjs.map +1 -1
  189. package/fesm2020/dsivd-prestations-ng.mjs +683 -639
  190. package/fesm2020/dsivd-prestations-ng.mjs.map +1 -1
  191. package/foehn-input/foehn-input-number.component.d.ts +8 -1
  192. package/foehn-modal/foehn-modal.component.d.ts +1 -2
  193. package/foehn-table/foehn-table-column-configuration.d.ts +6 -1
  194. package/package.json +2 -2
  195. package/sdk-dictionary/sdk-dictionary.service.d.ts +6 -0
  196. package/sdk-redirect/iam-expired-interceptor.service.d.ts +2 -2
  197. package/sdk-redirect/redirect.component.d.ts +2 -8
  198. package/dsivd-prestations-ng-v15.2.2.tgz +0 -0
@@ -85,15 +85,15 @@ export class FoehnDateComponent extends FoehnInputComponent {
85
85
  return num ? num.toString() : null;
86
86
  }
87
87
  }
88
- FoehnDateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: FoehnDateComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
89
- FoehnDateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.5", type: FoehnDateComponent, selector: "foehn-input-date", inputs: { disableDay: "disableDay", disableMonth: "disableMonth", disableYear: "disableYear", minDate: "minDate", maxDate: "maxDate", hideDatePickerButton: "hideDatePickerButton" }, providers: [
88
+ FoehnDateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: FoehnDateComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
89
+ FoehnDateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: FoehnDateComponent, selector: "foehn-input-date", inputs: { disableDay: "disableDay", disableMonth: "disableMonth", disableYear: "disableYear", minDate: "minDate", maxDate: "maxDate", hideDatePickerButton: "hideDatePickerButton" }, providers: [
90
90
  {
91
91
  provide: FoehnInputComponent,
92
92
  useExisting: forwardRef(() => FoehnDateComponent),
93
93
  multi: true
94
94
  }
95
- ], usesInheritance: true, ngImport: i0, template: "<div\n class=\"form-group\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n [attr.id]=\"buildId('Container')\"\n tabindex=\"-1\"\n>\n <fieldset\n class=\"mb-3\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n >\n <legend *ngIf=\"!!label\" [ngClass]=\"isLabelSrOnly ? 'sr-only' : 'vd-p'\">\n <span [innerHTML]=\"label\"></span>\n <span\n *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n aria-hidden=\"true\"\n >\n {{ 'foehn-input.optional' | fromDictionary }}\n </span>\n </legend>\n\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n <small\n *ngIf=\"helpText\"\n [attr.id]=\"buildId() + 'Help'\"\n class=\"text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-content></ng-content>\n\n <div class=\"vd-form-flex\">\n <div\n [ngClass]=\"{\n 'vd-form-flex__item--3-char-width':\n displayClearButton() | async,\n 'vd-form-flex__item--2-char-width': !(\n displayClearButton() | async\n )\n }\"\n class=\"vd-form-flex__item\"\n >\n <foehn-input-number\n [id]=\"buildId() + '_day'\"\n [name]=\"name + '_day'\"\n [label]=\"'foehn-input-date.day.label' | fromDictionary\"\n [(model)]=\"day\"\n (modelChange)=\"updateDate()\"\n [disabled]=\"disabled || disableDay\"\n [maxlength]=\"2\"\n [allowNegative]=\"false\"\n [max]=\"31\"\n [clearButton]=\"displayClearButton() | async\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n #entryComponent\n ></foehn-input-number>\n </div>\n <div\n [ngClass]=\"{\n 'vd-form-flex__item--3-char-width':\n displayClearButton() | async,\n 'vd-form-flex__item--2-char-width': !(\n displayClearButton() | async\n )\n }\"\n class=\"vd-form-flex__item\"\n >\n <foehn-input-number\n [id]=\"buildId() + '_month'\"\n [name]=\"name + '_month'\"\n [label]=\"'foehn-input-date.month.label' | fromDictionary\"\n [(model)]=\"month\"\n (modelChange)=\"updateDate()\"\n [disabled]=\"disabled || disableMonth\"\n [maxlength]=\"2\"\n [clearButton]=\"displayClearButton() | async\"\n [allowNegative]=\"false\"\n [max]=\"12\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n ></foehn-input-number>\n </div>\n <div\n class=\"vd-form-flex__item vd-form-flex__item--4-char-width\"\n [class.mr-0]=\"shouldDisplayDatePicker()\"\n >\n <foehn-input-number\n [id]=\"buildId() + '_year'\"\n [name]=\"name + '_year'\"\n [label]=\"'foehn-input-date.year.label' | fromDictionary\"\n [(model)]=\"year\"\n (modelChange)=\"updateDate()\"\n [disabled]=\"disabled || disableYear\"\n [allowNegative]=\"false\"\n [maxlength]=\"4\"\n [clearButton]=\"displayClearButton() | async\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n ></foehn-input-number>\n </div>\n <foehn-date-picker-button\n *ngIf=\"shouldDisplayDatePicker()\"\n [id]=\"buildId() + '_datePickerButton'\"\n [(model)]=\"datePickerModel\"\n (modelChange)=\"updateDateFromDatePicker($event)\"\n (userInput)=\"handleDatePickerUserInput($event)\"\n [displaySelectedDate]=\"false\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n class=\"align-self-center\"\n ></foehn-date-picker-button>\n </div>\n </fieldset>\n</div>\n", components: [{ type: i1.FoehnValidationAlertsComponent, selector: "foehn-validation-alerts", inputs: ["component", "shouldErrorsBeLive"] }, { type: i2.FoehnInputNumberComponent, selector: "foehn-input-number", inputs: ["allowDecimal", "allowNegative", "maxDecimalCount", "model"] }, { type: i3.FoehnDatePickerButtonComponent, selector: "foehn-date-picker-button", inputs: ["id", "name", "minYear", "maxYear", "minDate", "maxDate", "displaySelectedDate", "selectedDateSrOnlyLabelKey", "model"], outputs: ["modelChange", "userInput"] }], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], pipes: { "fromDictionary": i5.SdkDictionaryPipe, "async": i4.AsyncPipe } });
96
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: FoehnDateComponent, decorators: [{
95
+ ], usesInheritance: true, ngImport: i0, template: "<div\n class=\"form-group\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n [attr.id]=\"buildId('Container')\"\n tabindex=\"-1\"\n>\n <fieldset\n class=\"mb-3\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n >\n <legend *ngIf=\"!!label\" [ngClass]=\"isLabelSrOnly ? 'sr-only' : 'vd-p'\">\n <span [innerHTML]=\"label\"></span>\n <span\n *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n aria-hidden=\"true\"\n >\n {{ 'foehn-input.optional' | fromDictionary }}\n </span>\n </legend>\n\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n <small\n *ngIf=\"helpText\"\n [attr.id]=\"buildId() + 'Help'\"\n class=\"text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-content></ng-content>\n\n <div class=\"vd-form-flex\">\n <div\n [ngClass]=\"{\n 'vd-form-flex__item--3-char-width':\n displayClearButton() | async,\n 'vd-form-flex__item--2-char-width': !(\n displayClearButton() | async\n )\n }\"\n class=\"vd-form-flex__item\"\n >\n <foehn-input-number\n [id]=\"buildId() + '_day'\"\n [name]=\"name + '_day'\"\n [label]=\"'foehn-input-date.day.label' | fromDictionary\"\n [(model)]=\"day\"\n (modelChange)=\"updateDate()\"\n [disabled]=\"disabled || disableDay\"\n [maxlength]=\"2\"\n [allowNegative]=\"false\"\n [max]=\"31\"\n [clearButton]=\"displayClearButton() | async\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [hideStandardHelpText]=\"true\"\n #entryComponent\n ></foehn-input-number>\n </div>\n <div\n [ngClass]=\"{\n 'vd-form-flex__item--3-char-width':\n displayClearButton() | async,\n 'vd-form-flex__item--2-char-width': !(\n displayClearButton() | async\n )\n }\"\n class=\"vd-form-flex__item\"\n >\n <foehn-input-number\n [id]=\"buildId() + '_month'\"\n [name]=\"name + '_month'\"\n [label]=\"'foehn-input-date.month.label' | fromDictionary\"\n [(model)]=\"month\"\n (modelChange)=\"updateDate()\"\n [disabled]=\"disabled || disableMonth\"\n [maxlength]=\"2\"\n [clearButton]=\"displayClearButton() | async\"\n [allowNegative]=\"false\"\n [max]=\"12\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [hideStandardHelpText]=\"true\"\n ></foehn-input-number>\n </div>\n <div\n class=\"vd-form-flex__item vd-form-flex__item--4-char-width\"\n [class.mr-0]=\"shouldDisplayDatePicker()\"\n >\n <foehn-input-number\n [id]=\"buildId() + '_year'\"\n [name]=\"name + '_year'\"\n [label]=\"'foehn-input-date.year.label' | fromDictionary\"\n [(model)]=\"year\"\n (modelChange)=\"updateDate()\"\n [disabled]=\"disabled || disableYear\"\n [allowNegative]=\"false\"\n [maxlength]=\"4\"\n [clearButton]=\"displayClearButton() | async\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [hideStandardHelpText]=\"true\"\n ></foehn-input-number>\n </div>\n <foehn-date-picker-button\n *ngIf=\"shouldDisplayDatePicker()\"\n [id]=\"buildId() + '_datePickerButton'\"\n [(model)]=\"datePickerModel\"\n (modelChange)=\"updateDateFromDatePicker($event)\"\n (userInput)=\"handleDatePickerUserInput($event)\"\n [displaySelectedDate]=\"false\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n class=\"align-self-center\"\n ></foehn-date-picker-button>\n </div>\n </fieldset>\n</div>\n", components: [{ type: i1.FoehnValidationAlertsComponent, selector: "foehn-validation-alerts", inputs: ["component", "shouldErrorsBeLive"] }, { type: i2.FoehnInputNumberComponent, selector: "foehn-input-number", inputs: ["hideStandardHelpText", "allowDecimal", "allowNegative", "maxDecimalCount", "model"] }, { type: i3.FoehnDatePickerButtonComponent, selector: "foehn-date-picker-button", inputs: ["id", "name", "minYear", "maxYear", "minDate", "maxDate", "displaySelectedDate", "selectedDateSrOnlyLabelKey", "model"], outputs: ["modelChange", "userInput"] }], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], pipes: { "fromDictionary": i5.SdkDictionaryPipe, "async": i4.AsyncPipe } });
96
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: FoehnDateComponent, decorators: [{
97
97
  type: Component,
98
98
  args: [{ selector: 'foehn-input-date', providers: [
99
99
  {
@@ -101,7 +101,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImpor
101
101
  useExisting: forwardRef(() => FoehnDateComponent),
102
102
  multi: true
103
103
  }
104
- ], template: "<div\n class=\"form-group\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n [attr.id]=\"buildId('Container')\"\n tabindex=\"-1\"\n>\n <fieldset\n class=\"mb-3\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n >\n <legend *ngIf=\"!!label\" [ngClass]=\"isLabelSrOnly ? 'sr-only' : 'vd-p'\">\n <span [innerHTML]=\"label\"></span>\n <span\n *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n aria-hidden=\"true\"\n >\n {{ 'foehn-input.optional' | fromDictionary }}\n </span>\n </legend>\n\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n <small\n *ngIf=\"helpText\"\n [attr.id]=\"buildId() + 'Help'\"\n class=\"text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-content></ng-content>\n\n <div class=\"vd-form-flex\">\n <div\n [ngClass]=\"{\n 'vd-form-flex__item--3-char-width':\n displayClearButton() | async,\n 'vd-form-flex__item--2-char-width': !(\n displayClearButton() | async\n )\n }\"\n class=\"vd-form-flex__item\"\n >\n <foehn-input-number\n [id]=\"buildId() + '_day'\"\n [name]=\"name + '_day'\"\n [label]=\"'foehn-input-date.day.label' | fromDictionary\"\n [(model)]=\"day\"\n (modelChange)=\"updateDate()\"\n [disabled]=\"disabled || disableDay\"\n [maxlength]=\"2\"\n [allowNegative]=\"false\"\n [max]=\"31\"\n [clearButton]=\"displayClearButton() | async\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n #entryComponent\n ></foehn-input-number>\n </div>\n <div\n [ngClass]=\"{\n 'vd-form-flex__item--3-char-width':\n displayClearButton() | async,\n 'vd-form-flex__item--2-char-width': !(\n displayClearButton() | async\n )\n }\"\n class=\"vd-form-flex__item\"\n >\n <foehn-input-number\n [id]=\"buildId() + '_month'\"\n [name]=\"name + '_month'\"\n [label]=\"'foehn-input-date.month.label' | fromDictionary\"\n [(model)]=\"month\"\n (modelChange)=\"updateDate()\"\n [disabled]=\"disabled || disableMonth\"\n [maxlength]=\"2\"\n [clearButton]=\"displayClearButton() | async\"\n [allowNegative]=\"false\"\n [max]=\"12\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n ></foehn-input-number>\n </div>\n <div\n class=\"vd-form-flex__item vd-form-flex__item--4-char-width\"\n [class.mr-0]=\"shouldDisplayDatePicker()\"\n >\n <foehn-input-number\n [id]=\"buildId() + '_year'\"\n [name]=\"name + '_year'\"\n [label]=\"'foehn-input-date.year.label' | fromDictionary\"\n [(model)]=\"year\"\n (modelChange)=\"updateDate()\"\n [disabled]=\"disabled || disableYear\"\n [allowNegative]=\"false\"\n [maxlength]=\"4\"\n [clearButton]=\"displayClearButton() | async\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n ></foehn-input-number>\n </div>\n <foehn-date-picker-button\n *ngIf=\"shouldDisplayDatePicker()\"\n [id]=\"buildId() + '_datePickerButton'\"\n [(model)]=\"datePickerModel\"\n (modelChange)=\"updateDateFromDatePicker($event)\"\n (userInput)=\"handleDatePickerUserInput($event)\"\n [displaySelectedDate]=\"false\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n class=\"align-self-center\"\n ></foehn-date-picker-button>\n </div>\n </fieldset>\n</div>\n" }]
104
+ ], template: "<div\n class=\"form-group\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n [attr.id]=\"buildId('Container')\"\n tabindex=\"-1\"\n>\n <fieldset\n class=\"mb-3\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n >\n <legend *ngIf=\"!!label\" [ngClass]=\"isLabelSrOnly ? 'sr-only' : 'vd-p'\">\n <span [innerHTML]=\"label\"></span>\n <span\n *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n aria-hidden=\"true\"\n >\n {{ 'foehn-input.optional' | fromDictionary }}\n </span>\n </legend>\n\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n <small\n *ngIf=\"helpText\"\n [attr.id]=\"buildId() + 'Help'\"\n class=\"text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-content></ng-content>\n\n <div class=\"vd-form-flex\">\n <div\n [ngClass]=\"{\n 'vd-form-flex__item--3-char-width':\n displayClearButton() | async,\n 'vd-form-flex__item--2-char-width': !(\n displayClearButton() | async\n )\n }\"\n class=\"vd-form-flex__item\"\n >\n <foehn-input-number\n [id]=\"buildId() + '_day'\"\n [name]=\"name + '_day'\"\n [label]=\"'foehn-input-date.day.label' | fromDictionary\"\n [(model)]=\"day\"\n (modelChange)=\"updateDate()\"\n [disabled]=\"disabled || disableDay\"\n [maxlength]=\"2\"\n [allowNegative]=\"false\"\n [max]=\"31\"\n [clearButton]=\"displayClearButton() | async\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [hideStandardHelpText]=\"true\"\n #entryComponent\n ></foehn-input-number>\n </div>\n <div\n [ngClass]=\"{\n 'vd-form-flex__item--3-char-width':\n displayClearButton() | async,\n 'vd-form-flex__item--2-char-width': !(\n displayClearButton() | async\n )\n }\"\n class=\"vd-form-flex__item\"\n >\n <foehn-input-number\n [id]=\"buildId() + '_month'\"\n [name]=\"name + '_month'\"\n [label]=\"'foehn-input-date.month.label' | fromDictionary\"\n [(model)]=\"month\"\n (modelChange)=\"updateDate()\"\n [disabled]=\"disabled || disableMonth\"\n [maxlength]=\"2\"\n [clearButton]=\"displayClearButton() | async\"\n [allowNegative]=\"false\"\n [max]=\"12\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [hideStandardHelpText]=\"true\"\n ></foehn-input-number>\n </div>\n <div\n class=\"vd-form-flex__item vd-form-flex__item--4-char-width\"\n [class.mr-0]=\"shouldDisplayDatePicker()\"\n >\n <foehn-input-number\n [id]=\"buildId() + '_year'\"\n [name]=\"name + '_year'\"\n [label]=\"'foehn-input-date.year.label' | fromDictionary\"\n [(model)]=\"year\"\n (modelChange)=\"updateDate()\"\n [disabled]=\"disabled || disableYear\"\n [allowNegative]=\"false\"\n [maxlength]=\"4\"\n [clearButton]=\"displayClearButton() | async\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [hideStandardHelpText]=\"true\"\n ></foehn-input-number>\n </div>\n <foehn-date-picker-button\n *ngIf=\"shouldDisplayDatePicker()\"\n [id]=\"buildId() + '_datePickerButton'\"\n [(model)]=\"datePickerModel\"\n (modelChange)=\"updateDateFromDatePicker($event)\"\n (userInput)=\"handleDatePickerUserInput($event)\"\n [displaySelectedDate]=\"false\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n class=\"align-self-center\"\n ></foehn-date-picker-button>\n </div>\n </fieldset>\n</div>\n" }]
105
105
  }], propDecorators: { disableDay: [{
106
106
  type: Input
107
107
  }], disableMonth: [{
@@ -115,4 +115,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImpor
115
115
  }], hideDatePickerButton: [{
116
116
  type: Input
117
117
  }] } });
118
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-input-date.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-input-date/foehn-input-date.component.ts","../../../../projects/prestations-ng/src/foehn-input-date/foehn-input-date.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, Input } from '@angular/core';\nimport { FoehnInputComponent } from '../foehn-input/foehn-input.component';\nimport { Observable, of } from 'rxjs';\n\n@Component({\n    selector: 'foehn-input-date',\n    templateUrl: './foehn-input-date.component.html',\n    providers: [\n        {\n            provide: FoehnInputComponent,\n            useExisting: forwardRef(() => FoehnDateComponent),\n            multi: true\n        }\n    ]\n})\nexport class FoehnDateComponent extends FoehnInputComponent<number[]> {\n    @Input()\n    disableDay = false;\n\n    @Input()\n    disableMonth = false;\n\n    @Input()\n    disableYear = false;\n\n    @Input()\n    minDate: number[];\n\n    @Input()\n    maxDate: number[];\n\n    @Input()\n    hideDatePickerButton = false;\n\n    day: string;\n    month: string;\n    year: string;\n    datePickerModel: number[];\n\n    updateDate(): void {\n        const validValue = this.getValidValue();\n        if (typeof validValue !== 'undefined') {\n            this.updateNgModel(validValue);\n        }\n    }\n\n    updateDateFromDatePicker(date: number[]): void {\n        if (typeof date !== 'undefined') {\n            this.updateNgModel(date);\n        }\n    }\n\n    handleUserInput(): void {\n        const validValue = this.getValidValue();\n        if (typeof validValue !== 'undefined') {\n            this.handleChange(validValue);\n        }\n    }\n\n    handleDatePickerUserInput(date: number[]): void {\n        if (typeof date !== 'undefined') {\n            this.markAsDirty();\n            this.handleChange(date);\n        }\n    }\n\n    onModelChange(value: number[]): void {\n        if (value && value.length > 2) {\n            this.year = this.toString(value[0]);\n            this.month = this.toString(value[1]);\n            this.day = this.toString(value[2]);\n            this.datePickerModel = value;\n        } else if (!value) {\n            this.year = null;\n            this.month = null;\n            this.day = null;\n            this.datePickerModel = null;\n        }\n    }\n\n    displayClearButton(): Observable<boolean> {\n        // Override the clear button fonction not worry about the model at this stage.\n        return of(this.clearButton);\n    }\n\n    getValidValue(): number[] | null | undefined {\n        if (\n            this.isEmpty(this.day) &&\n            this.isEmpty(this.month) &&\n            this.isEmpty(this.year)\n        ) {\n            if (this.model_ !== undefined) {\n                return null;\n            }\n\n            return undefined;\n        }\n        return [\n            this.toNumber(this.year),\n            this.toNumber(this.month),\n            this.toNumber(this.day)\n        ];\n    }\n\n    shouldDisplayDatePicker(): boolean {\n        return (\n            !this.hideDatePickerButton &&\n            !this.disabled &&\n            !this.disableYear &&\n            !this.disableMonth &&\n            !this.disableDay\n        );\n    }\n\n    private toNumber(str: string): number {\n        return str ? Number(str) : null;\n    }\n\n    private toString(num: number): string {\n        return num ? num.toString() : null;\n    }\n}\n","<div\n    class=\"form-group\"\n    [class.has-danger]=\"hasErrorsToDisplay()\"\n    [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n    [attr.id]=\"buildId('Container')\"\n    tabindex=\"-1\"\n>\n    <fieldset\n        class=\"mb-3\"\n        [attr.aria-describedby]=\"getDescribedBy()\"\n        [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n    >\n        <legend *ngIf=\"!!label\" [ngClass]=\"isLabelSrOnly ? 'sr-only' : 'vd-p'\">\n            <span [innerHTML]=\"label\"></span>\n            <span\n                *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n                aria-hidden=\"true\"\n            >\n                {{ 'foehn-input.optional' | fromDictionary }}\n            </span>\n        </legend>\n\n        <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n        <small\n            *ngIf=\"helpText\"\n            [attr.id]=\"buildId() + 'Help'\"\n            class=\"text-secondary\"\n            [innerHTML]=\"helpText\"\n        ></small>\n\n        <ng-content></ng-content>\n\n        <div class=\"vd-form-flex\">\n            <div\n                [ngClass]=\"{\n                    'vd-form-flex__item--3-char-width':\n                        displayClearButton() | async,\n                    'vd-form-flex__item--2-char-width': !(\n                        displayClearButton() | async\n                    )\n                }\"\n                class=\"vd-form-flex__item\"\n            >\n                <foehn-input-number\n                    [id]=\"buildId() + '_day'\"\n                    [name]=\"name + '_day'\"\n                    [label]=\"'foehn-input-date.day.label' | fromDictionary\"\n                    [(model)]=\"day\"\n                    (modelChange)=\"updateDate()\"\n                    [disabled]=\"disabled || disableDay\"\n                    [maxlength]=\"2\"\n                    [allowNegative]=\"false\"\n                    [max]=\"31\"\n                    [clearButton]=\"displayClearButton() | async\"\n                    [required]=\"required\"\n                    [hideNotRequiredExtraLabel]=\"true\"\n                    (userInput)=\"handleUserInput()\"\n                    [isErrorInherited]=\"hasErrorsToDisplay()\"\n                    #entryComponent\n                ></foehn-input-number>\n            </div>\n            <div\n                [ngClass]=\"{\n                    'vd-form-flex__item--3-char-width':\n                        displayClearButton() | async,\n                    'vd-form-flex__item--2-char-width': !(\n                        displayClearButton() | async\n                    )\n                }\"\n                class=\"vd-form-flex__item\"\n            >\n                <foehn-input-number\n                    [id]=\"buildId() + '_month'\"\n                    [name]=\"name + '_month'\"\n                    [label]=\"'foehn-input-date.month.label' | fromDictionary\"\n                    [(model)]=\"month\"\n                    (modelChange)=\"updateDate()\"\n                    [disabled]=\"disabled || disableMonth\"\n                    [maxlength]=\"2\"\n                    [clearButton]=\"displayClearButton() | async\"\n                    [allowNegative]=\"false\"\n                    [max]=\"12\"\n                    [required]=\"required\"\n                    [hideNotRequiredExtraLabel]=\"true\"\n                    (userInput)=\"handleUserInput()\"\n                    [isErrorInherited]=\"hasErrorsToDisplay()\"\n                ></foehn-input-number>\n            </div>\n            <div\n                class=\"vd-form-flex__item vd-form-flex__item--4-char-width\"\n                [class.mr-0]=\"shouldDisplayDatePicker()\"\n            >\n                <foehn-input-number\n                    [id]=\"buildId() + '_year'\"\n                    [name]=\"name + '_year'\"\n                    [label]=\"'foehn-input-date.year.label' | fromDictionary\"\n                    [(model)]=\"year\"\n                    (modelChange)=\"updateDate()\"\n                    [disabled]=\"disabled || disableYear\"\n                    [allowNegative]=\"false\"\n                    [maxlength]=\"4\"\n                    [clearButton]=\"displayClearButton() | async\"\n                    [required]=\"required\"\n                    [hideNotRequiredExtraLabel]=\"true\"\n                    (userInput)=\"handleUserInput()\"\n                    [isErrorInherited]=\"hasErrorsToDisplay()\"\n                ></foehn-input-number>\n            </div>\n            <foehn-date-picker-button\n                *ngIf=\"shouldDisplayDatePicker()\"\n                [id]=\"buildId() + '_datePickerButton'\"\n                [(model)]=\"datePickerModel\"\n                (modelChange)=\"updateDateFromDatePicker($event)\"\n                (userInput)=\"handleDatePickerUserInput($event)\"\n                [displaySelectedDate]=\"false\"\n                [minDate]=\"minDate\"\n                [maxDate]=\"maxDate\"\n                class=\"align-self-center\"\n            ></foehn-date-picker-button>\n        </div>\n    </fieldset>\n</div>\n"]}
118
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-input-date.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-input-date/foehn-input-date.component.ts","../../../../projects/prestations-ng/src/foehn-input-date/foehn-input-date.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, Input } from '@angular/core';\nimport { FoehnInputComponent } from '../foehn-input/foehn-input.component';\nimport { Observable, of } from 'rxjs';\n\n@Component({\n    selector: 'foehn-input-date',\n    templateUrl: './foehn-input-date.component.html',\n    providers: [\n        {\n            provide: FoehnInputComponent,\n            useExisting: forwardRef(() => FoehnDateComponent),\n            multi: true\n        }\n    ]\n})\nexport class FoehnDateComponent extends FoehnInputComponent<number[]> {\n    @Input()\n    disableDay = false;\n\n    @Input()\n    disableMonth = false;\n\n    @Input()\n    disableYear = false;\n\n    @Input()\n    minDate: number[];\n\n    @Input()\n    maxDate: number[];\n\n    @Input()\n    hideDatePickerButton = false;\n\n    day: string;\n    month: string;\n    year: string;\n    datePickerModel: number[];\n\n    updateDate(): void {\n        const validValue = this.getValidValue();\n        if (typeof validValue !== 'undefined') {\n            this.updateNgModel(validValue);\n        }\n    }\n\n    updateDateFromDatePicker(date: number[]): void {\n        if (typeof date !== 'undefined') {\n            this.updateNgModel(date);\n        }\n    }\n\n    handleUserInput(): void {\n        const validValue = this.getValidValue();\n        if (typeof validValue !== 'undefined') {\n            this.handleChange(validValue);\n        }\n    }\n\n    handleDatePickerUserInput(date: number[]): void {\n        if (typeof date !== 'undefined') {\n            this.markAsDirty();\n            this.handleChange(date);\n        }\n    }\n\n    onModelChange(value: number[]): void {\n        if (value && value.length > 2) {\n            this.year = this.toString(value[0]);\n            this.month = this.toString(value[1]);\n            this.day = this.toString(value[2]);\n            this.datePickerModel = value;\n        } else if (!value) {\n            this.year = null;\n            this.month = null;\n            this.day = null;\n            this.datePickerModel = null;\n        }\n    }\n\n    displayClearButton(): Observable<boolean> {\n        // Override the clear button fonction not worry about the model at this stage.\n        return of(this.clearButton);\n    }\n\n    getValidValue(): number[] | null | undefined {\n        if (\n            this.isEmpty(this.day) &&\n            this.isEmpty(this.month) &&\n            this.isEmpty(this.year)\n        ) {\n            if (this.model_ !== undefined) {\n                return null;\n            }\n\n            return undefined;\n        }\n        return [\n            this.toNumber(this.year),\n            this.toNumber(this.month),\n            this.toNumber(this.day)\n        ];\n    }\n\n    shouldDisplayDatePicker(): boolean {\n        return (\n            !this.hideDatePickerButton &&\n            !this.disabled &&\n            !this.disableYear &&\n            !this.disableMonth &&\n            !this.disableDay\n        );\n    }\n\n    private toNumber(str: string): number {\n        return str ? Number(str) : null;\n    }\n\n    private toString(num: number): string {\n        return num ? num.toString() : null;\n    }\n}\n","<div\n    class=\"form-group\"\n    [class.has-danger]=\"hasErrorsToDisplay()\"\n    [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n    [attr.id]=\"buildId('Container')\"\n    tabindex=\"-1\"\n>\n    <fieldset\n        class=\"mb-3\"\n        [attr.aria-describedby]=\"getDescribedBy()\"\n        [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n    >\n        <legend *ngIf=\"!!label\" [ngClass]=\"isLabelSrOnly ? 'sr-only' : 'vd-p'\">\n            <span [innerHTML]=\"label\"></span>\n            <span\n                *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n                aria-hidden=\"true\"\n            >\n                {{ 'foehn-input.optional' | fromDictionary }}\n            </span>\n        </legend>\n\n        <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n        <small\n            *ngIf=\"helpText\"\n            [attr.id]=\"buildId() + 'Help'\"\n            class=\"text-secondary\"\n            [innerHTML]=\"helpText\"\n        ></small>\n\n        <ng-content></ng-content>\n\n        <div class=\"vd-form-flex\">\n            <div\n                [ngClass]=\"{\n                    'vd-form-flex__item--3-char-width':\n                        displayClearButton() | async,\n                    'vd-form-flex__item--2-char-width': !(\n                        displayClearButton() | async\n                    )\n                }\"\n                class=\"vd-form-flex__item\"\n            >\n                <foehn-input-number\n                    [id]=\"buildId() + '_day'\"\n                    [name]=\"name + '_day'\"\n                    [label]=\"'foehn-input-date.day.label' | fromDictionary\"\n                    [(model)]=\"day\"\n                    (modelChange)=\"updateDate()\"\n                    [disabled]=\"disabled || disableDay\"\n                    [maxlength]=\"2\"\n                    [allowNegative]=\"false\"\n                    [max]=\"31\"\n                    [clearButton]=\"displayClearButton() | async\"\n                    [required]=\"required\"\n                    [hideNotRequiredExtraLabel]=\"true\"\n                    (userInput)=\"handleUserInput()\"\n                    [isErrorInherited]=\"hasErrorsToDisplay()\"\n                    [hideStandardHelpText]=\"true\"\n                    #entryComponent\n                ></foehn-input-number>\n            </div>\n            <div\n                [ngClass]=\"{\n                    'vd-form-flex__item--3-char-width':\n                        displayClearButton() | async,\n                    'vd-form-flex__item--2-char-width': !(\n                        displayClearButton() | async\n                    )\n                }\"\n                class=\"vd-form-flex__item\"\n            >\n                <foehn-input-number\n                    [id]=\"buildId() + '_month'\"\n                    [name]=\"name + '_month'\"\n                    [label]=\"'foehn-input-date.month.label' | fromDictionary\"\n                    [(model)]=\"month\"\n                    (modelChange)=\"updateDate()\"\n                    [disabled]=\"disabled || disableMonth\"\n                    [maxlength]=\"2\"\n                    [clearButton]=\"displayClearButton() | async\"\n                    [allowNegative]=\"false\"\n                    [max]=\"12\"\n                    [required]=\"required\"\n                    [hideNotRequiredExtraLabel]=\"true\"\n                    (userInput)=\"handleUserInput()\"\n                    [isErrorInherited]=\"hasErrorsToDisplay()\"\n                    [hideStandardHelpText]=\"true\"\n                ></foehn-input-number>\n            </div>\n            <div\n                class=\"vd-form-flex__item vd-form-flex__item--4-char-width\"\n                [class.mr-0]=\"shouldDisplayDatePicker()\"\n            >\n                <foehn-input-number\n                    [id]=\"buildId() + '_year'\"\n                    [name]=\"name + '_year'\"\n                    [label]=\"'foehn-input-date.year.label' | fromDictionary\"\n                    [(model)]=\"year\"\n                    (modelChange)=\"updateDate()\"\n                    [disabled]=\"disabled || disableYear\"\n                    [allowNegative]=\"false\"\n                    [maxlength]=\"4\"\n                    [clearButton]=\"displayClearButton() | async\"\n                    [required]=\"required\"\n                    [hideNotRequiredExtraLabel]=\"true\"\n                    (userInput)=\"handleUserInput()\"\n                    [isErrorInherited]=\"hasErrorsToDisplay()\"\n                    [hideStandardHelpText]=\"true\"\n                ></foehn-input-number>\n            </div>\n            <foehn-date-picker-button\n                *ngIf=\"shouldDisplayDatePicker()\"\n                [id]=\"buildId() + '_datePickerButton'\"\n                [(model)]=\"datePickerModel\"\n                (modelChange)=\"updateDateFromDatePicker($event)\"\n                (userInput)=\"handleDatePickerUserInput($event)\"\n                [displaySelectedDate]=\"false\"\n                [minDate]=\"minDate\"\n                [maxDate]=\"maxDate\"\n                class=\"align-self-center\"\n            ></foehn-date-picker-button>\n        </div>\n    </fieldset>\n</div>\n"]}
@@ -54,15 +54,15 @@ export class FoehnTimeComponent extends FoehnInputStringComponent {
54
54
  return `${leftPad(this.hour)}:${leftPad(this.minute)}`;
55
55
  }
56
56
  }
57
- FoehnTimeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: FoehnTimeComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
58
- FoehnTimeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.5", type: FoehnTimeComponent, selector: "foehn-input-time", providers: [
57
+ FoehnTimeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: FoehnTimeComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
58
+ FoehnTimeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: FoehnTimeComponent, selector: "foehn-input-time", providers: [
59
59
  {
60
60
  provide: FoehnInputComponent,
61
61
  useExisting: forwardRef(() => FoehnTimeComponent),
62
62
  multi: true
63
63
  }
64
- ], usesInheritance: true, ngImport: i0, template: "<div\n class=\"form-group\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n [attr.id]=\"buildId('Container')\"\n tabindex=\"-1\"\n>\n <fieldset\n class=\"mb-3\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n >\n <legend *ngIf=\"!!label\" [ngClass]=\"isLabelSrOnly ? 'sr-only' : 'vd-p'\">\n <span [innerHTML]=\"label\"></span>\n <span\n *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n aria-hidden=\"true\"\n >\n {{ 'foehn-input.optional' | fromDictionary }}\n </span>\n </legend>\n\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n <small\n *ngIf=\"helpText\"\n [attr.id]=\"buildId() + 'Help'\"\n class=\"text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-content></ng-content>\n\n <div class=\"vd-form-flex\">\n <div\n [ngClass]=\"{\n 'vd-form-flex__item--3-char-width':\n displayClearButton() | async,\n 'vd-form-flex__item--2-char-width': !(\n displayClearButton() | async\n )\n }\"\n class=\"vd-form-flex__item\"\n >\n <foehn-input-number\n [id]=\"buildId() + '_hours'\"\n [name]=\"name + '_hours'\"\n [label]=\"'foehn-input-time.hours.label' | fromDictionary\"\n [maxlength]=\"2\"\n [max]=\"24\"\n [(model)]=\"hour\"\n (focusout)=\"updateTime()\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [disabled]=\"disabled\"\n #entryComponent\n ></foehn-input-number>\n </div>\n <div\n [ngClass]=\"{\n 'vd-form-flex__item--3-char-width':\n displayClearButton() | async,\n 'vd-form-flex__item--2-char-width': !(\n displayClearButton() | async\n )\n }\"\n class=\"vd-form-flex__item\"\n >\n <foehn-input-number\n [id]=\"buildId() + '_minutes'\"\n [name]=\"name + '_minutes'\"\n [label]=\"'foehn-input-time.minutes.label' | fromDictionary\"\n [maxlength]=\"2\"\n [max]=\"59\"\n [(model)]=\"minute\"\n (focusout)=\"updateTime()\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [disabled]=\"disabled\"\n ></foehn-input-number>\n </div>\n </div>\n </fieldset>\n</div>\n", components: [{ type: i1.FoehnValidationAlertsComponent, selector: "foehn-validation-alerts", inputs: ["component", "shouldErrorsBeLive"] }, { type: i2.FoehnInputNumberComponent, selector: "foehn-input-number", inputs: ["allowDecimal", "allowNegative", "maxDecimalCount", "model"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], pipes: { "fromDictionary": i4.SdkDictionaryPipe, "async": i3.AsyncPipe } });
65
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: FoehnTimeComponent, decorators: [{
64
+ ], usesInheritance: true, ngImport: i0, template: "<div\n class=\"form-group\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n [attr.id]=\"buildId('Container')\"\n tabindex=\"-1\"\n>\n <fieldset\n class=\"mb-3\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n >\n <legend *ngIf=\"!!label\" [ngClass]=\"isLabelSrOnly ? 'sr-only' : 'vd-p'\">\n <span [innerHTML]=\"label\"></span>\n <span\n *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n aria-hidden=\"true\"\n >\n {{ 'foehn-input.optional' | fromDictionary }}\n </span>\n </legend>\n\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n <small\n *ngIf=\"helpText\"\n [attr.id]=\"buildId() + 'Help'\"\n class=\"text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-content></ng-content>\n\n <div class=\"vd-form-flex\">\n <div\n [ngClass]=\"{\n 'vd-form-flex__item--3-char-width':\n displayClearButton() | async,\n 'vd-form-flex__item--2-char-width': !(\n displayClearButton() | async\n )\n }\"\n class=\"vd-form-flex__item\"\n >\n <foehn-input-number\n [id]=\"buildId() + '_hours'\"\n [name]=\"name + '_hours'\"\n [label]=\"'foehn-input-time.hours.label' | fromDictionary\"\n [maxlength]=\"2\"\n [max]=\"24\"\n [(model)]=\"hour\"\n (focusout)=\"updateTime()\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [disabled]=\"disabled\"\n [hideStandardHelpText]=\"true\"\n #entryComponent\n ></foehn-input-number>\n </div>\n <div\n [ngClass]=\"{\n 'vd-form-flex__item--3-char-width':\n displayClearButton() | async,\n 'vd-form-flex__item--2-char-width': !(\n displayClearButton() | async\n )\n }\"\n class=\"vd-form-flex__item\"\n >\n <foehn-input-number\n [id]=\"buildId() + '_minutes'\"\n [name]=\"name + '_minutes'\"\n [label]=\"'foehn-input-time.minutes.label' | fromDictionary\"\n [maxlength]=\"2\"\n [max]=\"59\"\n [(model)]=\"minute\"\n (focusout)=\"updateTime()\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [disabled]=\"disabled\"\n [hideStandardHelpText]=\"true\"\n ></foehn-input-number>\n </div>\n </div>\n </fieldset>\n</div>\n", components: [{ type: i1.FoehnValidationAlertsComponent, selector: "foehn-validation-alerts", inputs: ["component", "shouldErrorsBeLive"] }, { type: i2.FoehnInputNumberComponent, selector: "foehn-input-number", inputs: ["hideStandardHelpText", "allowDecimal", "allowNegative", "maxDecimalCount", "model"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], pipes: { "fromDictionary": i4.SdkDictionaryPipe, "async": i3.AsyncPipe } });
65
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: FoehnTimeComponent, decorators: [{
66
66
  type: Component,
67
67
  args: [{ selector: 'foehn-input-time', providers: [
68
68
  {
@@ -70,6 +70,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImpor
70
70
  useExisting: forwardRef(() => FoehnTimeComponent),
71
71
  multi: true
72
72
  }
73
- ], template: "<div\n class=\"form-group\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n [attr.id]=\"buildId('Container')\"\n tabindex=\"-1\"\n>\n <fieldset\n class=\"mb-3\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n >\n <legend *ngIf=\"!!label\" [ngClass]=\"isLabelSrOnly ? 'sr-only' : 'vd-p'\">\n <span [innerHTML]=\"label\"></span>\n <span\n *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n aria-hidden=\"true\"\n >\n {{ 'foehn-input.optional' | fromDictionary }}\n </span>\n </legend>\n\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n <small\n *ngIf=\"helpText\"\n [attr.id]=\"buildId() + 'Help'\"\n class=\"text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-content></ng-content>\n\n <div class=\"vd-form-flex\">\n <div\n [ngClass]=\"{\n 'vd-form-flex__item--3-char-width':\n displayClearButton() | async,\n 'vd-form-flex__item--2-char-width': !(\n displayClearButton() | async\n )\n }\"\n class=\"vd-form-flex__item\"\n >\n <foehn-input-number\n [id]=\"buildId() + '_hours'\"\n [name]=\"name + '_hours'\"\n [label]=\"'foehn-input-time.hours.label' | fromDictionary\"\n [maxlength]=\"2\"\n [max]=\"24\"\n [(model)]=\"hour\"\n (focusout)=\"updateTime()\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [disabled]=\"disabled\"\n #entryComponent\n ></foehn-input-number>\n </div>\n <div\n [ngClass]=\"{\n 'vd-form-flex__item--3-char-width':\n displayClearButton() | async,\n 'vd-form-flex__item--2-char-width': !(\n displayClearButton() | async\n )\n }\"\n class=\"vd-form-flex__item\"\n >\n <foehn-input-number\n [id]=\"buildId() + '_minutes'\"\n [name]=\"name + '_minutes'\"\n [label]=\"'foehn-input-time.minutes.label' | fromDictionary\"\n [maxlength]=\"2\"\n [max]=\"59\"\n [(model)]=\"minute\"\n (focusout)=\"updateTime()\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [disabled]=\"disabled\"\n ></foehn-input-number>\n </div>\n </div>\n </fieldset>\n</div>\n" }]
73
+ ], template: "<div\n class=\"form-group\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n [attr.id]=\"buildId('Container')\"\n tabindex=\"-1\"\n>\n <fieldset\n class=\"mb-3\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n >\n <legend *ngIf=\"!!label\" [ngClass]=\"isLabelSrOnly ? 'sr-only' : 'vd-p'\">\n <span [innerHTML]=\"label\"></span>\n <span\n *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n aria-hidden=\"true\"\n >\n {{ 'foehn-input.optional' | fromDictionary }}\n </span>\n </legend>\n\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n <small\n *ngIf=\"helpText\"\n [attr.id]=\"buildId() + 'Help'\"\n class=\"text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-content></ng-content>\n\n <div class=\"vd-form-flex\">\n <div\n [ngClass]=\"{\n 'vd-form-flex__item--3-char-width':\n displayClearButton() | async,\n 'vd-form-flex__item--2-char-width': !(\n displayClearButton() | async\n )\n }\"\n class=\"vd-form-flex__item\"\n >\n <foehn-input-number\n [id]=\"buildId() + '_hours'\"\n [name]=\"name + '_hours'\"\n [label]=\"'foehn-input-time.hours.label' | fromDictionary\"\n [maxlength]=\"2\"\n [max]=\"24\"\n [(model)]=\"hour\"\n (focusout)=\"updateTime()\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [disabled]=\"disabled\"\n [hideStandardHelpText]=\"true\"\n #entryComponent\n ></foehn-input-number>\n </div>\n <div\n [ngClass]=\"{\n 'vd-form-flex__item--3-char-width':\n displayClearButton() | async,\n 'vd-form-flex__item--2-char-width': !(\n displayClearButton() | async\n )\n }\"\n class=\"vd-form-flex__item\"\n >\n <foehn-input-number\n [id]=\"buildId() + '_minutes'\"\n [name]=\"name + '_minutes'\"\n [label]=\"'foehn-input-time.minutes.label' | fromDictionary\"\n [maxlength]=\"2\"\n [max]=\"59\"\n [(model)]=\"minute\"\n (focusout)=\"updateTime()\"\n [required]=\"required\"\n [hideNotRequiredExtraLabel]=\"true\"\n (userInput)=\"handleUserInput()\"\n [isErrorInherited]=\"hasErrorsToDisplay()\"\n [disabled]=\"disabled\"\n [hideStandardHelpText]=\"true\"\n ></foehn-input-number>\n </div>\n </div>\n </fieldset>\n</div>\n" }]
74
74
  }] });
75
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-input-time.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-input-time/foehn-input-time.component.ts","../../../../projects/prestations-ng/src/foehn-input-time/foehn-input-time.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AACtD,OAAO,EAAE,yBAAyB,EAAE,MAAM,6CAA6C,CAAC;AACxF,OAAO,EAAE,mBAAmB,EAAE,MAAM,sCAAsC,CAAC;;;;;;AAE3E;;;GAGG;AACH,+DAA+D;AAC/D,SAAS,OAAO,CAAC,GAAW;IACxB,IAAI,GAAG,KAAK,SAAS,IAAI,GAAG,KAAK,IAAI,EAAE;QACnC,OAAO,EAAE,CAAC;KACb;IACD,IAAI,GAAG,CAAC,MAAM,GAAG,CAAC,EAAE;QAChB,OAAO,IAAI,GAAG,EAAE,CAAC;KACpB;IACD,OAAO,GAAG,CAAC;AACf,CAAC;AAaD,MAAM,OAAO,kBAAmB,SAAQ,yBAAyB;IAI7D,UAAU;QACN,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;QACxC,IAAI,OAAO,UAAU,KAAK,WAAW,EAAE;YACnC,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;SAClC;IACL,CAAC;IAED,eAAe;QACX,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;QACxC,IAAI,OAAO,UAAU,KAAK,WAAW,EAAE;YACnC,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC;SACjC;IACL,CAAC;IAED,aAAa,CAAC,KAAa;QACvB,MAAM,SAAS,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QACpD,IAAI,SAAS,IAAI,SAAS,CAAC,MAAM,IAAI,CAAC,EAAE;YACpC,IAAI,CAAC,IAAI,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;YACzB,IAAI,CAAC,MAAM,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;SAC9B;aAAM,IAAI,CAAC,KAAK,EAAE;YACf,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;YACjB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;SACtB;IACL,CAAC;IAEO,aAAa;QACjB,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YAC5B,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,EAAE;gBAC3B,OAAO,IAAI,CAAC;aACf;YAED,OAAO,SAAS,CAAC;SACpB;QACD,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;IAC3D,CAAC;;+GAtCQ,kBAAkB;mGAAlB,kBAAkB,2CARhB;QACP;YACI,OAAO,EAAE,mBAAmB;YAC5B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,kBAAkB,CAAC;YACjD,KAAK,EAAE,IAAI;SACd;KACJ,iDC5BL,4xGAwFA;2FD1Da,kBAAkB;kBAX9B,SAAS;+BACI,kBAAkB,aAEjB;wBACP;4BACI,OAAO,EAAE,mBAAmB;4BAC5B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,mBAAmB,CAAC;4BACjD,KAAK,EAAE,IAAI;yBACd;qBACJ","sourcesContent":["import { Component, forwardRef } from '@angular/core';\nimport { FoehnInputStringComponent } from '../foehn-input/foehn-input-string.component';\nimport { FoehnInputComponent } from '../foehn-input/foehn-input.component';\n\n/**\n * @param num as string\n * @returns string\n */\n// eslint-disable-next-line prefer-arrow/prefer-arrow-functions\nfunction leftPad(num: string): string {\n    if (num === undefined || num === null) {\n        return '';\n    }\n    if (num.length < 2) {\n        return `0${num}`;\n    }\n    return num;\n}\n\n@Component({\n    selector: 'foehn-input-time',\n    templateUrl: './foehn-input-time.component.html',\n    providers: [\n        {\n            provide: FoehnInputComponent,\n            useExisting: forwardRef(() => FoehnTimeComponent),\n            multi: true\n        }\n    ]\n})\nexport class FoehnTimeComponent extends FoehnInputStringComponent {\n    hour: string;\n    minute: string;\n\n    updateTime(): void {\n        const validValue = this.getValidValue();\n        if (typeof validValue !== 'undefined') {\n            this.updateNgModel(validValue);\n        }\n    }\n\n    handleUserInput(): void {\n        const validValue = this.getValidValue();\n        if (typeof validValue !== 'undefined') {\n            this.handleChange(validValue);\n        }\n    }\n\n    onModelChange(value: string): void {\n        const timeParts = !!value ? value.split(':') : null;\n        if (timeParts && timeParts.length >= 2) {\n            this.hour = timeParts[0];\n            this.minute = timeParts[1];\n        } else if (!value) {\n            this.hour = null;\n            this.minute = null;\n        }\n    }\n\n    private getValidValue(): string | null | undefined {\n        if (!this.hour || !this.minute) {\n            if (this.model_ !== undefined) {\n                return null;\n            }\n\n            return undefined;\n        }\n        return `${leftPad(this.hour)}:${leftPad(this.minute)}`;\n    }\n}\n","<div\n    class=\"form-group\"\n    [class.has-danger]=\"hasErrorsToDisplay()\"\n    [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n    [attr.id]=\"buildId('Container')\"\n    tabindex=\"-1\"\n>\n    <fieldset\n        class=\"mb-3\"\n        [attr.aria-describedby]=\"getDescribedBy()\"\n        [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n    >\n        <legend *ngIf=\"!!label\" [ngClass]=\"isLabelSrOnly ? 'sr-only' : 'vd-p'\">\n            <span [innerHTML]=\"label\"></span>\n            <span\n                *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n                aria-hidden=\"true\"\n            >\n                {{ 'foehn-input.optional' | fromDictionary }}\n            </span>\n        </legend>\n\n        <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n        <small\n            *ngIf=\"helpText\"\n            [attr.id]=\"buildId() + 'Help'\"\n            class=\"text-secondary\"\n            [innerHTML]=\"helpText\"\n        ></small>\n\n        <ng-content></ng-content>\n\n        <div class=\"vd-form-flex\">\n            <div\n                [ngClass]=\"{\n                    'vd-form-flex__item--3-char-width':\n                        displayClearButton() | async,\n                    'vd-form-flex__item--2-char-width': !(\n                        displayClearButton() | async\n                    )\n                }\"\n                class=\"vd-form-flex__item\"\n            >\n                <foehn-input-number\n                    [id]=\"buildId() + '_hours'\"\n                    [name]=\"name + '_hours'\"\n                    [label]=\"'foehn-input-time.hours.label' | fromDictionary\"\n                    [maxlength]=\"2\"\n                    [max]=\"24\"\n                    [(model)]=\"hour\"\n                    (focusout)=\"updateTime()\"\n                    [required]=\"required\"\n                    [hideNotRequiredExtraLabel]=\"true\"\n                    (userInput)=\"handleUserInput()\"\n                    [isErrorInherited]=\"hasErrorsToDisplay()\"\n                    [disabled]=\"disabled\"\n                    #entryComponent\n                ></foehn-input-number>\n            </div>\n            <div\n                [ngClass]=\"{\n                    'vd-form-flex__item--3-char-width':\n                        displayClearButton() | async,\n                    'vd-form-flex__item--2-char-width': !(\n                        displayClearButton() | async\n                    )\n                }\"\n                class=\"vd-form-flex__item\"\n            >\n                <foehn-input-number\n                    [id]=\"buildId() + '_minutes'\"\n                    [name]=\"name + '_minutes'\"\n                    [label]=\"'foehn-input-time.minutes.label' | fromDictionary\"\n                    [maxlength]=\"2\"\n                    [max]=\"59\"\n                    [(model)]=\"minute\"\n                    (focusout)=\"updateTime()\"\n                    [required]=\"required\"\n                    [hideNotRequiredExtraLabel]=\"true\"\n                    (userInput)=\"handleUserInput()\"\n                    [isErrorInherited]=\"hasErrorsToDisplay()\"\n                    [disabled]=\"disabled\"\n                ></foehn-input-number>\n            </div>\n        </div>\n    </fieldset>\n</div>\n"]}
75
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-input-time.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-input-time/foehn-input-time.component.ts","../../../../projects/prestations-ng/src/foehn-input-time/foehn-input-time.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AACtD,OAAO,EAAE,yBAAyB,EAAE,MAAM,6CAA6C,CAAC;AACxF,OAAO,EAAE,mBAAmB,EAAE,MAAM,sCAAsC,CAAC;;;;;;AAE3E;;;GAGG;AACH,+DAA+D;AAC/D,SAAS,OAAO,CAAC,GAAW;IACxB,IAAI,GAAG,KAAK,SAAS,IAAI,GAAG,KAAK,IAAI,EAAE;QACnC,OAAO,EAAE,CAAC;KACb;IACD,IAAI,GAAG,CAAC,MAAM,GAAG,CAAC,EAAE;QAChB,OAAO,IAAI,GAAG,EAAE,CAAC;KACpB;IACD,OAAO,GAAG,CAAC;AACf,CAAC;AAaD,MAAM,OAAO,kBAAmB,SAAQ,yBAAyB;IAI7D,UAAU;QACN,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;QACxC,IAAI,OAAO,UAAU,KAAK,WAAW,EAAE;YACnC,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;SAClC;IACL,CAAC;IAED,eAAe;QACX,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;QACxC,IAAI,OAAO,UAAU,KAAK,WAAW,EAAE;YACnC,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC;SACjC;IACL,CAAC;IAED,aAAa,CAAC,KAAa;QACvB,MAAM,SAAS,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QACpD,IAAI,SAAS,IAAI,SAAS,CAAC,MAAM,IAAI,CAAC,EAAE;YACpC,IAAI,CAAC,IAAI,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;YACzB,IAAI,CAAC,MAAM,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;SAC9B;aAAM,IAAI,CAAC,KAAK,EAAE;YACf,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;YACjB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;SACtB;IACL,CAAC;IAEO,aAAa;QACjB,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YAC5B,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS,EAAE;gBAC3B,OAAO,IAAI,CAAC;aACf;YAED,OAAO,SAAS,CAAC;SACpB;QACD,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;IAC3D,CAAC;;gHAtCQ,kBAAkB;oGAAlB,kBAAkB,2CARhB;QACP;YACI,OAAO,EAAE,mBAAmB;YAC5B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,kBAAkB,CAAC;YACjD,KAAK,EAAE,IAAI;SACd;KACJ,iDC5BL,s4GA0FA;4FD5Da,kBAAkB;kBAX9B,SAAS;+BACI,kBAAkB,aAEjB;wBACP;4BACI,OAAO,EAAE,mBAAmB;4BAC5B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,mBAAmB,CAAC;4BACjD,KAAK,EAAE,IAAI;yBACd;qBACJ","sourcesContent":["import { Component, forwardRef } from '@angular/core';\nimport { FoehnInputStringComponent } from '../foehn-input/foehn-input-string.component';\nimport { FoehnInputComponent } from '../foehn-input/foehn-input.component';\n\n/**\n * @param num as string\n * @returns string\n */\n// eslint-disable-next-line prefer-arrow/prefer-arrow-functions\nfunction leftPad(num: string): string {\n    if (num === undefined || num === null) {\n        return '';\n    }\n    if (num.length < 2) {\n        return `0${num}`;\n    }\n    return num;\n}\n\n@Component({\n    selector: 'foehn-input-time',\n    templateUrl: './foehn-input-time.component.html',\n    providers: [\n        {\n            provide: FoehnInputComponent,\n            useExisting: forwardRef(() => FoehnTimeComponent),\n            multi: true\n        }\n    ]\n})\nexport class FoehnTimeComponent extends FoehnInputStringComponent {\n    hour: string;\n    minute: string;\n\n    updateTime(): void {\n        const validValue = this.getValidValue();\n        if (typeof validValue !== 'undefined') {\n            this.updateNgModel(validValue);\n        }\n    }\n\n    handleUserInput(): void {\n        const validValue = this.getValidValue();\n        if (typeof validValue !== 'undefined') {\n            this.handleChange(validValue);\n        }\n    }\n\n    onModelChange(value: string): void {\n        const timeParts = !!value ? value.split(':') : null;\n        if (timeParts && timeParts.length >= 2) {\n            this.hour = timeParts[0];\n            this.minute = timeParts[1];\n        } else if (!value) {\n            this.hour = null;\n            this.minute = null;\n        }\n    }\n\n    private getValidValue(): string | null | undefined {\n        if (!this.hour || !this.minute) {\n            if (this.model_ !== undefined) {\n                return null;\n            }\n\n            return undefined;\n        }\n        return `${leftPad(this.hour)}:${leftPad(this.minute)}`;\n    }\n}\n","<div\n    class=\"form-group\"\n    [class.has-danger]=\"hasErrorsToDisplay()\"\n    [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n    [attr.id]=\"buildId('Container')\"\n    tabindex=\"-1\"\n>\n    <fieldset\n        class=\"mb-3\"\n        [attr.aria-describedby]=\"getDescribedBy()\"\n        [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n    >\n        <legend *ngIf=\"!!label\" [ngClass]=\"isLabelSrOnly ? 'sr-only' : 'vd-p'\">\n            <span [innerHTML]=\"label\"></span>\n            <span\n                *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n                aria-hidden=\"true\"\n            >\n                {{ 'foehn-input.optional' | fromDictionary }}\n            </span>\n        </legend>\n\n        <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n        <small\n            *ngIf=\"helpText\"\n            [attr.id]=\"buildId() + 'Help'\"\n            class=\"text-secondary\"\n            [innerHTML]=\"helpText\"\n        ></small>\n\n        <ng-content></ng-content>\n\n        <div class=\"vd-form-flex\">\n            <div\n                [ngClass]=\"{\n                    'vd-form-flex__item--3-char-width':\n                        displayClearButton() | async,\n                    'vd-form-flex__item--2-char-width': !(\n                        displayClearButton() | async\n                    )\n                }\"\n                class=\"vd-form-flex__item\"\n            >\n                <foehn-input-number\n                    [id]=\"buildId() + '_hours'\"\n                    [name]=\"name + '_hours'\"\n                    [label]=\"'foehn-input-time.hours.label' | fromDictionary\"\n                    [maxlength]=\"2\"\n                    [max]=\"24\"\n                    [(model)]=\"hour\"\n                    (focusout)=\"updateTime()\"\n                    [required]=\"required\"\n                    [hideNotRequiredExtraLabel]=\"true\"\n                    (userInput)=\"handleUserInput()\"\n                    [isErrorInherited]=\"hasErrorsToDisplay()\"\n                    [disabled]=\"disabled\"\n                    [hideStandardHelpText]=\"true\"\n                    #entryComponent\n                ></foehn-input-number>\n            </div>\n            <div\n                [ngClass]=\"{\n                    'vd-form-flex__item--3-char-width':\n                        displayClearButton() | async,\n                    'vd-form-flex__item--2-char-width': !(\n                        displayClearButton() | async\n                    )\n                }\"\n                class=\"vd-form-flex__item\"\n            >\n                <foehn-input-number\n                    [id]=\"buildId() + '_minutes'\"\n                    [name]=\"name + '_minutes'\"\n                    [label]=\"'foehn-input-time.minutes.label' | fromDictionary\"\n                    [maxlength]=\"2\"\n                    [max]=\"59\"\n                    [(model)]=\"minute\"\n                    (focusout)=\"updateTime()\"\n                    [required]=\"required\"\n                    [hideNotRequiredExtraLabel]=\"true\"\n                    (userInput)=\"handleUserInput()\"\n                    [isErrorInherited]=\"hasErrorsToDisplay()\"\n                    [disabled]=\"disabled\"\n                    [hideStandardHelpText]=\"true\"\n                ></foehn-input-number>\n            </div>\n        </div>\n    </fieldset>\n</div>\n"]}
@@ -96,9 +96,9 @@ export class FoehnListComponent {
96
96
  this.filteredList = this._list.slice(start, start + this.itemsPerPage);
97
97
  }
98
98
  }
99
- FoehnListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: FoehnListComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
100
- FoehnListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.5", type: FoehnListComponent, selector: "foehn-list", inputs: { itemsPerPage: "itemsPerPage", id: "id", previousLabel: "previousLabel", nextLabel: "nextLabel", fixedPageCount: "fixedPageCount", list: "list", trackByFn: "trackByFn" }, outputs: { pageChange: "pageChange" }, queries: [{ propertyName: "templateVariable", first: true, predicate: TemplateRef, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"row\" [id]=\"id\">\n <div class=\"col-lg-12 col-md-12 col-sm-12 col-xs-12\">\n <ul class=\"list-unstyled\">\n <li\n *ngFor=\"\n let item of filteredList;\n let index = index;\n trackBy: trackByFn\n \"\n >\n <ng-template\n [ngTemplateOutlet]=\"templateVariable\"\n [ngTemplateOutletContext]=\"{ item: item, index: index }\"\n ></ng-template>\n </li>\n </ul>\n\n <div class=\"row d-flex justify-content-between p-1\">\n <div class=\"col-lg-3 col-md-3 col-sm-6 col-xs-6\">\n <nav\n class=\"vd-pagination\"\n aria-label=\"Pagination\"\n *ngIf=\"hasPreviousPage()\"\n >\n <ul class=\"vd-pagination__list\">\n <li\n class=\"vd-pagination__item vd-pagination__item--previous\"\n >\n <button\n class=\"btn-link vd-pagination__link btn-no-extra vd-pagination__link-reset\"\n (click)=\"previousPage()\"\n >\n <span class=\"vd-pagination__title\">\n <foehn-icon-chevron-left></foehn-icon-chevron-left>\n {{ previousLabel }}\n </span>\n <span class=\"sr-only\">:</span>\n <span class=\"vd-pagination__label\">\n {{ currentPage - 1 }} sur {{ pagesCount() }}\n </span>\n </button>\n </li>\n </ul>\n </nav>\n </div>\n\n <div class=\"col-lg-3 col-md-3 col-sm-6 col-xs-6\">\n <nav\n class=\"vd-pagination\"\n aria-label=\"Pagination\"\n *ngIf=\"hasNextPage()\"\n >\n <ul class=\"vd-pagination__list\">\n <li\n class=\"vd-pagination__item vd-pagination__item--next\"\n >\n <button\n class=\"btn-link vd-pagination__link btn-no-extra vd-pagination__link-reset\"\n (click)=\"nextPage()\"\n >\n <span class=\"vd-pagination__title\">\n {{ nextLabel }}\n <foehn-icon-chevron-right></foehn-icon-chevron-right>\n </span>\n <span class=\"sr-only\">:</span>\n <span class=\"vd-pagination__label\">\n {{ currentPage + 1 }} sur {{ pagesCount() }}\n </span>\n </button>\n </li>\n </ul>\n </nav>\n </div>\n </div>\n </div>\n</div>\n", styles: [".btn-no-extra{padding:0;border:none;font-weight:400;-webkit-text-decoration-line:none;text-decoration-line:none}.vd-pagination__link-reset{background:none;border:none;font-weight:inherit;-webkit-text-decoration-line:none;text-decoration-line:none;text-align:inherit;cursor:pointer}.vd-pagination__link-reset:focus{background-color:var(--vd-focus)}\n"], components: [{ type: i1.FoehnIconChevronLeftComponent, selector: "foehn-icon-chevron-left" }, { type: i2.FoehnIconChevronRightComponent, selector: "foehn-icon-chevron-right" }], directives: [{ type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
101
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: FoehnListComponent, decorators: [{
99
+ FoehnListComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: FoehnListComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
100
+ FoehnListComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: FoehnListComponent, selector: "foehn-list", inputs: { itemsPerPage: "itemsPerPage", id: "id", previousLabel: "previousLabel", nextLabel: "nextLabel", fixedPageCount: "fixedPageCount", list: "list", trackByFn: "trackByFn" }, outputs: { pageChange: "pageChange" }, queries: [{ propertyName: "templateVariable", first: true, predicate: TemplateRef, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"row\" [id]=\"id\">\n <div class=\"col-lg-12 col-md-12 col-sm-12 col-xs-12\">\n <ul class=\"list-unstyled\">\n <li\n *ngFor=\"\n let item of filteredList;\n let index = index;\n trackBy: trackByFn\n \"\n >\n <ng-template\n [ngTemplateOutlet]=\"templateVariable\"\n [ngTemplateOutletContext]=\"{ item: item, index: index }\"\n ></ng-template>\n </li>\n </ul>\n\n <div class=\"row d-flex justify-content-between p-1\">\n <div class=\"col-lg-3 col-md-3 col-sm-6 col-xs-6\">\n <nav\n class=\"vd-pagination\"\n aria-label=\"Pagination\"\n *ngIf=\"hasPreviousPage()\"\n >\n <ul class=\"vd-pagination__list\">\n <li\n class=\"vd-pagination__item vd-pagination__item--previous\"\n >\n <button\n class=\"btn-link vd-pagination__link btn-no-extra vd-pagination__link-reset\"\n (click)=\"previousPage()\"\n >\n <span class=\"vd-pagination__title\">\n <foehn-icon-chevron-left></foehn-icon-chevron-left>\n {{ previousLabel }}\n </span>\n <span class=\"sr-only\">:</span>\n <span class=\"vd-pagination__label\">\n {{ currentPage - 1 }} sur {{ pagesCount() }}\n </span>\n </button>\n </li>\n </ul>\n </nav>\n </div>\n\n <div class=\"col-lg-3 col-md-3 col-sm-6 col-xs-6\">\n <nav\n class=\"vd-pagination\"\n aria-label=\"Pagination\"\n *ngIf=\"hasNextPage()\"\n >\n <ul class=\"vd-pagination__list\">\n <li\n class=\"vd-pagination__item vd-pagination__item--next\"\n >\n <button\n class=\"btn-link vd-pagination__link btn-no-extra vd-pagination__link-reset\"\n (click)=\"nextPage()\"\n >\n <span class=\"vd-pagination__title\">\n {{ nextLabel }}\n <foehn-icon-chevron-right></foehn-icon-chevron-right>\n </span>\n <span class=\"sr-only\">:</span>\n <span class=\"vd-pagination__label\">\n {{ currentPage + 1 }} sur {{ pagesCount() }}\n </span>\n </button>\n </li>\n </ul>\n </nav>\n </div>\n </div>\n </div>\n</div>\n", styles: [".btn-no-extra{padding:0;border:none;font-weight:400;-webkit-text-decoration-line:none;text-decoration-line:none}.vd-pagination__link-reset{background:none;border:none;font-weight:inherit;-webkit-text-decoration-line:none;text-decoration-line:none;text-align:inherit;cursor:pointer}.vd-pagination__link-reset:focus{background-color:var(--vd-focus)}\n"], components: [{ type: i1.FoehnIconChevronLeftComponent, selector: "foehn-icon-chevron-left" }, { type: i2.FoehnIconChevronRightComponent, selector: "foehn-icon-chevron-right" }], directives: [{ type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
101
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: FoehnListComponent, decorators: [{
102
102
  type: Component,
103
103
  args: [{ selector: 'foehn-list', template: "<div class=\"row\" [id]=\"id\">\n <div class=\"col-lg-12 col-md-12 col-sm-12 col-xs-12\">\n <ul class=\"list-unstyled\">\n <li\n *ngFor=\"\n let item of filteredList;\n let index = index;\n trackBy: trackByFn\n \"\n >\n <ng-template\n [ngTemplateOutlet]=\"templateVariable\"\n [ngTemplateOutletContext]=\"{ item: item, index: index }\"\n ></ng-template>\n </li>\n </ul>\n\n <div class=\"row d-flex justify-content-between p-1\">\n <div class=\"col-lg-3 col-md-3 col-sm-6 col-xs-6\">\n <nav\n class=\"vd-pagination\"\n aria-label=\"Pagination\"\n *ngIf=\"hasPreviousPage()\"\n >\n <ul class=\"vd-pagination__list\">\n <li\n class=\"vd-pagination__item vd-pagination__item--previous\"\n >\n <button\n class=\"btn-link vd-pagination__link btn-no-extra vd-pagination__link-reset\"\n (click)=\"previousPage()\"\n >\n <span class=\"vd-pagination__title\">\n <foehn-icon-chevron-left></foehn-icon-chevron-left>\n {{ previousLabel }}\n </span>\n <span class=\"sr-only\">:</span>\n <span class=\"vd-pagination__label\">\n {{ currentPage - 1 }} sur {{ pagesCount() }}\n </span>\n </button>\n </li>\n </ul>\n </nav>\n </div>\n\n <div class=\"col-lg-3 col-md-3 col-sm-6 col-xs-6\">\n <nav\n class=\"vd-pagination\"\n aria-label=\"Pagination\"\n *ngIf=\"hasNextPage()\"\n >\n <ul class=\"vd-pagination__list\">\n <li\n class=\"vd-pagination__item vd-pagination__item--next\"\n >\n <button\n class=\"btn-link vd-pagination__link btn-no-extra vd-pagination__link-reset\"\n (click)=\"nextPage()\"\n >\n <span class=\"vd-pagination__title\">\n {{ nextLabel }}\n <foehn-icon-chevron-right></foehn-icon-chevron-right>\n </span>\n <span class=\"sr-only\">:</span>\n <span class=\"vd-pagination__label\">\n {{ currentPage + 1 }} sur {{ pagesCount() }}\n </span>\n </button>\n </li>\n </ul>\n </nav>\n </div>\n </div>\n </div>\n</div>\n", styles: [".btn-no-extra{padding:0;border:none;font-weight:400;-webkit-text-decoration-line:none;text-decoration-line:none}.vd-pagination__link-reset{background:none;border:none;font-weight:inherit;-webkit-text-decoration-line:none;text-decoration-line:none;text-align:inherit;cursor:pointer}.vd-pagination__link-reset:focus{background-color:var(--vd-focus)}\n"] }]
104
104
  }], propDecorators: {
@@ -125,4 +125,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImpor
125
125
  trackByFn: [{
126
126
  type: Input
127
127
  }] } });
128
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-list.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-list/foehn-list.component.ts","../../../../projects/prestations-ng/src/foehn-list/foehn-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ContentChild,\n    EventEmitter,\n    Input,\n    OnChanges,\n    Output,\n    SimpleChange,\n    SimpleChanges,\n    TemplateRef\n} from '@angular/core';\nimport { PageChangeEvent } from './page-change-event';\nimport { ObjectHelper } from '../helpers/object.helper';\n\nconst hasInputChanged = (change: SimpleChange): boolean =>\n    change && !ObjectHelper.isEqual(change.previousValue, change.currentValue);\n\n@Component({\n    selector: 'foehn-list',\n    templateUrl: './foehn-list.component.html',\n    styleUrls: ['./foehn-list.component.css']\n})\nexport class FoehnListComponent implements OnChanges {\n    @ContentChild(TemplateRef)\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    templateVariable: TemplateRef<any>;\n\n    @Input()\n    itemsPerPage = 10;\n\n    @Input()\n    id = 'foehn-list';\n\n    @Input()\n    previousLabel = 'Précédent';\n\n    @Input()\n    nextLabel = 'Suivant';\n\n    @Input()\n    fixedPageCount: number;\n\n    @Output()\n    pageChange = new EventEmitter<PageChangeEvent>();\n\n    currentPage = 1;\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    filteredList: any[] = [];\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    private _list: any[];\n\n    @Input()\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    set list(list: any[]) {\n        this._list = list;\n    }\n\n    @Input()\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any,@typescript-eslint/no-unused-vars\n    trackByFn = (index: number, item: any): number => index;\n\n    ngOnChanges(changes: SimpleChanges): void {\n        const itemsPerPageChange: SimpleChange = changes.itemsPerPage;\n        const listChange: SimpleChange = changes.list;\n        const fixedPageCountChange: SimpleChange = changes.fixedPageCount;\n\n        if (\n            !hasInputChanged(itemsPerPageChange) &&\n            !hasInputChanged(listChange) &&\n            !hasInputChanged(fixedPageCountChange)\n        ) {\n            return;\n        }\n\n        this.buildFilteredList();\n    }\n\n    previousPage(): void {\n        this.currentPage = this.currentPage - 1;\n        this.buildFilteredList();\n        this.pageChange.next({\n            previousPage: this.currentPage + 1,\n            currentPage: this.currentPage,\n            pageCount: this.pagesCount()\n        });\n    }\n\n    hasPreviousPage(): boolean {\n        return this.currentPage > 1;\n    }\n\n    nextPage(): void {\n        this.currentPage = this.currentPage + 1;\n        this.buildFilteredList();\n\n        this.pageChange.next({\n            previousPage: this.currentPage - 1,\n            currentPage: this.currentPage,\n            pageCount: this.pagesCount()\n        });\n    }\n\n    hasNextPage(): boolean {\n        return this.currentPage < this.pagesCount();\n    }\n\n    showPage(page: number, emitPageChangeEvent: boolean = false): void {\n        if (this.currentPage === page) {\n            return;\n        }\n\n        const previousPage = this.currentPage;\n        this.currentPage = page;\n        this.buildFilteredList();\n\n        if (emitPageChangeEvent) {\n            this.pageChange.next({\n                previousPage,\n                currentPage: this.currentPage,\n                pageCount: this.pagesCount()\n            });\n        }\n    }\n\n    pagesCount(): number {\n        if (!!this.fixedPageCount) {\n            return this.fixedPageCount;\n        }\n\n        return this._list\n            ? Math.ceil(this._list.length / this.itemsPerPage)\n            : 0;\n    }\n\n    private buildFilteredList(): void {\n        if (!this._list) {\n            this.filteredList = [];\n            return;\n        }\n\n        if (!!this.fixedPageCount) {\n            this.filteredList = this._list;\n            return;\n        }\n\n        const currentPageExists =\n            (this.currentPage - 1) * this.itemsPerPage <= this._list.length;\n        if (!currentPageExists) {\n            this.currentPage = 1;\n        }\n        const start = (this.currentPage - 1) * this.itemsPerPage;\n        this.filteredList = this._list.slice(start, start + this.itemsPerPage);\n    }\n}\n","<div class=\"row\" [id]=\"id\">\n    <div class=\"col-lg-12 col-md-12 col-sm-12 col-xs-12\">\n        <ul class=\"list-unstyled\">\n            <li\n                *ngFor=\"\n                    let item of filteredList;\n                    let index = index;\n                    trackBy: trackByFn\n                \"\n            >\n                <ng-template\n                    [ngTemplateOutlet]=\"templateVariable\"\n                    [ngTemplateOutletContext]=\"{ item: item, index: index }\"\n                ></ng-template>\n            </li>\n        </ul>\n\n        <div class=\"row d-flex justify-content-between p-1\">\n            <div class=\"col-lg-3 col-md-3 col-sm-6 col-xs-6\">\n                <nav\n                    class=\"vd-pagination\"\n                    aria-label=\"Pagination\"\n                    *ngIf=\"hasPreviousPage()\"\n                >\n                    <ul class=\"vd-pagination__list\">\n                        <li\n                            class=\"vd-pagination__item vd-pagination__item--previous\"\n                        >\n                            <button\n                                class=\"btn-link vd-pagination__link btn-no-extra vd-pagination__link-reset\"\n                                (click)=\"previousPage()\"\n                            >\n                                <span class=\"vd-pagination__title\">\n                                    <foehn-icon-chevron-left></foehn-icon-chevron-left>\n                                    {{ previousLabel }}\n                                </span>\n                                <span class=\"sr-only\">:</span>\n                                <span class=\"vd-pagination__label\">\n                                    {{ currentPage - 1 }} sur {{ pagesCount() }}\n                                </span>\n                            </button>\n                        </li>\n                    </ul>\n                </nav>\n            </div>\n\n            <div class=\"col-lg-3 col-md-3 col-sm-6 col-xs-6\">\n                <nav\n                    class=\"vd-pagination\"\n                    aria-label=\"Pagination\"\n                    *ngIf=\"hasNextPage()\"\n                >\n                    <ul class=\"vd-pagination__list\">\n                        <li\n                            class=\"vd-pagination__item vd-pagination__item--next\"\n                        >\n                            <button\n                                class=\"btn-link vd-pagination__link btn-no-extra vd-pagination__link-reset\"\n                                (click)=\"nextPage()\"\n                            >\n                                <span class=\"vd-pagination__title\">\n                                    {{ nextLabel }}\n                                    <foehn-icon-chevron-right></foehn-icon-chevron-right>\n                                </span>\n                                <span class=\"sr-only\">:</span>\n                                <span class=\"vd-pagination__label\">\n                                    {{ currentPage + 1 }} sur {{ pagesCount() }}\n                                </span>\n                            </button>\n                        </li>\n                    </ul>\n                </nav>\n            </div>\n        </div>\n    </div>\n</div>\n"]}
128
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-list.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-list/foehn-list.component.ts","../../../../projects/prestations-ng/src/foehn-list/foehn-list.component.html"],"names":[],"mappings":"AAAA,OAAO,EACH,SAAS,EACT,YAAY,EACZ,YAAY,EACZ,KAAK,EAEL,MAAM,EAGN,WAAW,EACd,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAC;;;;;AAExD,MAAM,eAAe,GAAG,CAAC,MAAoB,EAAW,EAAE,CACtD,MAAM,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,MAAM,CAAC,aAAa,EAAE,MAAM,CAAC,YAAY,CAAC,CAAC;AAO/E,MAAM,OAAO,kBAAkB;IAL/B;QAWI,iBAAY,GAAG,EAAE,CAAC;QAGlB,OAAE,GAAG,YAAY,CAAC;QAGlB,kBAAa,GAAG,WAAW,CAAC;QAG5B,cAAS,GAAG,SAAS,CAAC;QAMtB,eAAU,GAAG,IAAI,YAAY,EAAmB,CAAC;QAEjD,gBAAW,GAAG,CAAC,CAAC;QAEhB,8DAA8D;QAC9D,iBAAY,GAAU,EAAE,CAAC;QAYzB,gGAAgG;QAChG,cAAS,GAAG,CAAC,KAAa,EAAE,IAAS,EAAU,EAAE,CAAC,KAAK,CAAC;KA8F3D;IAtGG,IAEI,IAAI,CAAC,IAAW;QAChB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;IACtB,CAAC;IAMD,WAAW,CAAC,OAAsB;QAC9B,MAAM,kBAAkB,GAAiB,OAAO,CAAC,YAAY,CAAC;QAC9D,MAAM,UAAU,GAAiB,OAAO,CAAC,IAAI,CAAC;QAC9C,MAAM,oBAAoB,GAAiB,OAAO,CAAC,cAAc,CAAC;QAElE,IACI,CAAC,eAAe,CAAC,kBAAkB,CAAC;YACpC,CAAC,eAAe,CAAC,UAAU,CAAC;YAC5B,CAAC,eAAe,CAAC,oBAAoB,CAAC,EACxC;YACE,OAAO;SACV;QAED,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC7B,CAAC;IAED,YAAY;QACR,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC;QACxC,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC;YACjB,YAAY,EAAE,IAAI,CAAC,WAAW,GAAG,CAAC;YAClC,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,SAAS,EAAE,IAAI,CAAC,UAAU,EAAE;SAC/B,CAAC,CAAC;IACP,CAAC;IAED,eAAe;QACX,OAAO,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC;IAChC,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC;QACxC,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAEzB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC;YACjB,YAAY,EAAE,IAAI,CAAC,WAAW,GAAG,CAAC;YAClC,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,SAAS,EAAE,IAAI,CAAC,UAAU,EAAE;SAC/B,CAAC,CAAC;IACP,CAAC;IAED,WAAW;QACP,OAAO,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;IAChD,CAAC;IAED,QAAQ,CAAC,IAAY,EAAE,sBAA+B,KAAK;QACvD,IAAI,IAAI,CAAC,WAAW,KAAK,IAAI,EAAE;YAC3B,OAAO;SACV;QAED,MAAM,YAAY,GAAG,IAAI,CAAC,WAAW,CAAC;QACtC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAEzB,IAAI,mBAAmB,EAAE;YACrB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC;gBACjB,YAAY;gBACZ,WAAW,EAAE,IAAI,CAAC,WAAW;gBAC7B,SAAS,EAAE,IAAI,CAAC,UAAU,EAAE;aAC/B,CAAC,CAAC;SACN;IACL,CAAC;IAED,UAAU;QACN,IAAI,CAAC,CAAC,IAAI,CAAC,cAAc,EAAE;YACvB,OAAO,IAAI,CAAC,cAAc,CAAC;SAC9B;QAED,OAAO,IAAI,CAAC,KAAK;YACb,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC;YAClD,CAAC,CAAC,CAAC,CAAC;IACZ,CAAC;IAEO,iBAAiB;QACrB,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;YACb,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;YACvB,OAAO;SACV;QAED,IAAI,CAAC,CAAC,IAAI,CAAC,cAAc,EAAE;YACvB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC;YAC/B,OAAO;SACV;QAED,MAAM,iBAAiB,GACnB,CAAC,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;QACpE,IAAI,CAAC,iBAAiB,EAAE;YACpB,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC;SACxB;QACD,MAAM,KAAK,GAAG,CAAC,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC;QACzD,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,EAAE,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC;IAC3E,CAAC;;gHApIQ,kBAAkB;oGAAlB,kBAAkB,2TACb,WAAW,qECvB7B,gyGA4EA;4FDtDa,kBAAkB;kBAL9B,SAAS;+BACI,YAAY;;QAMtB,8DAA8D;QAC9D,gBAAgB;sBAFf,YAAY;uBAAC,WAAW;gBAKzB,YAAY;sBADX,KAAK;gBAIN,EAAE;sBADD,KAAK;gBAIN,aAAa;sBADZ,KAAK;gBAIN,SAAS;sBADR,KAAK;gBAIN,cAAc;sBADb,KAAK;gBAIN,UAAU;sBADT,MAAM;gBAaH,IAAI;sBAFP,KAAK;;QAON,gGAAgG;QAChG,SAAS;sBAFR,KAAK","sourcesContent":["import {\n    Component,\n    ContentChild,\n    EventEmitter,\n    Input,\n    OnChanges,\n    Output,\n    SimpleChange,\n    SimpleChanges,\n    TemplateRef\n} from '@angular/core';\nimport { PageChangeEvent } from './page-change-event';\nimport { ObjectHelper } from '../helpers/object.helper';\n\nconst hasInputChanged = (change: SimpleChange): boolean =>\n    change && !ObjectHelper.isEqual(change.previousValue, change.currentValue);\n\n@Component({\n    selector: 'foehn-list',\n    templateUrl: './foehn-list.component.html',\n    styleUrls: ['./foehn-list.component.css']\n})\nexport class FoehnListComponent implements OnChanges {\n    @ContentChild(TemplateRef)\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    templateVariable: TemplateRef<any>;\n\n    @Input()\n    itemsPerPage = 10;\n\n    @Input()\n    id = 'foehn-list';\n\n    @Input()\n    previousLabel = 'Précédent';\n\n    @Input()\n    nextLabel = 'Suivant';\n\n    @Input()\n    fixedPageCount: number;\n\n    @Output()\n    pageChange = new EventEmitter<PageChangeEvent>();\n\n    currentPage = 1;\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    filteredList: any[] = [];\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    private _list: any[];\n\n    @Input()\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    set list(list: any[]) {\n        this._list = list;\n    }\n\n    @Input()\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any,@typescript-eslint/no-unused-vars\n    trackByFn = (index: number, item: any): number => index;\n\n    ngOnChanges(changes: SimpleChanges): void {\n        const itemsPerPageChange: SimpleChange = changes.itemsPerPage;\n        const listChange: SimpleChange = changes.list;\n        const fixedPageCountChange: SimpleChange = changes.fixedPageCount;\n\n        if (\n            !hasInputChanged(itemsPerPageChange) &&\n            !hasInputChanged(listChange) &&\n            !hasInputChanged(fixedPageCountChange)\n        ) {\n            return;\n        }\n\n        this.buildFilteredList();\n    }\n\n    previousPage(): void {\n        this.currentPage = this.currentPage - 1;\n        this.buildFilteredList();\n        this.pageChange.next({\n            previousPage: this.currentPage + 1,\n            currentPage: this.currentPage,\n            pageCount: this.pagesCount()\n        });\n    }\n\n    hasPreviousPage(): boolean {\n        return this.currentPage > 1;\n    }\n\n    nextPage(): void {\n        this.currentPage = this.currentPage + 1;\n        this.buildFilteredList();\n\n        this.pageChange.next({\n            previousPage: this.currentPage - 1,\n            currentPage: this.currentPage,\n            pageCount: this.pagesCount()\n        });\n    }\n\n    hasNextPage(): boolean {\n        return this.currentPage < this.pagesCount();\n    }\n\n    showPage(page: number, emitPageChangeEvent: boolean = false): void {\n        if (this.currentPage === page) {\n            return;\n        }\n\n        const previousPage = this.currentPage;\n        this.currentPage = page;\n        this.buildFilteredList();\n\n        if (emitPageChangeEvent) {\n            this.pageChange.next({\n                previousPage,\n                currentPage: this.currentPage,\n                pageCount: this.pagesCount()\n            });\n        }\n    }\n\n    pagesCount(): number {\n        if (!!this.fixedPageCount) {\n            return this.fixedPageCount;\n        }\n\n        return this._list\n            ? Math.ceil(this._list.length / this.itemsPerPage)\n            : 0;\n    }\n\n    private buildFilteredList(): void {\n        if (!this._list) {\n            this.filteredList = [];\n            return;\n        }\n\n        if (!!this.fixedPageCount) {\n            this.filteredList = this._list;\n            return;\n        }\n\n        const currentPageExists =\n            (this.currentPage - 1) * this.itemsPerPage <= this._list.length;\n        if (!currentPageExists) {\n            this.currentPage = 1;\n        }\n        const start = (this.currentPage - 1) * this.itemsPerPage;\n        this.filteredList = this._list.slice(start, start + this.itemsPerPage);\n    }\n}\n","<div class=\"row\" [id]=\"id\">\n    <div class=\"col-lg-12 col-md-12 col-sm-12 col-xs-12\">\n        <ul class=\"list-unstyled\">\n            <li\n                *ngFor=\"\n                    let item of filteredList;\n                    let index = index;\n                    trackBy: trackByFn\n                \"\n            >\n                <ng-template\n                    [ngTemplateOutlet]=\"templateVariable\"\n                    [ngTemplateOutletContext]=\"{ item: item, index: index }\"\n                ></ng-template>\n            </li>\n        </ul>\n\n        <div class=\"row d-flex justify-content-between p-1\">\n            <div class=\"col-lg-3 col-md-3 col-sm-6 col-xs-6\">\n                <nav\n                    class=\"vd-pagination\"\n                    aria-label=\"Pagination\"\n                    *ngIf=\"hasPreviousPage()\"\n                >\n                    <ul class=\"vd-pagination__list\">\n                        <li\n                            class=\"vd-pagination__item vd-pagination__item--previous\"\n                        >\n                            <button\n                                class=\"btn-link vd-pagination__link btn-no-extra vd-pagination__link-reset\"\n                                (click)=\"previousPage()\"\n                            >\n                                <span class=\"vd-pagination__title\">\n                                    <foehn-icon-chevron-left></foehn-icon-chevron-left>\n                                    {{ previousLabel }}\n                                </span>\n                                <span class=\"sr-only\">:</span>\n                                <span class=\"vd-pagination__label\">\n                                    {{ currentPage - 1 }} sur {{ pagesCount() }}\n                                </span>\n                            </button>\n                        </li>\n                    </ul>\n                </nav>\n            </div>\n\n            <div class=\"col-lg-3 col-md-3 col-sm-6 col-xs-6\">\n                <nav\n                    class=\"vd-pagination\"\n                    aria-label=\"Pagination\"\n                    *ngIf=\"hasNextPage()\"\n                >\n                    <ul class=\"vd-pagination__list\">\n                        <li\n                            class=\"vd-pagination__item vd-pagination__item--next\"\n                        >\n                            <button\n                                class=\"btn-link vd-pagination__link btn-no-extra vd-pagination__link-reset\"\n                                (click)=\"nextPage()\"\n                            >\n                                <span class=\"vd-pagination__title\">\n                                    {{ nextLabel }}\n                                    <foehn-icon-chevron-right></foehn-icon-chevron-right>\n                                </span>\n                                <span class=\"sr-only\">:</span>\n                                <span class=\"vd-pagination__label\">\n                                    {{ currentPage + 1 }} sur {{ pagesCount() }}\n                                </span>\n                            </button>\n                        </li>\n                    </ul>\n                </nav>\n            </div>\n        </div>\n    </div>\n</div>\n"]}
@@ -5,10 +5,10 @@ import { FoehnIconsModule } from '../foehn-icons/foehn-icons.module';
5
5
  import * as i0 from "@angular/core";
6
6
  export class FoehnListModule {
7
7
  }
8
- FoehnListModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: FoehnListModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
9
- FoehnListModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: FoehnListModule, declarations: [FoehnListComponent], imports: [CommonModule, FoehnIconsModule], exports: [FoehnListComponent] });
10
- FoehnListModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: FoehnListModule, imports: [[CommonModule, FoehnIconsModule]] });
11
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: FoehnListModule, decorators: [{
8
+ FoehnListModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: FoehnListModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
9
+ FoehnListModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: FoehnListModule, declarations: [FoehnListComponent], imports: [CommonModule, FoehnIconsModule], exports: [FoehnListComponent] });
10
+ FoehnListModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: FoehnListModule, imports: [[CommonModule, FoehnIconsModule]] });
11
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: FoehnListModule, decorators: [{
12
12
  type: NgModule,
13
13
  args: [{
14
14
  imports: [CommonModule, FoehnIconsModule],
@@ -16,4 +16,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImpor
16
16
  exports: [FoehnListComponent]
17
17
  }]
18
18
  }] });
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9laG4tbGlzdC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9wcmVzdGF0aW9ucy1uZy9zcmMvZm9laG4tbGlzdC9mb2Vobi1saXN0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUUvQyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUM1RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQzs7QUFPckUsTUFBTSxPQUFPLGVBQWU7OzRHQUFmLGVBQWU7NkdBQWYsZUFBZSxpQkFIVCxrQkFBa0IsYUFEdkIsWUFBWSxFQUFFLGdCQUFnQixhQUU5QixrQkFBa0I7NkdBRW5CLGVBQWUsWUFKZixDQUFDLFlBQVksRUFBRSxnQkFBZ0IsQ0FBQzsyRkFJaEMsZUFBZTtrQkFMM0IsUUFBUTttQkFBQztvQkFDTixPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsZ0JBQWdCLENBQUM7b0JBQ3pDLFlBQVksRUFBRSxDQUFDLGtCQUFrQixDQUFDO29CQUNsQyxPQUFPLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQztpQkFDaEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcblxuaW1wb3J0IHsgRm9laG5MaXN0Q29tcG9uZW50IH0gZnJvbSAnLi9mb2Vobi1saXN0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBGb2Vobkljb25zTW9kdWxlIH0gZnJvbSAnLi4vZm9laG4taWNvbnMvZm9laG4taWNvbnMubW9kdWxlJztcblxuQE5nTW9kdWxlKHtcbiAgICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBGb2Vobkljb25zTW9kdWxlXSxcbiAgICBkZWNsYXJhdGlvbnM6IFtGb2Vobkxpc3RDb21wb25lbnRdLFxuICAgIGV4cG9ydHM6IFtGb2Vobkxpc3RDb21wb25lbnRdXG59KVxuZXhwb3J0IGNsYXNzIEZvZWhuTGlzdE1vZHVsZSB7fVxuIl19
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9laG4tbGlzdC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9wcmVzdGF0aW9ucy1uZy9zcmMvZm9laG4tbGlzdC9mb2Vobi1saXN0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUUvQyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUM1RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQzs7QUFPckUsTUFBTSxPQUFPLGVBQWU7OzZHQUFmLGVBQWU7OEdBQWYsZUFBZSxpQkFIVCxrQkFBa0IsYUFEdkIsWUFBWSxFQUFFLGdCQUFnQixhQUU5QixrQkFBa0I7OEdBRW5CLGVBQWUsWUFKZixDQUFDLFlBQVksRUFBRSxnQkFBZ0IsQ0FBQzs0RkFJaEMsZUFBZTtrQkFMM0IsUUFBUTttQkFBQztvQkFDTixPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsZ0JBQWdCLENBQUM7b0JBQ3pDLFlBQVksRUFBRSxDQUFDLGtCQUFrQixDQUFDO29CQUNsQyxPQUFPLEVBQUUsQ0FBQyxrQkFBa0IsQ0FBQztpQkFDaEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcblxuaW1wb3J0IHsgRm9laG5MaXN0Q29tcG9uZW50IH0gZnJvbSAnLi9mb2Vobi1saXN0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBGb2Vobkljb25zTW9kdWxlIH0gZnJvbSAnLi4vZm9laG4taWNvbnMvZm9laG4taWNvbnMubW9kdWxlJztcblxuQE5nTW9kdWxlKHtcbiAgICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBGb2Vobkljb25zTW9kdWxlXSxcbiAgICBkZWNsYXJhdGlvbnM6IFtGb2Vobkxpc3RDb21wb25lbnRdLFxuICAgIGV4cG9ydHM6IFtGb2Vobkxpc3RDb21wb25lbnRdXG59KVxuZXhwb3J0IGNsYXNzIEZvZWhuTGlzdE1vZHVsZSB7fVxuIl19
@@ -114,9 +114,9 @@ export class AbstractListDetailPageComponent extends AbstractPageFromMenuCompone
114
114
  });
115
115
  }
116
116
  }
117
- AbstractListDetailPageComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: AbstractListDetailPageComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.FoehnConfirmModalService }, { token: i1.Router }, { token: i3.Location }], target: i0.ɵɵFactoryTarget.Directive });
118
- AbstractListDetailPageComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.5", type: AbstractListDetailPageComponent, usesInheritance: true, ngImport: i0 });
119
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: AbstractListDetailPageComponent, decorators: [{
117
+ AbstractListDetailPageComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AbstractListDetailPageComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.FoehnConfirmModalService }, { token: i1.Router }, { token: i3.Location }], target: i0.ɵɵFactoryTarget.Directive });
118
+ AbstractListDetailPageComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.11", type: AbstractListDetailPageComponent, usesInheritance: true, ngImport: i0 });
119
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AbstractListDetailPageComponent, decorators: [{
120
120
  type: Directive
121
121
  }], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i2.FoehnConfirmModalService }, { type: i1.Router }, { type: i3.Location }]; } });
122
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-list-item-detail-page.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-menu-prestation/abstract-list-item-detail-page.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, OnDestroy, OnInit } from '@angular/core';\nimport { ActivatedRoute, Router } from '@angular/router';\n\nimport { first } from 'rxjs/operators';\nimport { Subscription } from 'rxjs';\nimport { Location } from '@angular/common';\nimport { AbstractPageFromMenuComponent } from './abstract-page-from-menu.component';\nimport { FoehnListItem } from './foehn-list-summary/foehn-list-item';\nimport { FoehnConfirmModalService } from '../foehn-confirm-modal/foehn-confirm-modal.service';\nimport { I18nForm } from '../i18n-form';\n\n@Directive()\nexport abstract class AbstractListDetailPageComponent<\n        FORM_TYPE extends I18nForm,\n        ITEM_TYPE extends FoehnListItem\n    >\n    extends AbstractPageFromMenuComponent<FORM_TYPE>\n    implements OnInit, OnDestroy {\n    list: ITEM_TYPE[];\n    itemIndex: number = null;\n    private formSub: Subscription;\n\n    constructor(\n        protected activatedRoute: ActivatedRoute,\n        protected confirmModalService: FoehnConfirmModalService,\n        protected router: Router,\n        protected location: Location\n    ) {\n        super(activatedRoute, confirmModalService);\n    }\n\n    get itemToEdit(): ITEM_TYPE {\n        return this.getList()[this.itemIndex];\n    }\n\n    ngOnInit(): void {\n        super.ngOnInit();\n        this.formSub = this._gesdemEventService\n            .formInitializationObservable()\n            .pipe(first())\n            .subscribe(() => {\n                const indexParam = this.activatedRoute.snapshot.paramMap.get(\n                    'index'\n                );\n                const showErrorsOnPageLoad = !!indexParam;\n\n                this.list = this.getList();\n\n                if (indexParam) {\n                    this.assignItemIndex(Number(indexParam));\n                } else {\n                    this.loadNewItem();\n                }\n\n                this.scrollToSpecifiedElement();\n\n                if (showErrorsOnPageLoad) {\n                    this.showErrors();\n                }\n            });\n    }\n\n    ngOnDestroy(): void {\n        super.ngOnDestroy();\n        if (this.formSub) {\n            this.formSub.unsubscribe();\n        }\n        this.resetBreadCrumb();\n    }\n\n    protected getNextTrackingIndex(): number {\n        if (!this.list || !this.list.length) {\n            return 1;\n        }\n        return this.list[this.list.length - 1].trackingIndex + 1;\n    }\n\n    protected returnToParent(): void {\n        this.router.navigate([\n            this._gesdemService.lastResponse.meta.reference,\n            this.getListPagePath()\n        ]);\n    }\n\n    protected resetBreadCrumb(): void {\n        this._breadcrumbEventService\n            .breadcrumbObservable()\n            .pipe(first())\n            .subscribe(breadCrumb => {\n                breadCrumb.breadcrumbItems.pop();\n                this._breadcrumbEventService.setBreadcrumb(breadCrumb);\n            });\n    }\n\n    protected appendPageToBreadCrumb(): void {\n        this._breadcrumbEventService\n            .breadcrumbObservable()\n            .pipe(first())\n            .subscribe(breadCrumb => {\n                breadCrumb.breadcrumbItems.push({\n                    url: null,\n                    routerLink: `${\n                        this._gesdemService.lastResponse.meta.reference\n                    }/${this.getListPagePath()}`,\n                    label: this.getListPageLabel(),\n                    skipLeavingAlert: true\n                });\n                this._breadcrumbEventService.setBreadcrumb(breadCrumb);\n            });\n    }\n\n    private loadNewItem(): void {\n        const newItem = this.getNewListItem();\n        newItem.trackingIndex = this.getNextTrackingIndex();\n        this.list.push(newItem);\n        this.itemIndex = this.list.length - 1;\n\n        const currentUrl = this.router\n            .createUrlTree([], { relativeTo: this.activatedRoute })\n            .toString();\n        this.location.go(`${currentUrl}/${this.itemIndex}`);\n    }\n\n    private assignItemIndex(index: number): void {\n        if (index >= this.list.length) {\n            // index does not exist, return to list\n            window.history.back();\n        }\n        this.itemIndex = index;\n    }\n\n    private scrollToSpecifiedElement(): void {\n        if (this.activatedRoute.snapshot.queryParamMap.get('scrollTo')) {\n            setTimeout(() => {\n                const componentContainerId = `${this.activatedRoute.snapshot.queryParamMap.get(\n                    'scrollTo'\n                )}Container`;\n                document.getElementById(componentContainerId).scrollIntoView();\n                document.getElementById(componentContainerId).focus();\n            });\n        }\n    }\n\n    private showErrors(): void {\n        setTimeout(() => {\n            this.foehnFormComponent.reset();\n            this._validationHandlerService.shouldDisplayErrors(true);\n            this._validationHandlerService.updateErrors(\n                this._gesdemService.lastResponse.errors\n            );\n        });\n    }\n\n    abstract getList(): ITEM_TYPE[];\n\n    abstract getNewListItem(): ITEM_TYPE;\n\n    abstract getListPagePath(): string;\n\n    abstract getListPageLabel(): string;\n}\n"]}
122
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-list-item-detail-page.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-menu-prestation/abstract-list-item-detail-page.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, OnDestroy, OnInit } from '@angular/core';\nimport { ActivatedRoute, Router } from '@angular/router';\n\nimport { first } from 'rxjs/operators';\nimport { Subscription } from 'rxjs';\nimport { Location } from '@angular/common';\nimport { AbstractPageFromMenuComponent } from './abstract-page-from-menu.component';\nimport { FoehnListItem } from './foehn-list-summary/foehn-list-item';\nimport { FoehnConfirmModalService } from '../foehn-confirm-modal/foehn-confirm-modal.service';\nimport { I18nForm } from '../i18n-form';\n\n@Directive()\nexport abstract class AbstractListDetailPageComponent<\n        FORM_TYPE extends I18nForm,\n        ITEM_TYPE extends FoehnListItem\n    >\n    extends AbstractPageFromMenuComponent<FORM_TYPE>\n    implements OnInit, OnDestroy {\n    list: ITEM_TYPE[];\n    itemIndex: number = null;\n    private formSub: Subscription;\n\n    constructor(\n        protected activatedRoute: ActivatedRoute,\n        protected confirmModalService: FoehnConfirmModalService,\n        protected router: Router,\n        protected location: Location\n    ) {\n        super(activatedRoute, confirmModalService);\n    }\n\n    get itemToEdit(): ITEM_TYPE {\n        return this.getList()[this.itemIndex];\n    }\n\n    ngOnInit(): void {\n        super.ngOnInit();\n        this.formSub = this._gesdemEventService\n            .formInitializationObservable()\n            .pipe(first())\n            .subscribe(() => {\n                const indexParam = this.activatedRoute.snapshot.paramMap.get(\n                    'index'\n                );\n                const showErrorsOnPageLoad = !!indexParam;\n\n                this.list = this.getList();\n\n                if (indexParam) {\n                    this.assignItemIndex(Number(indexParam));\n                } else {\n                    this.loadNewItem();\n                }\n\n                this.scrollToSpecifiedElement();\n\n                if (showErrorsOnPageLoad) {\n                    this.showErrors();\n                }\n            });\n    }\n\n    ngOnDestroy(): void {\n        super.ngOnDestroy();\n        if (this.formSub) {\n            this.formSub.unsubscribe();\n        }\n        this.resetBreadCrumb();\n    }\n\n    protected getNextTrackingIndex(): number {\n        if (!this.list || !this.list.length) {\n            return 1;\n        }\n        return this.list[this.list.length - 1].trackingIndex + 1;\n    }\n\n    protected returnToParent(): void {\n        this.router.navigate([\n            this._gesdemService.lastResponse.meta.reference,\n            this.getListPagePath()\n        ]);\n    }\n\n    protected resetBreadCrumb(): void {\n        this._breadcrumbEventService\n            .breadcrumbObservable()\n            .pipe(first())\n            .subscribe(breadCrumb => {\n                breadCrumb.breadcrumbItems.pop();\n                this._breadcrumbEventService.setBreadcrumb(breadCrumb);\n            });\n    }\n\n    protected appendPageToBreadCrumb(): void {\n        this._breadcrumbEventService\n            .breadcrumbObservable()\n            .pipe(first())\n            .subscribe(breadCrumb => {\n                breadCrumb.breadcrumbItems.push({\n                    url: null,\n                    routerLink: `${\n                        this._gesdemService.lastResponse.meta.reference\n                    }/${this.getListPagePath()}`,\n                    label: this.getListPageLabel(),\n                    skipLeavingAlert: true\n                });\n                this._breadcrumbEventService.setBreadcrumb(breadCrumb);\n            });\n    }\n\n    private loadNewItem(): void {\n        const newItem = this.getNewListItem();\n        newItem.trackingIndex = this.getNextTrackingIndex();\n        this.list.push(newItem);\n        this.itemIndex = this.list.length - 1;\n\n        const currentUrl = this.router\n            .createUrlTree([], { relativeTo: this.activatedRoute })\n            .toString();\n        this.location.go(`${currentUrl}/${this.itemIndex}`);\n    }\n\n    private assignItemIndex(index: number): void {\n        if (index >= this.list.length) {\n            // index does not exist, return to list\n            window.history.back();\n        }\n        this.itemIndex = index;\n    }\n\n    private scrollToSpecifiedElement(): void {\n        if (this.activatedRoute.snapshot.queryParamMap.get('scrollTo')) {\n            setTimeout(() => {\n                const componentContainerId = `${this.activatedRoute.snapshot.queryParamMap.get(\n                    'scrollTo'\n                )}Container`;\n                document.getElementById(componentContainerId).scrollIntoView();\n                document.getElementById(componentContainerId).focus();\n            });\n        }\n    }\n\n    private showErrors(): void {\n        setTimeout(() => {\n            this.foehnFormComponent.reset();\n            this._validationHandlerService.shouldDisplayErrors(true);\n            this._validationHandlerService.updateErrors(\n                this._gesdemService.lastResponse.errors\n            );\n        });\n    }\n\n    abstract getList(): ITEM_TYPE[];\n\n    abstract getNewListItem(): ITEM_TYPE;\n\n    abstract getListPagePath(): string;\n\n    abstract getListPageLabel(): string;\n}\n"]}
@@ -23,9 +23,9 @@ export class AbstractMenuPageComponent extends AbstractPageComponent {
23
23
  });
24
24
  }
25
25
  }
26
- AbstractMenuPageComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: AbstractMenuPageComponent, deps: [{ token: i1.ActivatedRoute }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Directive });
27
- AbstractMenuPageComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.5", type: AbstractMenuPageComponent, usesInheritance: true, ngImport: i0 });
28
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: AbstractMenuPageComponent, decorators: [{
26
+ AbstractMenuPageComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AbstractMenuPageComponent, deps: [{ token: i1.ActivatedRoute }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Directive });
27
+ AbstractMenuPageComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.11", type: AbstractMenuPageComponent, usesInheritance: true, ngImport: i0 });
28
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AbstractMenuPageComponent, decorators: [{
29
29
  type: Directive
30
30
  }], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i0.NgZone }]; } });
31
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWJzdHJhY3QtbWVudS1wYWdlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3ByZXN0YXRpb25zLW5nL3NyYy9mb2Vobi1tZW51LXByZXN0YXRpb24vYWJzdHJhY3QtbWVudS1wYWdlLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQXlCLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNqRSxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFdkMsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7OztBQUluRSxNQUFNLE9BQWdCLHlCQUNsQixTQUFRLHFCQUF3QjtJQUVoQyxZQUNjLGNBQThCLEVBQzlCLE1BQWM7UUFFeEIsS0FBSyxDQUFDLGNBQWMsQ0FBQyxDQUFDO1FBSFosbUJBQWMsR0FBZCxjQUFjLENBQWdCO1FBQzlCLFdBQU0sR0FBTixNQUFNLENBQVE7SUFHNUIsQ0FBQztJQUVELGVBQWU7UUFDWCxLQUFLLENBQUMsZUFBZSxFQUFFLENBQUM7UUFFeEIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ3RELE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxHQUFHLENBQzNELFVBQVUsQ0FDYixDQUFDO1lBQ0YsSUFBSSxDQUFDLENBQUMsUUFBUSxFQUFFO2dCQUNaLE1BQU0sU0FBUyxHQUFHLFFBQVEsQ0FBQyxjQUFjLENBQUMsUUFBUSxDQUFDLENBQUM7Z0JBQ3BELElBQUksQ0FBQyxDQUFDLFNBQVMsRUFBRTtvQkFDYixTQUFTLENBQUMsY0FBYyxFQUFFLENBQUM7b0JBQzNCLFNBQVMsQ0FBQyxLQUFLLEVBQUUsQ0FBQztpQkFDckI7YUFDSjtRQUNMLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQzs7c0hBekJpQix5QkFBeUI7MEdBQXpCLHlCQUF5QjsyRkFBekIseUJBQXlCO2tCQUQ5QyxTQUFTIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQWZ0ZXJWaWV3SW5pdCwgTmdab25lLCBEaXJlY3RpdmUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGZpcnN0IH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuaW1wb3J0IHsgQWN0aXZhdGVkUm91dGUgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuaW1wb3J0IHsgQWJzdHJhY3RQYWdlQ29tcG9uZW50IH0gZnJvbSAnLi4vYWJzdHJhY3QtcGFnZS1jb21wb25lbnQnO1xuaW1wb3J0IHsgSTE4bkZvcm0gfSBmcm9tICcuLi9pMThuLWZvcm0nO1xuXG5ARGlyZWN0aXZlKClcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBBYnN0cmFjdE1lbnVQYWdlQ29tcG9uZW50PFQgZXh0ZW5kcyBJMThuRm9ybT5cbiAgICBleHRlbmRzIEFic3RyYWN0UGFnZUNvbXBvbmVudDxUPlxuICAgIGltcGxlbWVudHMgQWZ0ZXJWaWV3SW5pdCB7XG4gICAgY29uc3RydWN0b3IoXG4gICAgICAgIHByb3RlY3RlZCBhY3RpdmF0ZWRSb3V0ZTogQWN0aXZhdGVkUm91dGUsXG4gICAgICAgIHByb3RlY3RlZCBuZ1pvbmU6IE5nWm9uZVxuICAgICkge1xuICAgICAgICBzdXBlcihhY3RpdmF0ZWRSb3V0ZSk7XG4gICAgfVxuXG4gICAgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xuICAgICAgICBzdXBlci5uZ0FmdGVyVmlld0luaXQoKTtcblxuICAgICAgICB0aGlzLm5nWm9uZS5vbk1pY3JvdGFza0VtcHR5LnBpcGUoZmlyc3QoKSkuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgICAgICAgIGNvbnN0IHNjcm9sbFRvID0gdGhpcy5hY3RpdmF0ZWRSb3V0ZS5zbmFwc2hvdC5xdWVyeVBhcmFtTWFwLmdldChcbiAgICAgICAgICAgICAgICAnc2Nyb2xsVG8nXG4gICAgICAgICAgICApO1xuICAgICAgICAgICAgaWYgKCEhc2Nyb2xsVG8pIHtcbiAgICAgICAgICAgICAgICBjb25zdCBvbkVsZW1lbnQgPSBkb2N1bWVudC5nZXRFbGVtZW50QnlJZChzY3JvbGxUbyk7XG4gICAgICAgICAgICAgICAgaWYgKCEhb25FbGVtZW50KSB7XG4gICAgICAgICAgICAgICAgICAgIG9uRWxlbWVudC5zY3JvbGxJbnRvVmlldygpO1xuICAgICAgICAgICAgICAgICAgICBvbkVsZW1lbnQuZm9jdXMoKTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgIH0pO1xuICAgIH1cbn1cbiJdfQ==
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWJzdHJhY3QtbWVudS1wYWdlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3ByZXN0YXRpb25zLW5nL3NyYy9mb2Vobi1tZW51LXByZXN0YXRpb24vYWJzdHJhY3QtbWVudS1wYWdlLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQXlCLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNqRSxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFdkMsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7OztBQUluRSxNQUFNLE9BQWdCLHlCQUNsQixTQUFRLHFCQUF3QjtJQUVoQyxZQUNjLGNBQThCLEVBQzlCLE1BQWM7UUFFeEIsS0FBSyxDQUFDLGNBQWMsQ0FBQyxDQUFDO1FBSFosbUJBQWMsR0FBZCxjQUFjLENBQWdCO1FBQzlCLFdBQU0sR0FBTixNQUFNLENBQVE7SUFHNUIsQ0FBQztJQUVELGVBQWU7UUFDWCxLQUFLLENBQUMsZUFBZSxFQUFFLENBQUM7UUFFeEIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ3RELE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxHQUFHLENBQzNELFVBQVUsQ0FDYixDQUFDO1lBQ0YsSUFBSSxDQUFDLENBQUMsUUFBUSxFQUFFO2dCQUNaLE1BQU0sU0FBUyxHQUFHLFFBQVEsQ0FBQyxjQUFjLENBQUMsUUFBUSxDQUFDLENBQUM7Z0JBQ3BELElBQUksQ0FBQyxDQUFDLFNBQVMsRUFBRTtvQkFDYixTQUFTLENBQUMsY0FBYyxFQUFFLENBQUM7b0JBQzNCLFNBQVMsQ0FBQyxLQUFLLEVBQUUsQ0FBQztpQkFDckI7YUFDSjtRQUNMLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQzs7dUhBekJpQix5QkFBeUI7MkdBQXpCLHlCQUF5Qjs0RkFBekIseUJBQXlCO2tCQUQ5QyxTQUFTIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQWZ0ZXJWaWV3SW5pdCwgTmdab25lLCBEaXJlY3RpdmUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGZpcnN0IH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuaW1wb3J0IHsgQWN0aXZhdGVkUm91dGUgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuaW1wb3J0IHsgQWJzdHJhY3RQYWdlQ29tcG9uZW50IH0gZnJvbSAnLi4vYWJzdHJhY3QtcGFnZS1jb21wb25lbnQnO1xuaW1wb3J0IHsgSTE4bkZvcm0gfSBmcm9tICcuLi9pMThuLWZvcm0nO1xuXG5ARGlyZWN0aXZlKClcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBBYnN0cmFjdE1lbnVQYWdlQ29tcG9uZW50PFQgZXh0ZW5kcyBJMThuRm9ybT5cbiAgICBleHRlbmRzIEFic3RyYWN0UGFnZUNvbXBvbmVudDxUPlxuICAgIGltcGxlbWVudHMgQWZ0ZXJWaWV3SW5pdCB7XG4gICAgY29uc3RydWN0b3IoXG4gICAgICAgIHByb3RlY3RlZCBhY3RpdmF0ZWRSb3V0ZTogQWN0aXZhdGVkUm91dGUsXG4gICAgICAgIHByb3RlY3RlZCBuZ1pvbmU6IE5nWm9uZVxuICAgICkge1xuICAgICAgICBzdXBlcihhY3RpdmF0ZWRSb3V0ZSk7XG4gICAgfVxuXG4gICAgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xuICAgICAgICBzdXBlci5uZ0FmdGVyVmlld0luaXQoKTtcblxuICAgICAgICB0aGlzLm5nWm9uZS5vbk1pY3JvdGFza0VtcHR5LnBpcGUoZmlyc3QoKSkuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgICAgICAgIGNvbnN0IHNjcm9sbFRvID0gdGhpcy5hY3RpdmF0ZWRSb3V0ZS5zbmFwc2hvdC5xdWVyeVBhcmFtTWFwLmdldChcbiAgICAgICAgICAgICAgICAnc2Nyb2xsVG8nXG4gICAgICAgICAgICApO1xuICAgICAgICAgICAgaWYgKCEhc2Nyb2xsVG8pIHtcbiAgICAgICAgICAgICAgICBjb25zdCBvbkVsZW1lbnQgPSBkb2N1bWVudC5nZXRFbGVtZW50QnlJZChzY3JvbGxUbyk7XG4gICAgICAgICAgICAgICAgaWYgKCEhb25FbGVtZW50KSB7XG4gICAgICAgICAgICAgICAgICAgIG9uRWxlbWVudC5zY3JvbGxJbnRvVmlldygpO1xuICAgICAgICAgICAgICAgICAgICBvbkVsZW1lbnQuZm9jdXMoKTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgIH0pO1xuICAgIH1cbn1cbiJdfQ==
@@ -79,9 +79,9 @@ export class AbstractPageFromMenuComponent extends AbstractPageComponent {
79
79
  () => { });
80
80
  }
81
81
  }
82
- AbstractPageFromMenuComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: AbstractPageFromMenuComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.FoehnConfirmModalService }], target: i0.ɵɵFactoryTarget.Directive });
83
- AbstractPageFromMenuComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.5", type: AbstractPageFromMenuComponent, usesInheritance: true, ngImport: i0 });
84
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.5", ngImport: i0, type: AbstractPageFromMenuComponent, decorators: [{
82
+ AbstractPageFromMenuComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AbstractPageFromMenuComponent, deps: [{ token: i1.ActivatedRoute }, { token: i2.FoehnConfirmModalService }], target: i0.ɵɵFactoryTarget.Directive });
83
+ AbstractPageFromMenuComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.11", type: AbstractPageFromMenuComponent, usesInheritance: true, ngImport: i0 });
84
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AbstractPageFromMenuComponent, decorators: [{
85
85
  type: Directive
86
86
  }], ctorParameters: function () { return [{ type: i1.ActivatedRoute }, { type: i2.FoehnConfirmModalService }]; } });
87
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWJzdHJhY3QtcGFnZS1mcm9tLW1lbnUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJlc3RhdGlvbnMtbmcvc3JjL2ZvZWhuLW1lbnUtcHJlc3RhdGlvbi9hYnN0cmFjdC1wYWdlLWZyb20tbWVudS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUNsRCxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFdkMsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7Ozs7QUFLbkUsTUFBTSxPQUFnQiw2QkFDbEIsU0FBUSxxQkFBd0I7SUFFaEMsWUFDYyxjQUE4QixFQUM5QixtQkFBNkM7UUFFdkQsS0FBSyxDQUFDLGNBQWMsQ0FBQyxDQUFDO1FBSFosbUJBQWMsR0FBZCxjQUFjLENBQWdCO1FBQzlCLHdCQUFtQixHQUFuQixtQkFBbUIsQ0FBMEI7SUFHM0QsQ0FBQztJQUVELFFBQVE7UUFDSixLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDakIsSUFBSSxDQUFDLHNCQUFzQixFQUFFLENBQUM7SUFDbEMsQ0FBQztJQUVTLFVBQVUsQ0FBQyxZQUFxQjtRQUN0QyxJQUFJLElBQUksQ0FBQyxrQkFBa0IsRUFBRTtZQUN6QixnQ0FBZ0M7WUFDaEMsSUFBSSxDQUFDLGtCQUFrQixDQUFDLEtBQUssRUFBRSxDQUFDO1NBQ25DO1FBRUQsTUFBTSxPQUFPO1FBQ1QsZ0NBQWdDO1FBQ2hDLENBQUMsSUFBSSxDQUFDLGtCQUFrQjtZQUN4QixDQUFDLElBQUksQ0FBQyxrQkFBa0I7Z0JBQ3BCLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxPQUFPLEVBQUU7Z0JBQ2pDLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBRXpELElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUN6QyxJQUFJLENBQUMsY0FBYyxDQUFDLFlBQVksQ0FDbkMsQ0FBQztRQUVGLElBQUksQ0FBQyxZQUFZLEVBQUU7WUFDZixPQUFPO1NBQ1Y7UUFDRCxJQUFJLE9BQU8sRUFBRTtZQUNULElBQUksQ0FBQyxjQUFjLEVBQUUsQ0FBQztTQUN6QjthQUFNO1lBQ0gsSUFBSSxDQUFDLDZCQUE2QixFQUFFLENBQUM7U0FDeEM7SUFDTCxDQUFDO0lBRVMsY0FBYztRQUNwQixJQUFJLENBQUMsdUJBQXVCO2FBQ3ZCLG9CQUFvQixFQUFFO2FBQ3RCLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQzthQUNiLFNBQVMsQ0FBQyxVQUFVLENBQUMsRUFBRTtZQUNwQixVQUFVLENBQUMsZUFBZSxDQUFDLEdBQUcsRUFBRSxDQUFDO1lBQ2pDLElBQUksQ0FBQyx1QkFBdUIsQ0FBQyxhQUFhLENBQUMsVUFBVSxDQUFDLENBQUM7WUFDdkQsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUM1QixDQUFDLENBQUMsQ0FBQztJQUNYLENBQUM7SUFFUyxzQkFBc0I7UUFDNUIsSUFBSSxDQUFDLHVCQUF1QjthQUN2QixvQkFBb0IsRUFBRTthQUN0QixJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7YUFDYixTQUFTLENBQUMsVUFBVSxDQUFDLEVBQUU7WUFDcEIsTUFBTSxVQUFVLEdBQ1osSUFBSSxDQUFDLGNBQWMsQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLFNBQVM7Z0JBQy9DLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztZQUN2QixNQUFNLFFBQVEsR0FBRyxVQUFVLENBQUMsZUFBZSxDQUFDLElBQUksQ0FDNUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsVUFBVSxLQUFLLFVBQVUsQ0FDbkMsQ0FBQztZQUVGLElBQUksQ0FBQyxRQUFRLEVBQUU7Z0JBQ1gsVUFBVSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUM7b0JBQzVCLEdBQUcsRUFBRSxJQUFJO29CQUNULFVBQVU7b0JBQ1YsS0FBSyxFQUFFLElBQUksQ0FBQyxZQUFZLEVBQUU7b0JBQzFCLGdCQUFnQixFQUFFLElBQUk7aUJBQ3pCLENBQUMsQ0FBQztnQkFDSCxJQUFJLENBQUMsdUJBQXVCLENBQUMsYUFBYSxDQUFDLFVBQVUsQ0FBQyxDQUFDO2FBQzFEO1FBQ0wsQ0FBQyxDQUFDLENBQUM7SUFDWCxDQUFDO0lBRU8sNkJBQTZCO1FBQ2pDLElBQUksQ0FBQyxtQkFBbUI7YUFDbkIsZ0JBQWdCLENBQUM7WUFDZCxXQUFXLEVBQ1AseUVBQXlFO2dCQUN6RSxVQUFVO2dCQUNWLHVDQUF1QztZQUMzQyxhQUFhLEVBQUUsMEJBQTBCO1lBQ3pDLGlCQUFpQixFQUFFLHNCQUFzQjtTQUM1QyxDQUFDO2FBQ0QsSUFBSSxDQUNELEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxjQUFjLEVBQUU7UUFDM0IsZ0VBQWdFO1FBQ2hFLEdBQUcsRUFBRSxHQUFFLENBQUMsQ0FDWCxDQUFDO0lBQ1YsQ0FBQzs7MEhBNUZpQiw2QkFBNkI7OEdBQTdCLDZCQUE2QjsyRkFBN0IsNkJBQTZCO2tCQURsRCxTQUFTIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGZpcnN0IH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuaW1wb3J0IHsgQWN0aXZhdGVkUm91dGUgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuaW1wb3J0IHsgQWJzdHJhY3RQYWdlQ29tcG9uZW50IH0gZnJvbSAnLi4vYWJzdHJhY3QtcGFnZS1jb21wb25lbnQnO1xuaW1wb3J0IHsgRm9laG5Db25maXJtTW9kYWxTZXJ2aWNlIH0gZnJvbSAnLi4vZm9laG4tY29uZmlybS1tb2RhbC9mb2Vobi1jb25maXJtLW1vZGFsLnNlcnZpY2UnO1xuaW1wb3J0IHsgSTE4bkZvcm0gfSBmcm9tICcuLi9pMThuLWZvcm0nO1xuXG5ARGlyZWN0aXZlKClcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBBYnN0cmFjdFBhZ2VGcm9tTWVudUNvbXBvbmVudDxUIGV4dGVuZHMgSTE4bkZvcm0+XG4gICAgZXh0ZW5kcyBBYnN0cmFjdFBhZ2VDb21wb25lbnQ8VD5cbiAgICBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gICAgY29uc3RydWN0b3IoXG4gICAgICAgIHByb3RlY3RlZCBhY3RpdmF0ZWRSb3V0ZTogQWN0aXZhdGVkUm91dGUsXG4gICAgICAgIHByb3RlY3RlZCBjb25maXJtTW9kYWxTZXJ2aWNlOiBGb2VobkNvbmZpcm1Nb2RhbFNlcnZpY2VcbiAgICApIHtcbiAgICAgICAgc3VwZXIoYWN0aXZhdGVkUm91dGUpO1xuICAgIH1cblxuICAgIG5nT25Jbml0KCk6IHZvaWQge1xuICAgICAgICBzdXBlci5uZ09uSW5pdCgpO1xuICAgICAgICB0aGlzLmFwcGVuZFBhZ2VUb0JyZWFkQ3J1bWIoKTtcbiAgICB9XG5cbiAgICBwcm90ZWN0ZWQgb25Gb3JtU2VudChnb1RvTmV4dFBhZ2U6IGJvb2xlYW4pOiB2b2lkIHtcbiAgICAgICAgaWYgKHRoaXMuZm9laG5Gb3JtQ29tcG9uZW50KSB7XG4gICAgICAgICAgICAvLyBTb21lIHBhZ2VzIGRvbid0IGhhdmUgYSBmb3JtLlxuICAgICAgICAgICAgdGhpcy5mb2VobkZvcm1Db21wb25lbnQucmVzZXQoKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbnN0IGlzVmFsaWQgPVxuICAgICAgICAgICAgLy8gU29tZSBwYWdlcyBkb24ndCBoYXZlIGEgZm9ybS5cbiAgICAgICAgICAgICF0aGlzLmZvZWhuRm9ybUNvbXBvbmVudCB8fFxuICAgICAgICAgICAgKHRoaXMuZm9laG5Gb3JtQ29tcG9uZW50ICYmXG4gICAgICAgICAgICAgICAgdGhpcy5mb2VobkZvcm1Db21wb25lbnQuaXNWYWxpZCgpICYmXG4gICAgICAgICAgICAgICAgIXRoaXMuX2dlc2RlbVNlcnZpY2UubGFzdFJlc3BvbnNlLm1ldGEuY3JpdGljYWwpO1xuXG4gICAgICAgIHRoaXMuX2dlc2RlbUV2ZW50U2VydmljZS5mb3JtU2VudFN1YmplY3QubmV4dChcbiAgICAgICAgICAgIHRoaXMuX2dlc2RlbVNlcnZpY2UubGFzdFJlc3BvbnNlXG4gICAgICAgICk7XG5cbiAgICAgICAgaWYgKCFnb1RvTmV4dFBhZ2UpIHtcbiAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuICAgICAgICBpZiAoaXNWYWxpZCkge1xuICAgICAgICAgICAgdGhpcy5yZXR1cm5Ub1BhcmVudCgpO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgdGhpcy5kaXNwbGF5TW9kYWxFcnJvckNvbmZpcm1hdGlvbigpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHJvdGVjdGVkIHJldHVyblRvUGFyZW50KCk6IHZvaWQge1xuICAgICAgICB0aGlzLl9icmVhZGNydW1iRXZlbnRTZXJ2aWNlXG4gICAgICAgICAgICAuYnJlYWRjcnVtYk9ic2VydmFibGUoKVxuICAgICAgICAgICAgLnBpcGUoZmlyc3QoKSlcbiAgICAgICAgICAgIC5zdWJzY3JpYmUoYnJlYWRDcnVtYiA9PiB7XG4gICAgICAgICAgICAgICAgYnJlYWRDcnVtYi5icmVhZGNydW1iSXRlbXMucG9wKCk7XG4gICAgICAgICAgICAgICAgdGhpcy5fYnJlYWRjcnVtYkV2ZW50U2VydmljZS5zZXRCcmVhZGNydW1iKGJyZWFkQ3J1bWIpO1xuICAgICAgICAgICAgICAgIHRoaXMuX25hdmlnYXRpb24ubmV4dCgpO1xuICAgICAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgcHJvdGVjdGVkIGFwcGVuZFBhZ2VUb0JyZWFkQ3J1bWIoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuX2JyZWFkY3J1bWJFdmVudFNlcnZpY2VcbiAgICAgICAgICAgIC5icmVhZGNydW1iT2JzZXJ2YWJsZSgpXG4gICAgICAgICAgICAucGlwZShmaXJzdCgpKVxuICAgICAgICAgICAgLnN1YnNjcmliZShicmVhZENydW1iID0+IHtcbiAgICAgICAgICAgICAgICBjb25zdCByb3V0ZXJMaW5rID1cbiAgICAgICAgICAgICAgICAgICAgdGhpcy5fZ2VzZGVtU2VydmljZS5sYXN0UmVzcG9uc2UubWV0YS5yZWZlcmVuY2UgK1xuICAgICAgICAgICAgICAgICAgICB0aGlzLmdldE1lbnVQYXRoKCk7XG4gICAgICAgICAgICAgICAgY29uc3QgaGFzQ3J1bWIgPSBicmVhZENydW1iLmJyZWFkY3J1bWJJdGVtcy5maW5kKFxuICAgICAgICAgICAgICAgICAgICBiID0+IGIucm91dGVyTGluayA9PT0gcm91dGVyTGlua1xuICAgICAgICAgICAgICAgICk7XG5cbiAgICAgICAgICAgICAgICBpZiAoIWhhc0NydW1iKSB7XG4gICAgICAgICAgICAgICAgICAgIGJyZWFkQ3J1bWIuYnJlYWRjcnVtYkl0ZW1zLnB1c2goe1xuICAgICAgICAgICAgICAgICAgICAgICAgdXJsOiBudWxsLFxuICAgICAgICAgICAgICAgICAgICAgICAgcm91dGVyTGluayxcbiAgICAgICAgICAgICAgICAgICAgICAgIGxhYmVsOiB0aGlzLmdldE1lbnVMYWJlbCgpLFxuICAgICAgICAgICAgICAgICAgICAgICAgc2tpcExlYXZpbmdBbGVydDogdHJ1ZVxuICAgICAgICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgICAgICAgICAgdGhpcy5fYnJlYWRjcnVtYkV2ZW50U2VydmljZS5zZXRCcmVhZGNydW1iKGJyZWFkQ3J1bWIpO1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH0pO1xuICAgIH1cblxuICAgIHByaXZhdGUgZGlzcGxheU1vZGFsRXJyb3JDb25maXJtYXRpb24oKTogdm9pZCB7XG4gICAgICAgIHRoaXMuY29uZmlybU1vZGFsU2VydmljZVxuICAgICAgICAgICAgLm9wZW5Db25maXJtTW9kYWwoe1xuICAgICAgICAgICAgICAgIGh0bWxDb250ZW50OlxuICAgICAgICAgICAgICAgICAgICAnVm9zIGRvbm7DqWVzIG9udCBiaWVuIMOpdMOpIHNhdXZlZ2FyZMOpZXMuIENlcGVuZGFudCwgaWwgcmVzdGUgZGVzIGVycmV1cnMuJyArXG4gICAgICAgICAgICAgICAgICAgICc8YnI+PGJyPicgK1xuICAgICAgICAgICAgICAgICAgICAnU291aGFpdGV6LXZvdXMgcXVhbmQgbcOqbWUgY29udGludWVyID8nLFxuICAgICAgICAgICAgICAgIG9rQnV0dG9uTGFiZWw6ICdQb3Vyc3VpdnJlIHNhbnMgY29ycmlnZXInLFxuICAgICAgICAgICAgICAgIGNhbmNlbEJ1dHRvbkxhYmVsOiAnQ29ycmlnZXIgbGVzIGVycmV1cnMnXG4gICAgICAgICAgICB9KVxuICAgICAgICAgICAgLnRoZW4oXG4gICAgICAgICAgICAgICAgKCkgPT4gdGhpcy5yZXR1cm5Ub1BhcmVudCgpLFxuICAgICAgICAgICAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZW1wdHktZnVuY3Rpb25cbiAgICAgICAgICAgICAgICAoKSA9PiB7fVxuICAgICAgICAgICAgKTtcbiAgICB9XG5cbiAgICBwcm90ZWN0ZWQgYWJzdHJhY3QgZ2V0TWVudVBhdGgoKTogc3RyaW5nO1xuXG4gICAgcHJvdGVjdGVkIGFic3RyYWN0IGdldE1lbnVMYWJlbCgpOiBzdHJpbmc7XG59XG4iXX0=
87
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWJzdHJhY3QtcGFnZS1mcm9tLW1lbnUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJlc3RhdGlvbnMtbmcvc3JjL2ZvZWhuLW1lbnUtcHJlc3RhdGlvbi9hYnN0cmFjdC1wYWdlLWZyb20tbWVudS5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUNsRCxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFdkMsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7Ozs7QUFLbkUsTUFBTSxPQUFnQiw2QkFDbEIsU0FBUSxxQkFBd0I7SUFFaEMsWUFDYyxjQUE4QixFQUM5QixtQkFBNkM7UUFFdkQsS0FBSyxDQUFDLGNBQWMsQ0FBQyxDQUFDO1FBSFosbUJBQWMsR0FBZCxjQUFjLENBQWdCO1FBQzlCLHdCQUFtQixHQUFuQixtQkFBbUIsQ0FBMEI7SUFHM0QsQ0FBQztJQUVELFFBQVE7UUFDSixLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDakIsSUFBSSxDQUFDLHNCQUFzQixFQUFFLENBQUM7SUFDbEMsQ0FBQztJQUVTLFVBQVUsQ0FBQyxZQUFxQjtRQUN0QyxJQUFJLElBQUksQ0FBQyxrQkFBa0IsRUFBRTtZQUN6QixnQ0FBZ0M7WUFDaEMsSUFBSSxDQUFDLGtCQUFrQixDQUFDLEtBQUssRUFBRSxDQUFDO1NBQ25DO1FBRUQsTUFBTSxPQUFPO1FBQ1QsZ0NBQWdDO1FBQ2hDLENBQUMsSUFBSSxDQUFDLGtCQUFrQjtZQUN4QixDQUFDLElBQUksQ0FBQyxrQkFBa0I7Z0JBQ3BCLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxPQUFPLEVBQUU7Z0JBQ2pDLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBRXpELElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUN6QyxJQUFJLENBQUMsY0FBYyxDQUFDLFlBQVksQ0FDbkMsQ0FBQztRQUVGLElBQUksQ0FBQyxZQUFZLEVBQUU7WUFDZixPQUFPO1NBQ1Y7UUFDRCxJQUFJLE9BQU8sRUFBRTtZQUNULElBQUksQ0FBQyxjQUFjLEVBQUUsQ0FBQztTQUN6QjthQUFNO1lBQ0gsSUFBSSxDQUFDLDZCQUE2QixFQUFFLENBQUM7U0FDeEM7SUFDTCxDQUFDO0lBRVMsY0FBYztRQUNwQixJQUFJLENBQUMsdUJBQXVCO2FBQ3ZCLG9CQUFvQixFQUFFO2FBQ3RCLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQzthQUNiLFNBQVMsQ0FBQyxVQUFVLENBQUMsRUFBRTtZQUNwQixVQUFVLENBQUMsZUFBZSxDQUFDLEdBQUcsRUFBRSxDQUFDO1lBQ2pDLElBQUksQ0FBQyx1QkFBdUIsQ0FBQyxhQUFhLENBQUMsVUFBVSxDQUFDLENBQUM7WUFDdkQsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQUUsQ0FBQztRQUM1QixDQUFDLENBQUMsQ0FBQztJQUNYLENBQUM7SUFFUyxzQkFBc0I7UUFDNUIsSUFBSSxDQUFDLHVCQUF1QjthQUN2QixvQkFBb0IsRUFBRTthQUN0QixJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7YUFDYixTQUFTLENBQUMsVUFBVSxDQUFDLEVBQUU7WUFDcEIsTUFBTSxVQUFVLEdBQ1osSUFBSSxDQUFDLGNBQWMsQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLFNBQVM7Z0JBQy9DLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztZQUN2QixNQUFNLFFBQVEsR0FBRyxVQUFVLENBQUMsZUFBZSxDQUFDLElBQUksQ0FDNUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsVUFBVSxLQUFLLFVBQVUsQ0FDbkMsQ0FBQztZQUVGLElBQUksQ0FBQyxRQUFRLEVBQUU7Z0JBQ1gsVUFBVSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUM7b0JBQzVCLEdBQUcsRUFBRSxJQUFJO29CQUNULFVBQVU7b0JBQ1YsS0FBSyxFQUFFLElBQUksQ0FBQyxZQUFZLEVBQUU7b0JBQzFCLGdCQUFnQixFQUFFLElBQUk7aUJBQ3pCLENBQUMsQ0FBQztnQkFDSCxJQUFJLENBQUMsdUJBQXVCLENBQUMsYUFBYSxDQUFDLFVBQVUsQ0FBQyxDQUFDO2FBQzFEO1FBQ0wsQ0FBQyxDQUFDLENBQUM7SUFDWCxDQUFDO0lBRU8sNkJBQTZCO1FBQ2pDLElBQUksQ0FBQyxtQkFBbUI7YUFDbkIsZ0JBQWdCLENBQUM7WUFDZCxXQUFXLEVBQ1AseUVBQXlFO2dCQUN6RSxVQUFVO2dCQUNWLHVDQUF1QztZQUMzQyxhQUFhLEVBQUUsMEJBQTBCO1lBQ3pDLGlCQUFpQixFQUFFLHNCQUFzQjtTQUM1QyxDQUFDO2FBQ0QsSUFBSSxDQUNELEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxjQUFjLEVBQUU7UUFDM0IsZ0VBQWdFO1FBQ2hFLEdBQUcsRUFBRSxHQUFFLENBQUMsQ0FDWCxDQUFDO0lBQ1YsQ0FBQzs7MkhBNUZpQiw2QkFBNkI7K0dBQTdCLDZCQUE2Qjs0RkFBN0IsNkJBQTZCO2tCQURsRCxTQUFTIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IGZpcnN0IH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuaW1wb3J0IHsgQWN0aXZhdGVkUm91dGUgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuaW1wb3J0IHsgQWJzdHJhY3RQYWdlQ29tcG9uZW50IH0gZnJvbSAnLi4vYWJzdHJhY3QtcGFnZS1jb21wb25lbnQnO1xuaW1wb3J0IHsgRm9laG5Db25maXJtTW9kYWxTZXJ2aWNlIH0gZnJvbSAnLi4vZm9laG4tY29uZmlybS1tb2RhbC9mb2Vobi1jb25maXJtLW1vZGFsLnNlcnZpY2UnO1xuaW1wb3J0IHsgSTE4bkZvcm0gfSBmcm9tICcuLi9pMThuLWZvcm0nO1xuXG5ARGlyZWN0aXZlKClcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBBYnN0cmFjdFBhZ2VGcm9tTWVudUNvbXBvbmVudDxUIGV4dGVuZHMgSTE4bkZvcm0+XG4gICAgZXh0ZW5kcyBBYnN0cmFjdFBhZ2VDb21wb25lbnQ8VD5cbiAgICBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gICAgY29uc3RydWN0b3IoXG4gICAgICAgIHByb3RlY3RlZCBhY3RpdmF0ZWRSb3V0ZTogQWN0aXZhdGVkUm91dGUsXG4gICAgICAgIHByb3RlY3RlZCBjb25maXJtTW9kYWxTZXJ2aWNlOiBGb2VobkNvbmZpcm1Nb2RhbFNlcnZpY2VcbiAgICApIHtcbiAgICAgICAgc3VwZXIoYWN0aXZhdGVkUm91dGUpO1xuICAgIH1cblxuICAgIG5nT25Jbml0KCk6IHZvaWQge1xuICAgICAgICBzdXBlci5uZ09uSW5pdCgpO1xuICAgICAgICB0aGlzLmFwcGVuZFBhZ2VUb0JyZWFkQ3J1bWIoKTtcbiAgICB9XG5cbiAgICBwcm90ZWN0ZWQgb25Gb3JtU2VudChnb1RvTmV4dFBhZ2U6IGJvb2xlYW4pOiB2b2lkIHtcbiAgICAgICAgaWYgKHRoaXMuZm9laG5Gb3JtQ29tcG9uZW50KSB7XG4gICAgICAgICAgICAvLyBTb21lIHBhZ2VzIGRvbid0IGhhdmUgYSBmb3JtLlxuICAgICAgICAgICAgdGhpcy5mb2VobkZvcm1Db21wb25lbnQucmVzZXQoKTtcbiAgICAgICAgfVxuXG4gICAgICAgIGNvbnN0IGlzVmFsaWQgPVxuICAgICAgICAgICAgLy8gU29tZSBwYWdlcyBkb24ndCBoYXZlIGEgZm9ybS5cbiAgICAgICAgICAgICF0aGlzLmZvZWhuRm9ybUNvbXBvbmVudCB8fFxuICAgICAgICAgICAgKHRoaXMuZm9laG5Gb3JtQ29tcG9uZW50ICYmXG4gICAgICAgICAgICAgICAgdGhpcy5mb2VobkZvcm1Db21wb25lbnQuaXNWYWxpZCgpICYmXG4gICAgICAgICAgICAgICAgIXRoaXMuX2dlc2RlbVNlcnZpY2UubGFzdFJlc3BvbnNlLm1ldGEuY3JpdGljYWwpO1xuXG4gICAgICAgIHRoaXMuX2dlc2RlbUV2ZW50U2VydmljZS5mb3JtU2VudFN1YmplY3QubmV4dChcbiAgICAgICAgICAgIHRoaXMuX2dlc2RlbVNlcnZpY2UubGFzdFJlc3BvbnNlXG4gICAgICAgICk7XG5cbiAgICAgICAgaWYgKCFnb1RvTmV4dFBhZ2UpIHtcbiAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgfVxuICAgICAgICBpZiAoaXNWYWxpZCkge1xuICAgICAgICAgICAgdGhpcy5yZXR1cm5Ub1BhcmVudCgpO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgdGhpcy5kaXNwbGF5TW9kYWxFcnJvckNvbmZpcm1hdGlvbigpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgcHJvdGVjdGVkIHJldHVyblRvUGFyZW50KCk6IHZvaWQge1xuICAgICAgICB0aGlzLl9icmVhZGNydW1iRXZlbnRTZXJ2aWNlXG4gICAgICAgICAgICAuYnJlYWRjcnVtYk9ic2VydmFibGUoKVxuICAgICAgICAgICAgLnBpcGUoZmlyc3QoKSlcbiAgICAgICAgICAgIC5zdWJzY3JpYmUoYnJlYWRDcnVtYiA9PiB7XG4gICAgICAgICAgICAgICAgYnJlYWRDcnVtYi5icmVhZGNydW1iSXRlbXMucG9wKCk7XG4gICAgICAgICAgICAgICAgdGhpcy5fYnJlYWRjcnVtYkV2ZW50U2VydmljZS5zZXRCcmVhZGNydW1iKGJyZWFkQ3J1bWIpO1xuICAgICAgICAgICAgICAgIHRoaXMuX25hdmlnYXRpb24ubmV4dCgpO1xuICAgICAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgcHJvdGVjdGVkIGFwcGVuZFBhZ2VUb0JyZWFkQ3J1bWIoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuX2JyZWFkY3J1bWJFdmVudFNlcnZpY2VcbiAgICAgICAgICAgIC5icmVhZGNydW1iT2JzZXJ2YWJsZSgpXG4gICAgICAgICAgICAucGlwZShmaXJzdCgpKVxuICAgICAgICAgICAgLnN1YnNjcmliZShicmVhZENydW1iID0+IHtcbiAgICAgICAgICAgICAgICBjb25zdCByb3V0ZXJMaW5rID1cbiAgICAgICAgICAgICAgICAgICAgdGhpcy5fZ2VzZGVtU2VydmljZS5sYXN0UmVzcG9uc2UubWV0YS5yZWZlcmVuY2UgK1xuICAgICAgICAgICAgICAgICAgICB0aGlzLmdldE1lbnVQYXRoKCk7XG4gICAgICAgICAgICAgICAgY29uc3QgaGFzQ3J1bWIgPSBicmVhZENydW1iLmJyZWFkY3J1bWJJdGVtcy5maW5kKFxuICAgICAgICAgICAgICAgICAgICBiID0+IGIucm91dGVyTGluayA9PT0gcm91dGVyTGlua1xuICAgICAgICAgICAgICAgICk7XG5cbiAgICAgICAgICAgICAgICBpZiAoIWhhc0NydW1iKSB7XG4gICAgICAgICAgICAgICAgICAgIGJyZWFkQ3J1bWIuYnJlYWRjcnVtYkl0ZW1zLnB1c2goe1xuICAgICAgICAgICAgICAgICAgICAgICAgdXJsOiBudWxsLFxuICAgICAgICAgICAgICAgICAgICAgICAgcm91dGVyTGluayxcbiAgICAgICAgICAgICAgICAgICAgICAgIGxhYmVsOiB0aGlzLmdldE1lbnVMYWJlbCgpLFxuICAgICAgICAgICAgICAgICAgICAgICAgc2tpcExlYXZpbmdBbGVydDogdHJ1ZVxuICAgICAgICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgICAgICAgICAgdGhpcy5fYnJlYWRjcnVtYkV2ZW50U2VydmljZS5zZXRCcmVhZGNydW1iKGJyZWFkQ3J1bWIpO1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH0pO1xuICAgIH1cblxuICAgIHByaXZhdGUgZGlzcGxheU1vZGFsRXJyb3JDb25maXJtYXRpb24oKTogdm9pZCB7XG4gICAgICAgIHRoaXMuY29uZmlybU1vZGFsU2VydmljZVxuICAgICAgICAgICAgLm9wZW5Db25maXJtTW9kYWwoe1xuICAgICAgICAgICAgICAgIGh0bWxDb250ZW50OlxuICAgICAgICAgICAgICAgICAgICAnVm9zIGRvbm7DqWVzIG9udCBiaWVuIMOpdMOpIHNhdXZlZ2FyZMOpZXMuIENlcGVuZGFudCwgaWwgcmVzdGUgZGVzIGVycmV1cnMuJyArXG4gICAgICAgICAgICAgICAgICAgICc8YnI+PGJyPicgK1xuICAgICAgICAgICAgICAgICAgICAnU291aGFpdGV6LXZvdXMgcXVhbmQgbcOqbWUgY29udGludWVyID8nLFxuICAgICAgICAgICAgICAgIG9rQnV0dG9uTGFiZWw6ICdQb3Vyc3VpdnJlIHNhbnMgY29ycmlnZXInLFxuICAgICAgICAgICAgICAgIGNhbmNlbEJ1dHRvbkxhYmVsOiAnQ29ycmlnZXIgbGVzIGVycmV1cnMnXG4gICAgICAgICAgICB9KVxuICAgICAgICAgICAgLnRoZW4oXG4gICAgICAgICAgICAgICAgKCkgPT4gdGhpcy5yZXR1cm5Ub1BhcmVudCgpLFxuICAgICAgICAgICAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZW1wdHktZnVuY3Rpb25cbiAgICAgICAgICAgICAgICAoKSA9PiB7fVxuICAgICAgICAgICAgKTtcbiAgICB9XG5cbiAgICBwcm90ZWN0ZWQgYWJzdHJhY3QgZ2V0TWVudVBhdGgoKTogc3RyaW5nO1xuXG4gICAgcHJvdGVjdGVkIGFic3RyYWN0IGdldE1lbnVMYWJlbCgpOiBzdHJpbmc7XG59XG4iXX0=