@dsivd/prestations-ng 14.5.21 → 14.5.23-beta2

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 (27) hide show
  1. package/CHANGELOG.md +7 -2
  2. package/bundles/dsivd-prestations-ng.umd.js +463 -103
  3. package/bundles/dsivd-prestations-ng.umd.js.map +1 -1
  4. package/dsivd-prestations-ng-v14.5.23-beta2.tgz +0 -0
  5. package/esm2015/foehn-checkables/foehn-checkable-group.component.js +11 -3
  6. package/esm2015/foehn-date-picker/foehn-date-picker.component.js +2 -2
  7. package/esm2015/foehn-input/foehn-input-email.component.js +2 -2
  8. package/esm2015/foehn-input/foehn-input-hidden.component.js +2 -2
  9. package/esm2015/foehn-input/foehn-input-number.component.js +2 -2
  10. package/esm2015/foehn-input/foehn-input-password.component.js +2 -2
  11. package/esm2015/foehn-input/foehn-input-phone.component.js +2 -2
  12. package/esm2015/foehn-input/foehn-input-text.component.js +2 -2
  13. package/esm2015/foehn-multiselect-autocomplete/foehn-multiselect-autocomplete.component.js +287 -0
  14. package/esm2015/foehn-multiselect-autocomplete/foehn-multiselect-autocomplete.module.js +42 -0
  15. package/esm2015/foehn-upload/foehn-picture-upload/foehn-picture-upload.component.js +2 -2
  16. package/esm2015/index.js +4 -1
  17. package/esm2015/sdk-dictionary/default-dictionary.js +12 -2
  18. package/esm2015/sdk-recaptcha/grecaptcha/grecaptcha.component.js +2 -2
  19. package/fesm2015/dsivd-prestations-ng.js +427 -101
  20. package/fesm2015/dsivd-prestations-ng.js.map +1 -1
  21. package/foehn-checkables/foehn-checkable-group.component.d.ts +3 -2
  22. package/foehn-multiselect-autocomplete/foehn-multiselect-autocomplete.component.d.ts +47 -0
  23. package/foehn-multiselect-autocomplete/foehn-multiselect-autocomplete.module.d.ts +13 -0
  24. package/index.d.ts +2 -0
  25. package/package.json +1 -1
  26. package/sdk-recaptcha/grecaptcha/grecaptcha.component.d.ts +1 -1
  27. package/dsivd-prestations-ng-v14.5.21.tgz +0 -0
@@ -1,11 +1,12 @@
1
1
  /* eslint-disable @typescript-eslint/no-explicit-any */
2
- import { Input, Directive } from '@angular/core';
2
+ import { Input, Directive, Output, EventEmitter } from '@angular/core';
3
3
  import { FoehnInputComponent } from '../foehn-input/foehn-input.component';
4
4
  import { HttpClient } from '@angular/common/http';
5
5
  import { ServiceLocator } from '../service-locator';
6
6
  import { of, Subject } from 'rxjs';
7
7
  import { first, map, shareReplay } from 'rxjs/operators';
8
8
  import { FormSelectOptionGroup } from './form-select-option-group';
9
+ import { ObjectHelper } from '../helpers/object.helper';
9
10
  import * as i0 from "@angular/core";
10
11
  export class FoehnCheckableGroupComponent extends FoehnInputComponent {
11
12
  constructor(ngZone) {
@@ -23,6 +24,7 @@ export class FoehnCheckableGroupComponent extends FoehnInputComponent {
23
24
  this.elementLabel = 'label';
24
25
  this.elementDisabled = 'disabled';
25
26
  this.allElementDisabled = false;
27
+ this.elementsLoaded = new EventEmitter();
26
28
  this.multiple = false;
27
29
  this._onInitSubject = new Subject();
28
30
  this.httpClient = ServiceLocator.injector.get(HttpClient);
@@ -72,6 +74,7 @@ export class FoehnCheckableGroupComponent extends FoehnInputComponent {
72
74
  }
73
75
  setElements(elements) {
74
76
  this.elements = elements;
77
+ this.elementsLoaded.next(elements);
75
78
  this.onElementsRetrieved();
76
79
  }
77
80
  // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types
@@ -261,6 +264,9 @@ export class FoehnCheckableGroupComponent extends FoehnInputComponent {
261
264
  // Hack to refresh the display value
262
265
  this.updateNgModel(this.model_);
263
266
  }
267
+ else if (change && !ObjectHelper.isEqual(change.currentValue, change.previousValue)) {
268
+ this.elementsLoaded.next(change.currentValue);
269
+ }
264
270
  }
265
271
  onElementsUrlChange(change) {
266
272
  if (change && !change.firstChange) {
@@ -269,7 +275,7 @@ export class FoehnCheckableGroupComponent extends FoehnInputComponent {
269
275
  }
270
276
  }
271
277
  FoehnCheckableGroupComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: FoehnCheckableGroupComponent, deps: [{ token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Directive });
272
- FoehnCheckableGroupComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.4", type: FoehnCheckableGroupComponent, inputs: { elements: "elements", elementsUrl: "elementsUrl", elementValue: "elementValue", elementLabel: "elementLabel", elementValueIdentity: "elementValueIdentity", elementDisabled: "elementDisabled", allElementDisabled: "allElementDisabled", elementGroup: "elementGroup", defaultElementValue: "defaultElementValue" }, usesInheritance: true, usesOnChanges: true, ngImport: i0 });
278
+ FoehnCheckableGroupComponent.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.4", type: FoehnCheckableGroupComponent, inputs: { elements: "elements", elementsUrl: "elementsUrl", elementValue: "elementValue", elementLabel: "elementLabel", elementValueIdentity: "elementValueIdentity", elementDisabled: "elementDisabled", allElementDisabled: "allElementDisabled", elementGroup: "elementGroup", defaultElementValue: "defaultElementValue" }, outputs: { elementsLoaded: "elementsLoaded" }, usesInheritance: true, usesOnChanges: true, ngImport: i0 });
273
279
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: FoehnCheckableGroupComponent, decorators: [{
274
280
  type: Directive
275
281
  }], ctorParameters: function () { return [{ type: i0.NgZone }]; }, propDecorators: { elements: [{
@@ -288,7 +294,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImpor
288
294
  type: Input
289
295
  }], elementGroup: [{
290
296
  type: Input
297
+ }], elementsLoaded: [{
298
+ type: Output
291
299
  }], defaultElementValue: [{
292
300
  type: Input
293
301
  }] } });
294
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-checkable-group.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-checkables/foehn-checkable-group.component.ts"],"names":[],"mappings":"AAAA,uDAAuD;AACvD,OAAO,EACH,KAAK,EAML,SAAS,EACZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,mBAAmB,EAAE,MAAM,sCAAsC,CAAC;AAC3E,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAClD,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACpD,OAAO,EAAc,EAAE,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/C,OAAO,EAAE,KAAK,EAAE,GAAG,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AACzD,OAAO,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAC;;AAGnE,MAAM,OAAgB,4BAClB,SAAQ,mBAAwB;IA+DhC,YAAoB,MAAc;QAC9B,KAAK,EAAE,CAAC;QADQ,WAAM,GAAN,MAAM,CAAQ;QAvDlC;;;WAGG;QAEH,iBAAY,GAAQ,OAAO,CAAC;QAE5B;;;WAGG;QAEH,iBAAY,GAAQ,OAAO,CAAC;QAU5B,oBAAe,GAAQ,UAAU,CAAC;QAGlC,uBAAkB,GAAG,KAAK,CAAC;QAqBjB,aAAQ,GAAG,KAAK,CAAC;QAEnB,mBAAc,GAAiB,IAAI,OAAO,EAAO,CAAC;QAStD,IAAI,CAAC,UAAU,GAAG,cAAc,CAAC,QAAQ,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;IAC9D,CAAC;IA5BD,IACI,mBAAmB,CAAC,GAAW;QAC/B,IAAI,CAAC,oBAAoB,GAAG,GAAG,CAAC;QAChC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;YACnB,IAAI,CAAC,mBAAmB,EAAE,CAAC;SAC9B;IACL,CAAC;IAED,IAAI,mBAAmB;QACnB,OAAO,IAAI,CAAC,oBAAoB,CAAC;IACrC,CAAC;IAWD,IAAI,aAAa;QACb,OAAO,IAAI,CAAC,cAAc,CAAC;IAC/B,CAAC;IAOD,QAAQ;QACJ,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,IAAI,IAAI,CAAC,WAAW,EAAE;YAClB,IAAI,CAAC,oBAAoB,EAAE,CAAC;SAC/B;aAAM,IAAI,IAAI,CAAC,QAAQ,EAAE;YACtB,IAAI,CAAC,mBAAmB,EAAE,CAAC;SAC9B;IACL,CAAC;IAED,WAAW,CAAC,OAAsB;QAC9B,yCAAyC;QACzC,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;QAExC,4CAA4C;QAC5C,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;IAClD,CAAC;IAED,WAAW;QACP,IAAI,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE;YACpB,OAAO,IAAI,CAAC,QAAQ,CAAC;SACxB;QAED,OAAO,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAC7B,CAAC;IACD,6EAA6E;IAC7E,QAAQ,CAAC,OAAY;QACjB,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;YAChC,OAAO,IAAI,CAAC;SACf;QAED,IAAI,OAAO,IAAI,CAAC,YAAY,KAAK,QAAQ,EAAE;YACvC,OAAO,IAAI,CAAC,iBAAiB,CAAC,OAAO,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;SAC7D;QACD,OAAO,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;IACtC,CAAC;IAED,WAAW,CAAC,QAAe;QACvB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC/B,CAAC;IAED,6EAA6E;IAC7E,QAAQ,CAAC,OAAY;QACjB,IAAI,CAAC,OAAO,EAAE;YACV,OAAO,IAAI,CAAC;SACf;QAED,IAAI,OAAO,IAAI,CAAC,YAAY,KAAK,QAAQ,EAAE;YACvC,OAAO,IAAI,CAAC,iBAAiB,CAAC,OAAO,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;SAC7D;QACD,OAAO,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;IACtC,CAAC;IAED,6EAA6E;IAC7E,QAAQ,CAAC,OAAY;QACjB,IAAI,OAAO,IAAI,CAAC,YAAY,KAAK,QAAQ,EAAE;YACvC,OAAO,IAAI,CAAC,iBAAiB,CAAC,OAAO,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;SAC7D;QACD,OAAO,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;IACtC,CAAC;IAED,6EAA6E;IAC7E,WAAW,CAAC,OAAY;QACpB,IAAI,IAAI,CAAC,kBAAkB,EAAE;YACzB,OAAO,UAAU,CAAC;SACrB;QAED,IAAI,OAAO,IAAI,CAAC,eAAe,KAAK,QAAQ,EAAE;YAC1C,OAAO,IAAI,CAAC,iBAAiB,CAAC,OAAO,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;SAChE;QACD,OAAO,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;IACzC,CAAC;IAED,OAAO;IACH,6EAA6E;IAC7E,OAAY;IACZ,6EAA6E;IAC7E,WAAgB,EAChB,kBAA2B,IAAI;QAE/B,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;QACrC,IAAI,IAAI,CAAC,QAAQ,EAAE;YACf,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;gBACb,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;aACnB;YACD,MAAM,UAAU,GAAG,IAAI,CAAC,KAAiB,CAAC;YAC1C,IAAI,CAAC,CAAC,WAAW,EAAE;gBACf,IAAI,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE;oBAClC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;iBAC1B;aACJ;iBAAM;gBACH,MAAM,YAAY,GAAG,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;gBAClD,IAAI,YAAY,IAAI,CAAC,EAAE;oBACnB,UAAU,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC;iBACtC;aACJ;YACD,IAAI,eAAe,EAAE;gBACjB,IAAI,CAAC,KAAK,GAAG,CAAC,GAAG,UAAU,CAAC,CAAC;aAChC;SACJ;aAAM;YACH,IAAI,CAAC,CAAC,WAAW,EAAE;gBACf,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;aACtB;iBAAM;gBACH,IAAI,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,EAAE,KAAK,CAAC,EAAE;oBACzC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;iBACrB;aACJ;SACJ;IACL,CAAC;IAED,6EAA6E;IAC7E,iBAAiB,CAAC,OAAY;QAC1B,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;QACrC,IAAI,IAAI,CAAC,QAAQ,EAAE;YACf,OAAO,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;SAC1D;QAED,OAAO,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IACnD,CAAC;IAED,KAAK;QACD,IAAI,CAAC,CAAC,IAAI,CAAC,mBAAmB,EAAE;YAC5B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;SAChD;aAAM;YACH,KAAK,CAAC,KAAK,EAAE,CAAC;SACjB;IACL,CAAC;IAED,kBAAkB;QACd,IAAI,IAAI,CAAC,WAAW,EAAE;YAClB,IAAI,CAAC,oBAAoB,EAAE,CAAC;SAC/B;IACL,CAAC;IAED,6EAA6E;IACnE,gBAAgB,CAAC,KAAU;QACjC,IAAI,IAAI,CAAC,QAAQ,EAAE;YACf,OAAQ,IAAI,CAAC,KAAe,CAAC,SAAS,CAAC,UAAU,CAAC,EAAE,CAChD,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,UAAU,CAAC,CAC1C,CAAC;SACL;QACD,MAAM,IAAI,KAAK,CACX,+DAA+D,CAClE,CAAC;IACN,CAAC;IAED,6EAA6E;IACnE,eAAe,CAAC,MAAW,EAAE,MAAW;QAC9C,yDAAyD;QACzD,+DAA+D;QAC/D,iBAAiB;QACjB,MAAM,UAAU,GAAG,IAAI,CAAC,wBAAwB,EAAE,CAAC;QACnD,OAAO,UAAU,CAAC,MAAM,CAAC,KAAK,UAAU,CAAC,MAAM,CAAC,CAAC;IACrD,CAAC;IAES,mBAAmB;QACzB,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,mBAAmB,EAAE;YACzC,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;gBACtD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;YACjD,CAAC,CAAC,CAAC;SACN;aAAM,IAAI,IAAI,CAAC,KAAK,EAAE;YACnB,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;gBACtD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YACpC,CAAC,CAAC,CAAC;SACN;QACD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,kBAAkB,EAAE,CAAC;IACrD,CAAC;IAEO,kBAAkB;QACtB,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAChB,OAAO,EAAE,CAAC;SACb;QACD,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;YACpB,OAAO,CAAC,EAAE,UAAU,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;SAC1D;QAED,MAAM,eAAe,GAAuB,IAAI,GAAG,EAAiB,CAAC;QAErE,MAAM,UAAU,GAAG,IAAI,qBAAqB,EAAE,CAAC;QAC/C,UAAU,CAAC,QAAQ,GAAG,EAAE,CAAC;QAEzB,KAAK,MAAM,OAAO,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjC,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;YACvC,IAAI,CAAC,CAAC,OAAO,EAAE;gBACX,IAAI,eAAe,GAAU,eAAe,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;gBAC1D,IAAI,CAAC,eAAe,EAAE;oBAClB,eAAe,GAAG,EAAE,CAAC;oBACrB,eAAe,CAAC,GAAG,CAAC,OAAO,EAAE,eAAe,CAAC,CAAC;iBACjD;gBACD,eAAe,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;aACjC;iBAAM;gBACH,UAAU,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;aACrC;SACJ;QAED,MAAM,sBAAsB,GAA4B,EAAE,CAAC;QAE3D,IAAI,UAAU,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE;YAChC,sBAAsB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;SAC3C;QACD,eAAe,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE;YACnC,sBAAsB,CAAC,IAAI,CAAC,EAAE,UAAU,EAAE,GAAG,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC;QACtE,CAAC,CAAC,CAAC;QAEH,OAAO,sBAAsB,CAAC;IAClC,CAAC;IAEO,iBAAiB,CAAC,GAAQ,EAAE,GAAW;QAC3C,KAAK,MAAM,QAAQ,IAAI,GAAG,EAAE;YACxB,IAAI,GAAG,CAAC,cAAc,CAAC,QAAQ,CAAC,EAAE;gBAC9B,0BAA0B;gBAC1B,IAAI,OAAO,GAAG,CAAC,QAAQ,CAAC,KAAK,QAAQ,EAAE;oBACnC,MAAM,MAAM,GAAG,IAAI,CAAC,iBAAiB,CACjC,GAAG,CAAC,QAAQ,CAAC,EACb,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CACpC,CAAC;oBAEF,IAAI,OAAO,MAAM,KAAK,WAAW,EAAE;wBAC/B,OAAO,MAAM,CAAC;qBACjB;iBACJ;qBAAM,IAAI,QAAQ,KAAK,GAAG,EAAE;oBACzB,OAAO,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,oBAAoB;iBACxC;aACJ;SACJ;IACL,CAAC;IAEO,wBAAwB;QAC5B,OAAO,OAAO,IAAI,CAAC,oBAAoB,KAAK,UAAU;YAClD,CAAC,CAAC,IAAI,CAAC,oBAAoB;YAC3B,CAAC,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,CAAC;IACxB,CAAC;IAEO,SAAS;QACb,OAAO,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,IAAI,CAC7C,GAAG,CAAC,CAAC,CAAC,EAAE;YACJ,MAAM,QAAQ,GAAQ,CAAC,CAAC;YACxB,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;YAC3B,OAAO,QAAQ,CAAC;QACpB,CAAC,CAAC,EACF,WAAW,CAAC,CAAC,CAAC,CACjB,CAAC;IACN,CAAC;IAEO,oBAAoB;QACxB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;QACjC,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,GAAG,EAAE;YACzB,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;QAC9B,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,gBAAgB,CAAC,MAAoB;QACzC,IAAI,MAAM,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE;YAC/B,qEAAqE;YACrE,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAC3B,oCAAoC;YACpC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SACnC;IACL,CAAC;IAEO,mBAAmB,CAAC,MAAoB;QAC5C,IAAI,MAAM,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE;YAC/B,IAAI,CAAC,oBAAoB,EAAE,CAAC;SAC/B;IACL,CAAC;;yHA7UiB,4BAA4B;6GAA5B,4BAA4B;2FAA5B,4BAA4B;kBADjD,SAAS;6FAKN,QAAQ;sBADP,KAAK;gBAIN,WAAW;sBADV,KAAK;gBAQN,YAAY;sBADX,KAAK;gBAQN,YAAY;sBADX,KAAK;gBAQN,oBAAoB;sBADnB,KAAK;gBAIN,eAAe;sBADd,KAAK;gBAIN,kBAAkB;sBADjB,KAAK;gBAIN,YAAY;sBADX,KAAK;gBAIF,mBAAmB;sBADtB,KAAK","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport {\n    Input,\n    NgZone,\n    OnChanges,\n    OnInit,\n    SimpleChange,\n    SimpleChanges,\n    Directive\n} from '@angular/core';\nimport { FoehnInputComponent } from '../foehn-input/foehn-input.component';\nimport { HttpClient } from '@angular/common/http';\nimport { ServiceLocator } from '../service-locator';\nimport { Observable, of, Subject } from 'rxjs';\nimport { first, map, shareReplay } from 'rxjs/operators';\nimport { FormSelectOptionGroup } from './form-select-option-group';\n\n@Directive()\nexport abstract class FoehnCheckableGroupComponent\n    extends FoehnInputComponent<any>\n    implements OnInit, OnChanges {\n    @Input()\n    elements: any;\n\n    @Input()\n    elementsUrl: string;\n\n    /**\n     * The value in the object. Can be a string or a function.\n     * Defaults to `value`\n     */\n    @Input()\n    elementValue: any = 'value';\n\n    /**\n     * The label in the object. Can be a string or a function\n     * Defaults to `label`\n     */\n    @Input()\n    elementLabel: any = 'label';\n\n    /**\n     * The identify value to match the value to the list of elements.\n     * By default `x => x`\n     */\n    @Input()\n    elementValueIdentity: (element: any) => any;\n\n    @Input()\n    elementDisabled: any = 'disabled';\n\n    @Input()\n    allElementDisabled = false;\n\n    @Input()\n    elementGroup: any;\n\n    @Input()\n    set defaultElementValue(val: string) {\n        this.defaultElementValue_ = val;\n        if (!this.elementsUrl) {\n            this.onElementsRetrieved();\n        }\n    }\n\n    get defaultElementValue(): string {\n        return this.defaultElementValue_;\n    }\n\n    groupedElements: FormSelectOptionGroup[];\n\n    httpClient: HttpClient;\n\n    protected multiple = false;\n    private pulling_: Observable<any>;\n    private _onInitSubject: Subject<any> = new Subject<any>();\n    private defaultElementValue_: string;\n\n    get onInitSubject(): Subject<any> {\n        return this._onInitSubject;\n    }\n\n    constructor(private ngZone: NgZone) {\n        super();\n        this.httpClient = ServiceLocator.injector.get(HttpClient);\n    }\n\n    ngOnInit(): void {\n        super.ngOnInit();\n        if (this.elementsUrl) {\n            this.fetchElementsFromUrl();\n        } else if (this.elements) {\n            this.onElementsRetrieved();\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        // Handle a change in the elements Input.\n        this.onElementsChange(changes.elements);\n\n        // Handle a change in the elementsUrl Input.\n        this.onElementsUrlChange(changes.elementsUrl);\n    }\n\n    getElements(): Observable<any> {\n        if (!!this.elementsUrl) {\n            return this.pulling_;\n        }\n\n        return of(this.elements);\n    }\n    // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n    getGroup(element: any): string {\n        if (!element || !this.elementGroup) {\n            return null;\n        }\n\n        if (typeof this.elementGroup === 'string') {\n            return this.getNestedProperty(element, this.elementGroup);\n        }\n        return this.elementGroup(element);\n    }\n\n    setElements(elements: any[]): void {\n        this.elements = elements;\n        this.onElementsRetrieved();\n    }\n\n    // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n    getValue(element: any): string {\n        if (!element) {\n            return null;\n        }\n\n        if (typeof this.elementValue === 'string') {\n            return this.getNestedProperty(element, this.elementValue);\n        }\n        return this.elementValue(element);\n    }\n\n    // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n    getLabel(element: any): string {\n        if (typeof this.elementLabel === 'string') {\n            return this.getNestedProperty(element, this.elementLabel);\n        }\n        return this.elementLabel(element);\n    }\n\n    // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n    getDisabled(element: any): string {\n        if (this.allElementDisabled) {\n            return 'disabled';\n        }\n\n        if (typeof this.elementDisabled === 'string') {\n            return this.getNestedProperty(element, this.elementDisabled);\n        }\n        return this.elementDisabled(element);\n    }\n\n    onCheck(\n        // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n        element: any,\n        // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n        selectEvent: any,\n        fireModelChange: boolean = true\n    ): void {\n        const value = this.getValue(element);\n        if (this.multiple) {\n            if (!this.model) {\n                this.model = [];\n            }\n            const modelArray = this.model as string[];\n            if (!!selectEvent) {\n                if (this.findIndexInModel(value) < 0) {\n                    modelArray.push(value);\n                }\n            } else {\n                const indexInModel = this.findIndexInModel(value);\n                if (indexInModel >= 0) {\n                    modelArray.splice(indexInModel, 1);\n                }\n            }\n            if (fireModelChange) {\n                this.model = [...modelArray];\n            }\n        } else {\n            if (!!selectEvent) {\n                this.model = value;\n            } else {\n                if (this.areValuesEquals(this.model, value)) {\n                    this.model = null;\n                }\n            }\n        }\n    }\n\n    // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n    isElementSelected(element: any): boolean {\n        const value = this.getValue(element);\n        if (this.multiple) {\n            return this.model && this.findIndexInModel(value) >= 0;\n        }\n\n        return this.areValuesEquals(this.model, value);\n    }\n\n    reset(): void {\n        if (!!this.defaultElementValue) {\n            this.updateNgModel(this.defaultElementValue);\n        } else {\n            super.reset();\n        }\n    }\n\n    refreshElementsUrl(): void {\n        if (this.elementsUrl) {\n            this.fetchElementsFromUrl();\n        }\n    }\n\n    // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n    protected findIndexInModel(value: any): number {\n        if (this.multiple) {\n            return (this.model as any[]).findIndex(modelValue =>\n                this.areValuesEquals(value, modelValue)\n            );\n        }\n        throw new Error(\n            'findIndexInModel cannot be used when this.multiple is false !'\n        );\n    }\n\n    // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n    protected areValuesEquals(value1: any, value2: any): boolean {\n        // Get an option way to compare the value from the model.\n        // This allows us to properly use an object as the model rather\n        // than a string.\n        const identityFn = this.getValueIdentityFunction();\n        return identityFn(value1) === identityFn(value2);\n    }\n\n    protected onElementsRetrieved(): void {\n        if (!this.model && this.defaultElementValue) {\n            this.ngZone.onMicrotaskEmpty.pipe(first()).subscribe(() => {\n                this.updateNgModel(this.defaultElementValue);\n            });\n        } else if (this.model) {\n            this.ngZone.onMicrotaskEmpty.pipe(first()).subscribe(() => {\n                this.updateNgModel(this.model_);\n            });\n        }\n        this.groupedElements = this.getGroupedElements();\n    }\n\n    private getGroupedElements(): FormSelectOptionGroup[] {\n        if (!this.elements) {\n            return [];\n        }\n        if (!this.elementGroup) {\n            return [{ groupTitle: null, elements: this.elements }];\n        }\n\n        const elementsByGroup: Map<string, any[]> = new Map<string, any[]>();\n\n        const emptyGroup = new FormSelectOptionGroup();\n        emptyGroup.elements = [];\n\n        for (const element of this.elements) {\n            const groupId = this.getGroup(element);\n            if (!!groupId) {\n                let elementsOfGroup: any[] = elementsByGroup.get(groupId);\n                if (!elementsOfGroup) {\n                    elementsOfGroup = [];\n                    elementsByGroup.set(groupId, elementsOfGroup);\n                }\n                elementsOfGroup.push(element);\n            } else {\n                emptyGroup.elements.push(element);\n            }\n        }\n\n        const formSelectOptionsGroup: FormSelectOptionGroup[] = [];\n\n        if (emptyGroup.elements.length > 0) {\n            formSelectOptionsGroup.push(emptyGroup);\n        }\n        elementsByGroup.forEach((value, key) => {\n            formSelectOptionsGroup.push({ groupTitle: key, elements: value });\n        });\n\n        return formSelectOptionsGroup;\n    }\n\n    private getNestedProperty(obj: any, key: string): any {\n        for (const property in obj) {\n            if (obj.hasOwnProperty(property)) {\n                // in case it is an object\n                if (typeof obj[property] === 'object') {\n                    const result = this.getNestedProperty(\n                        obj[property],\n                        key.split('.').slice(1).join('.')\n                    );\n\n                    if (typeof result !== 'undefined') {\n                        return result;\n                    }\n                } else if (property === key) {\n                    return obj[key]; // returns the value\n                }\n            }\n        }\n    }\n\n    private getValueIdentityFunction(): any {\n        return typeof this.elementValueIdentity === 'function'\n            ? this.elementValueIdentity\n            : (x: any) => x;\n    }\n\n    private fetchData(): Observable<any> {\n        return this.httpClient.get(this.elementsUrl).pipe(\n            map(r => {\n                const elements: any = r;\n                this.setElements(elements);\n                return elements;\n            }),\n            shareReplay(1)\n        );\n    }\n\n    private fetchElementsFromUrl(): void {\n        this.pulling_ = this.fetchData();\n        this.pulling_.subscribe(() => {\n            this.onInitSubject.next();\n        });\n    }\n\n    private onElementsChange(change: SimpleChange): void {\n        if (change && !change.firstChange) {\n            // When elements are deferred from ngOnInit (i.e. pipe async is used)\n            this.onElementsRetrieved();\n            // Hack to refresh the display value\n            this.updateNgModel(this.model_);\n        }\n    }\n\n    private onElementsUrlChange(change: SimpleChange): void {\n        if (change && !change.firstChange) {\n            this.fetchElementsFromUrl();\n        }\n    }\n}\n"]}
302
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-checkable-group.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-checkables/foehn-checkable-group.component.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport {\n    Input,\n    NgZone,\n    OnChanges,\n    OnInit,\n    SimpleChange,\n    SimpleChanges,\n    Directive, Output, EventEmitter\n} from '@angular/core';\nimport { FoehnInputComponent } from '../foehn-input/foehn-input.component';\nimport { HttpClient } from '@angular/common/http';\nimport { ServiceLocator } from '../service-locator';\nimport { Observable, of, Subject } from 'rxjs';\nimport { first, map, shareReplay } from 'rxjs/operators';\nimport { FormSelectOptionGroup } from './form-select-option-group';\nimport { ObjectHelper } from '../helpers/object.helper';\n\n@Directive()\nexport abstract class FoehnCheckableGroupComponent\n    extends FoehnInputComponent<any>\n    implements OnInit, OnChanges {\n    @Input()\n    elements: any;\n\n    @Input()\n    elementsUrl: string;\n\n    /**\n     * The value in the object. Can be a string or a function.\n     * Defaults to `value`\n     */\n    @Input()\n    elementValue: any = 'value';\n\n    /**\n     * The label in the object. Can be a string or a function\n     * Defaults to `label`\n     */\n    @Input()\n    elementLabel: any = 'label';\n\n    /**\n     * The identify value to match the value to the list of elements.\n     * By default `x => x`\n     */\n    @Input()\n    elementValueIdentity: (element: any) => any;\n\n    @Input()\n    elementDisabled: any = 'disabled';\n\n    @Input()\n    allElementDisabled = false;\n\n    @Input()\n    elementGroup: any;\n\n    @Output()\n    elementsLoaded = new EventEmitter<any>();\n\n    @Input()\n    set defaultElementValue(val: string) {\n        this.defaultElementValue_ = val;\n        if (!this.elementsUrl) {\n            this.onElementsRetrieved();\n        }\n    }\n\n    get defaultElementValue(): string {\n        return this.defaultElementValue_;\n    }\n\n    groupedElements: FormSelectOptionGroup[];\n\n    httpClient: HttpClient;\n\n    protected multiple = false;\n    private pulling_: Observable<any>;\n    private _onInitSubject: Subject<any> = new Subject<any>();\n    private defaultElementValue_: string;\n\n    get onInitSubject(): Subject<any> {\n        return this._onInitSubject;\n    }\n\n    constructor(private ngZone: NgZone) {\n        super();\n        this.httpClient = ServiceLocator.injector.get(HttpClient);\n    }\n\n    ngOnInit(): void {\n        super.ngOnInit();\n        if (this.elementsUrl) {\n            this.fetchElementsFromUrl();\n        } else if (this.elements) {\n            this.onElementsRetrieved();\n        }\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        // Handle a change in the elements Input.\n        this.onElementsChange(changes.elements);\n\n        // Handle a change in the elementsUrl Input.\n        this.onElementsUrlChange(changes.elementsUrl);\n    }\n\n    getElements(): Observable<any> {\n        if (!!this.elementsUrl) {\n            return this.pulling_;\n        }\n\n        return of(this.elements);\n    }\n    // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n    getGroup(element: any): string {\n        if (!element || !this.elementGroup) {\n            return null;\n        }\n\n        if (typeof this.elementGroup === 'string') {\n            return this.getNestedProperty(element, this.elementGroup);\n        }\n        return this.elementGroup(element);\n    }\n\n    setElements(elements: any[]): void {\n        this.elements = elements;\n        this.elementsLoaded.next(elements);\n        this.onElementsRetrieved();\n    }\n\n    // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n    getValue(element: any): string {\n        if (!element) {\n            return null;\n        }\n\n        if (typeof this.elementValue === 'string') {\n            return this.getNestedProperty(element, this.elementValue);\n        }\n        return this.elementValue(element);\n    }\n\n    // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n    getLabel(element: any): string {\n        if (typeof this.elementLabel === 'string') {\n            return this.getNestedProperty(element, this.elementLabel);\n        }\n        return this.elementLabel(element);\n    }\n\n    // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n    getDisabled(element: any): string {\n        if (this.allElementDisabled) {\n            return 'disabled';\n        }\n\n        if (typeof this.elementDisabled === 'string') {\n            return this.getNestedProperty(element, this.elementDisabled);\n        }\n        return this.elementDisabled(element);\n    }\n\n    onCheck(\n        // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n        element: any,\n        // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n        selectEvent: any,\n        fireModelChange: boolean = true\n    ): void {\n        const value = this.getValue(element);\n        if (this.multiple) {\n            if (!this.model) {\n                this.model = [];\n            }\n            const modelArray = this.model as string[];\n            if (!!selectEvent) {\n                if (this.findIndexInModel(value) < 0) {\n                    modelArray.push(value);\n                }\n            } else {\n                const indexInModel = this.findIndexInModel(value);\n                if (indexInModel >= 0) {\n                    modelArray.splice(indexInModel, 1);\n                }\n            }\n            if (fireModelChange) {\n                this.model = [...modelArray];\n            }\n        } else {\n            if (!!selectEvent) {\n                this.model = value;\n            } else {\n                if (this.areValuesEquals(this.model, value)) {\n                    this.model = null;\n                }\n            }\n        }\n    }\n\n    // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n    isElementSelected(element: any): boolean {\n        const value = this.getValue(element);\n        if (this.multiple) {\n            return this.model && this.findIndexInModel(value) >= 0;\n        }\n\n        return this.areValuesEquals(this.model, value);\n    }\n\n    reset(): void {\n        if (!!this.defaultElementValue) {\n            this.updateNgModel(this.defaultElementValue);\n        } else {\n            super.reset();\n        }\n    }\n\n    refreshElementsUrl(): void {\n        if (this.elementsUrl) {\n            this.fetchElementsFromUrl();\n        }\n    }\n\n    // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n    protected findIndexInModel(value: any): number {\n        if (this.multiple) {\n            return (this.model as any[]).findIndex(modelValue =>\n                this.areValuesEquals(value, modelValue)\n            );\n        }\n        throw new Error(\n            'findIndexInModel cannot be used when this.multiple is false !'\n        );\n    }\n\n    // eslint-disable-next-line @typescript-eslint/explicit-module-boundary-types\n    protected areValuesEquals(value1: any, value2: any): boolean {\n        // Get an option way to compare the value from the model.\n        // This allows us to properly use an object as the model rather\n        // than a string.\n        const identityFn = this.getValueIdentityFunction();\n        return identityFn(value1) === identityFn(value2);\n    }\n\n    protected onElementsRetrieved(): void {\n        if (!this.model && this.defaultElementValue) {\n            this.ngZone.onMicrotaskEmpty.pipe(first()).subscribe(() => {\n                this.updateNgModel(this.defaultElementValue);\n            });\n        } else if (this.model) {\n            this.ngZone.onMicrotaskEmpty.pipe(first()).subscribe(() => {\n                this.updateNgModel(this.model_);\n            });\n        }\n        this.groupedElements = this.getGroupedElements();\n    }\n\n    private getGroupedElements(): FormSelectOptionGroup[] {\n        if (!this.elements) {\n            return [];\n        }\n        if (!this.elementGroup) {\n            return [{ groupTitle: null, elements: this.elements }];\n        }\n\n        const elementsByGroup: Map<string, any[]> = new Map<string, any[]>();\n\n        const emptyGroup = new FormSelectOptionGroup();\n        emptyGroup.elements = [];\n\n        for (const element of this.elements) {\n            const groupId = this.getGroup(element);\n            if (!!groupId) {\n                let elementsOfGroup: any[] = elementsByGroup.get(groupId);\n                if (!elementsOfGroup) {\n                    elementsOfGroup = [];\n                    elementsByGroup.set(groupId, elementsOfGroup);\n                }\n                elementsOfGroup.push(element);\n            } else {\n                emptyGroup.elements.push(element);\n            }\n        }\n\n        const formSelectOptionsGroup: FormSelectOptionGroup[] = [];\n\n        if (emptyGroup.elements.length > 0) {\n            formSelectOptionsGroup.push(emptyGroup);\n        }\n        elementsByGroup.forEach((value, key) => {\n            formSelectOptionsGroup.push({ groupTitle: key, elements: value });\n        });\n\n        return formSelectOptionsGroup;\n    }\n\n    private getNestedProperty(obj: any, key: string): any {\n        for (const property in obj) {\n            if (obj.hasOwnProperty(property)) {\n                // in case it is an object\n                if (typeof obj[property] === 'object') {\n                    const result = this.getNestedProperty(\n                        obj[property],\n                        key.split('.').slice(1).join('.')\n                    );\n\n                    if (typeof result !== 'undefined') {\n                        return result;\n                    }\n                } else if (property === key) {\n                    return obj[key]; // returns the value\n                }\n            }\n        }\n    }\n\n    private getValueIdentityFunction(): any {\n        return typeof this.elementValueIdentity === 'function'\n            ? this.elementValueIdentity\n            : (x: any) => x;\n    }\n\n    private fetchData(): Observable<any> {\n        return this.httpClient.get(this.elementsUrl).pipe(\n            map(r => {\n                const elements: any = r;\n                this.setElements(elements);\n                return elements;\n            }),\n            shareReplay(1)\n        );\n    }\n\n    private fetchElementsFromUrl(): void {\n        this.pulling_ = this.fetchData();\n        this.pulling_.subscribe(() => {\n            this.onInitSubject.next();\n        });\n    }\n\n    private onElementsChange(change: SimpleChange): void {\n        if (change && !change.firstChange) {\n            // When elements are deferred from ngOnInit (i.e. pipe async is used)\n            this.onElementsRetrieved();\n            // Hack to refresh the display value\n            this.updateNgModel(this.model_);\n        } else if (change && !ObjectHelper.isEqual(change.currentValue, change.previousValue)) {\n            this.elementsLoaded.next(change.currentValue);\n        }\n    }\n\n    private onElementsUrlChange(change: SimpleChange): void {\n        if (change && !change.firstChange) {\n            this.fetchElementsFromUrl();\n        }\n    }\n}\n"]}
@@ -261,7 +261,7 @@ export class FoehnDatePickerComponent {
261
261
  }
262
262
  }
263
263
  FoehnDatePickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: FoehnDatePickerComponent, deps: [{ token: i1.SdkDictionaryService }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
264
- FoehnDatePickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: FoehnDatePickerComponent, selector: "foehn-date-picker", inputs: { minYear: "minYear", maxYear: "maxYear", datepickerTriggerHtmlElement: "datepickerTriggerHtmlElement", closeable: "closeable", isDatepickerVisible: "isDatepickerVisible", model: "model" }, outputs: { modelChange: "modelChange", userInput: "userInput", isDatepickerVisibleChange: "isDatepickerVisibleChange" }, host: { listeners: { "keyup": "handleKeyboardUpEvent($event)", "keydown": "handleKeyboardDownEvent($event)" } }, viewQueries: [{ propertyName: "daysButtonsElemRef", predicate: ["dayButtonElemRef"], descendants: true }], ngImport: i0, template: "<div\n id=\"datepicker_wrapper\"\n *ngIf=\"isDatepickerVisible\"\n [cdkTrapFocus]=\"!!datepickerTriggerHtmlElement\"\n tabindex=\"-1\"\n role=\"application\"\n [attr.aria-label]=\"\n 'foehn-date-picker.container.aria-label' | fromDictionary\n \"\n>\n <button\n *ngIf=\"closeable\"\n (click)=\"isDatepickerVisible = false\"\n type=\"button\"\n class=\"btn close\"\n [attr.aria-label]=\"\n 'foehn-date-picker.close-button.aria-label' | fromDictionary\n \"\n id=\"closeButton\"\n >\n <span aria-hidden=\"true\">&times;</span>\n </button>\n <div id=\"datepicker_header\" class=\"d-flex justify-content-between\">\n <button\n id=\"previous-month\"\n class=\"btn btn-link\"\n (click)=\"previousMonth()\"\n >\n <foehn-icon-chevron-left\n [title]=\"\n 'foehn-date-picker.previous-month-button.title'\n | fromDictionary\n \"\n ></foehn-icon-chevron-left>\n </button>\n <ng-container *ngIf=\"currentMonthYear | async as monthYear\">\n <span id=\"month-year-label\" aria-live=\"polite\" class=\"sr-only\">\n {{\n 'foehn-date-picker.screen-reader.actual-month-displayed'\n | fromDictionary\n }}\n {{ getMonthAsReadable(monthYear.month) }} {{ monthYear.year }}\n </span>\n <foehn-select\n id=\"month-input\"\n class=\"align-self-center\"\n [label]=\"\n 'foehn-date-picker.screen-reader.month-input.label'\n | fromDictionary\n \"\n [isLabelSrOnly]=\"true\"\n [elements]=\"monthListItem\"\n [model]=\"monthYear.month\"\n [required]=\"false\"\n (userInput)=\"userInputMonth($event)\"\n ></foehn-select>\n <foehn-select\n id=\"year-input\"\n class=\"align-self-center\"\n [label]=\"\n 'foehn-date-picker.screen-reader.year-input.label'\n | fromDictionary\n \"\n [isLabelSrOnly]=\"true\"\n [elements]=\"yearListItem\"\n [model]=\"monthYear.year\"\n [required]=\"false\"\n (userInput)=\"userInputYear($event)\"\n ></foehn-select>\n </ng-container>\n <button id=\"next-month\" class=\"btn btn-link\" (click)=\"nextMonth()\">\n <foehn-icon-chevron-right\n [title]=\"\n 'foehn-date-picker.next-month-button.title' | fromDictionary\n \"\n ></foehn-icon-chevron-right>\n </button>\n </div>\n <table\n id=\"datepicker_table\"\n role=\"grid\"\n (focusin)=\"onDaysFocusin()\"\n (focusout)=\"onDaysFocusout()\"\n >\n <thead role=\"presentation\" aria-hidden=\"true\">\n <tr role=\"row\">\n <th\n scope=\"col\"\n role=\"columnheader\"\n *ngFor=\"let weekday of weekDays\"\n >\n <foehn-abbr\n [text]=\"weekday.substr(0, 2)\"\n [title]=\"weekday\"\n ></foehn-abbr>\n </th>\n </tr>\n </thead>\n <tbody role=\"presentation\">\n <tr role=\"row\" *ngFor=\"let week of weeks; let indexRow = index\">\n <td\n role=\"gridcell\"\n *ngFor=\"let dayOfWeek of week; let indexColumn = index\"\n >\n <button\n class=\"btn w-100\"\n #dayButtonElemRef\n [id]=\"'day_' + indexRow + '_' + indexColumn\"\n [tabindex]=\"getDayTabIndex(dayOfWeek)\"\n [class.btn-info]=\"!isToday(dayOfWeek.date)\"\n [class.btn-secondary]=\"isToday(dayOfWeek.date)\"\n [class.btn-danger]=\"isSelected(dayOfWeek.date)\"\n [attr.aria-label]=\"\n weekDays[indexColumn] +\n ' ' +\n dayOfWeek.dateAsReadable\n \"\n [attr.data-is-today]=\"isToday(dayOfWeek.date)\"\n [attr.data-is-selected]=\"isSelected(dayOfWeek.date)\"\n [attr.data-row-index]=\"indexRow\"\n [attr.data-column-index]=\"indexColumn\"\n [attr.day-number]=\"dayOfWeek.dayOfMonth\"\n [disabled]=\"!dayOfWeek.isCurrentMonth\"\n (click)=\"handleUserInput(dayOfWeek.date)\"\n >\n {{ dayOfWeek.dayOfMonth }}\n </button>\n </td>\n </tr>\n </tbody>\n </table>\n</div>\n", styles: [":host ::ng-deep .btn-link .svg-inline--fa{color:#000!important}#datepicker_header{margin-bottom:10px}#datepicker_wrapper{max-width:245px;padding:5px;border:1px solid #dfdfdf;background-color:#fff}#datepicker_wrapper .h4{margin-bottom:0}#datepicker_wrapper thead th{text-align:center;width:15%}#datepicker_wrapper .btn{padding:2px 4px}#datepicker_wrapper button.close{position:absolute;right:-14px;top:-18px;background-color:#fff;border:1px solid #dfdfdf;border-radius:50%;width:30px;height:30px;opacity:1}#datepicker_wrapper #month-input{width:50%;margin-right:5px}:host ::ng-deep foehn-select select.form-control{padding:0;margin:0;height:30px}:host ::ng-deep foehn-select .form-group{margin:0}\n"], components: [{ type: i2.FoehnIconChevronLeftComponent, selector: "foehn-icon-chevron-left" }, { type: i3.FoehnSelectComponent, selector: "foehn-select", inputs: ["multiple"] }, { type: i4.FoehnIconChevronRightComponent, selector: "foehn-icon-chevron-right" }, { type: i5.FoehnAbbrComponent, selector: "foehn-abbr", inputs: ["title", "text"] }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.CdkTrapFocus, selector: "[cdkTrapFocus]", inputs: ["cdkTrapFocus", "cdkTrapFocusAutoCapture"], exportAs: ["cdkTrapFocus"] }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "fromDictionary": i8.SdkDictionaryPipe, "async": i6.AsyncPipe } });
264
+ FoehnDatePickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.4", type: FoehnDatePickerComponent, selector: "foehn-date-picker", inputs: { minYear: "minYear", maxYear: "maxYear", datepickerTriggerHtmlElement: "datepickerTriggerHtmlElement", closeable: "closeable", isDatepickerVisible: "isDatepickerVisible", model: "model" }, outputs: { modelChange: "modelChange", userInput: "userInput", isDatepickerVisibleChange: "isDatepickerVisibleChange" }, host: { listeners: { "keyup": "handleKeyboardUpEvent($event)", "keydown": "handleKeyboardDownEvent($event)" } }, viewQueries: [{ propertyName: "daysButtonsElemRef", predicate: ["dayButtonElemRef"], descendants: true }], ngImport: i0, template: "<div\n id=\"datepicker_wrapper\"\n *ngIf=\"isDatepickerVisible\"\n [cdkTrapFocus]=\"!!datepickerTriggerHtmlElement\"\n tabindex=\"-1\"\n role=\"application\"\n [attr.aria-label]=\"\n 'foehn-date-picker.container.aria-label' | fromDictionary\n \"\n>\n <button\n *ngIf=\"closeable\"\n (click)=\"isDatepickerVisible = false\"\n type=\"button\"\n class=\"btn close\"\n [attr.aria-label]=\"\n 'foehn-date-picker.close-button.aria-label' | fromDictionary\n \"\n id=\"closeButton\"\n >\n <span aria-hidden=\"true\">&times;</span>\n </button>\n <div id=\"datepicker_header\" class=\"d-flex justify-content-between\">\n <button\n id=\"previous-month\"\n class=\"btn btn-link\"\n (click)=\"previousMonth()\"\n >\n <foehn-icon-chevron-left\n [title]=\"\n 'foehn-date-picker.previous-month-button.title'\n | fromDictionary\n \"\n ></foehn-icon-chevron-left>\n </button>\n <ng-container *ngIf=\"currentMonthYear | async as monthYear\">\n <span id=\"month-year-label\" aria-live=\"polite\" class=\"sr-only\">\n {{\n 'foehn-date-picker.screen-reader.actual-month-displayed'\n | fromDictionary\n }}\n {{ getMonthAsReadable(monthYear.month) }} {{ monthYear.year }}\n </span>\n <foehn-select\n id=\"month-input\"\n class=\"align-self-center\"\n [label]=\"\n 'foehn-date-picker.screen-reader.month-input.label'\n | fromDictionary\n \"\n [isLabelSrOnly]=\"true\"\n [elements]=\"monthListItem\"\n [model]=\"monthYear.month\"\n [required]=\"false\"\n (userInput)=\"userInputMonth($event)\"\n ></foehn-select>\n <foehn-select\n id=\"year-input\"\n class=\"align-self-center\"\n [label]=\"\n 'foehn-date-picker.screen-reader.year-input.label'\n | fromDictionary\n \"\n [isLabelSrOnly]=\"true\"\n [elements]=\"yearListItem\"\n [model]=\"monthYear.year\"\n [required]=\"false\"\n (userInput)=\"userInputYear($event)\"\n ></foehn-select>\n </ng-container>\n <button id=\"next-month\" class=\"btn btn-link\" (click)=\"nextMonth()\">\n <foehn-icon-chevron-right\n [title]=\"\n 'foehn-date-picker.next-month-button.title' | fromDictionary\n \"\n ></foehn-icon-chevron-right>\n </button>\n </div>\n <table\n id=\"datepicker_table\"\n role=\"grid\"\n (focusin)=\"onDaysFocusin()\"\n (focusout)=\"onDaysFocusout()\"\n >\n <thead role=\"presentation\" aria-hidden=\"true\">\n <tr role=\"row\">\n <th\n scope=\"col\"\n role=\"columnheader\"\n *ngFor=\"let weekday of weekDays\"\n >\n <foehn-abbr\n [text]=\"weekday.substr(0, 2)\"\n [title]=\"weekday\"\n ></foehn-abbr>\n </th>\n </tr>\n </thead>\n <tbody role=\"presentation\">\n <tr role=\"row\" *ngFor=\"let week of weeks; let indexRow = index\">\n <td\n role=\"gridcell\"\n *ngFor=\"let dayOfWeek of week; let indexColumn = index\"\n >\n <button\n class=\"btn w-100\"\n #dayButtonElemRef\n [id]=\"'day_' + indexRow + '_' + indexColumn\"\n [tabindex]=\"getDayTabIndex(dayOfWeek)\"\n [class.btn-info]=\"!isToday(dayOfWeek.date)\"\n [class.btn-secondary]=\"isToday(dayOfWeek.date)\"\n [class.btn-danger]=\"isSelected(dayOfWeek.date)\"\n [attr.aria-label]=\"\n weekDays[indexColumn] +\n ' ' +\n dayOfWeek.dateAsReadable\n \"\n [attr.data-is-today]=\"isToday(dayOfWeek.date)\"\n [attr.data-is-selected]=\"isSelected(dayOfWeek.date)\"\n [attr.data-row-index]=\"indexRow\"\n [attr.data-column-index]=\"indexColumn\"\n [attr.day-number]=\"dayOfWeek.dayOfMonth\"\n [attr.disabled]=\"!dayOfWeek.isCurrentMonth ? 'disabled' : null\"\n (click)=\"handleUserInput(dayOfWeek.date)\"\n >\n {{ dayOfWeek.dayOfMonth }}\n </button>\n </td>\n </tr>\n </tbody>\n </table>\n</div>\n", styles: [":host ::ng-deep .btn-link .svg-inline--fa{color:#000!important}#datepicker_header{margin-bottom:10px}#datepicker_wrapper{max-width:245px;padding:5px;border:1px solid #dfdfdf;background-color:#fff}#datepicker_wrapper .h4{margin-bottom:0}#datepicker_wrapper thead th{text-align:center;width:15%}#datepicker_wrapper .btn{padding:2px 4px}#datepicker_wrapper button.close{position:absolute;right:-14px;top:-18px;background-color:#fff;border:1px solid #dfdfdf;border-radius:50%;width:30px;height:30px;opacity:1}#datepicker_wrapper #month-input{width:50%;margin-right:5px}:host ::ng-deep foehn-select select.form-control{padding:0;margin:0;height:30px}:host ::ng-deep foehn-select .form-group{margin:0}\n"], components: [{ type: i2.FoehnIconChevronLeftComponent, selector: "foehn-icon-chevron-left" }, { type: i3.FoehnSelectComponent, selector: "foehn-select", inputs: ["multiple"] }, { type: i4.FoehnIconChevronRightComponent, selector: "foehn-icon-chevron-right" }, { type: i5.FoehnAbbrComponent, selector: "foehn-abbr", inputs: ["title", "text"] }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.CdkTrapFocus, selector: "[cdkTrapFocus]", inputs: ["cdkTrapFocus", "cdkTrapFocusAutoCapture"], exportAs: ["cdkTrapFocus"] }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "fromDictionary": i8.SdkDictionaryPipe, "async": i6.AsyncPipe } });
265
265
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: FoehnDatePickerComponent, decorators: [{
266
266
  type: Component,
267
267
  args: [{
@@ -297,4 +297,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImpor
297
297
  }], model: [{
298
298
  type: Input
299
299
  }] } });
300
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-date-picker.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-date-picker/foehn-date-picker.component.ts","../../../../projects/prestations-ng/src/foehn-date-picker/foehn-date-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    Component,\n    ElementRef,\n    EventEmitter,\n    HostListener,\n    Input,\n    NgZone,\n    OnDestroy,\n    OnInit,\n    Output,\n    QueryList,\n    ViewChildren\n} from '@angular/core';\nimport { DayMonth } from './day-month.type';\nimport { MonthYear } from './month-year.type';\nimport { DatePickerHelper } from './date-picker.helper';\nimport { SdkDictionaryService } from '../sdk-dictionary/sdk-dictionary.service';\nimport { Observable, Subscription } from 'rxjs';\nimport { distinctUntilChanged, first } from 'rxjs/operators';\nimport { FormSelectOption } from '../foehn-checkables/form-select-option';\n\nimport dayjs from 'dayjs';\nimport isToday from 'dayjs/plugin/isToday';\nimport { DatePickerNavigationHelper } from './date-picker-navigation.helper';\n\ndayjs.extend(isToday);\n\n@Component({\n    selector: 'foehn-date-picker',\n    templateUrl: './foehn-date-picker.component.html',\n    styleUrls: ['./foehn-date-picker.component.css']\n})\nexport class FoehnDatePickerComponent\n    implements OnInit, OnDestroy, AfterViewInit {\n    @Input()\n    minYear = dayjs().year() - 100;\n\n    @Input()\n    maxYear = dayjs().year() + 10;\n\n    @Input()\n    datepickerTriggerHtmlElement: HTMLElement;\n\n    @Input()\n    closeable = true;\n\n    @Output()\n    modelChange = new EventEmitter<number[]>();\n\n    @Output()\n    userInput = new EventEmitter<number[]>();\n\n    @Output()\n    isDatepickerVisibleChange = new EventEmitter();\n\n    @ViewChildren('dayButtonElemRef')\n    daysButtonsElemRef: QueryList<ElementRef>;\n\n    weekDays: string[] = [];\n    weeks: DayMonth[][];\n\n    selectedDate: dayjs.Dayjs;\n    currentMonthYear: Observable<MonthYear>;\n\n    model_: number[];\n    monthListItem: FormSelectOption[] = [];\n    yearListItem: FormSelectOption[] = [];\n\n    private isVisible = false;\n    private keyboardNavigationAllowed = false;\n    private currentLanguageCodeSubscription: Subscription;\n    private datePickerHelper = new DatePickerHelper();\n    private datePickerNavigationHelper = new DatePickerNavigationHelper();\n\n    private readonly displayNextMonthSubscription: Subscription;\n    private readonly displayPreviousMonthSubscription: Subscription;\n\n    constructor(\n        private dictionary: SdkDictionaryService,\n        private ngZone: NgZone\n    ) {\n        this.currentMonthYear = this.datePickerHelper.displayedMonthYear;\n        this.displayNextMonthSubscription = this.datePickerNavigationHelper.displayNextMonth.subscribe(\n            () => this.nextMonth()\n        );\n        this.displayPreviousMonthSubscription = this.datePickerNavigationHelper.displayPreviousMonth.subscribe(\n            () => this.previousMonth()\n        );\n    }\n\n    @HostListener('keyup', ['$event'])\n    handleKeyboardUpEvent(event: KeyboardEvent): void {\n        if (this.closeable && event.key === 'Escape') {\n            this.isDatepickerVisible = false;\n        }\n    }\n\n    @HostListener('keydown', ['$event'])\n    handleKeyboardDownEvent(event: KeyboardEvent): void {\n        if (this.keyboardNavigationAllowed) {\n            this.onKeyDownInner(event);\n        }\n    }\n\n    @Input()\n    get isDatepickerVisible(): boolean {\n        return this.isVisible;\n    }\n\n    set isDatepickerVisible(val: boolean) {\n        // Store the previous value to handle transitions from one state to another.\n        const wasOpen = this.isVisible;\n\n        // Ensure we always initialize date picker depending on it's model\n        if (!wasOpen && this.closeable) {\n            this.onModelChange(this.model);\n        }\n\n        this.isVisible = val;\n        this.isDatepickerVisibleChange.emit(this.isVisible);\n\n        this.focusDefaultDay();\n        this.focusOnDatepickerTrigger(wasOpen, val);\n    }\n\n    @Input()\n    set model(value: number[]) {\n        this.onModelChange(value);\n    }\n\n    get model(): number[] {\n        return this.model_;\n    }\n\n    ngOnInit(): void {\n        this.currentLanguageCodeSubscription = this.dictionary\n            .getCurrentLanguageCode()\n            .pipe(distinctUntilChanged())\n            .subscribe((code: string) => {\n                this.datePickerHelper\n                    .loadLocale(code)\n                    .catch(() => {\n                        console.warn(\n                            `locale '${code}' does not exist. Fallback to 'en.'`\n                        );\n                    })\n                    .then(() => {\n                        this.initializeDatepicker();\n                    });\n            });\n    }\n\n    ngAfterViewInit(): void {\n        this.daysButtonsElemRef.changes.subscribe(() => {\n            this.datePickerNavigationHelper.daysButtonsElemRef = this.daysButtonsElemRef;\n        });\n    }\n\n    ngOnDestroy(): void {\n        if (!!this.currentLanguageCodeSubscription) {\n            this.currentLanguageCodeSubscription.unsubscribe();\n        }\n        if (!!this.displayNextMonthSubscription) {\n            this.displayNextMonthSubscription.unsubscribe();\n        }\n        if (!!this.displayPreviousMonthSubscription) {\n            this.displayPreviousMonthSubscription.unsubscribe();\n        }\n    }\n\n    onModelChange(value: number[]): void {\n        if (\n            !!value &&\n            value.length > 2 &&\n            !!value[0] &&\n            value[0] >= this.minYear &&\n            !!value[1] &&\n            !!value[2]\n        ) {\n            const dateAsString = `${value[0]}-${value[1]}-${value[2]}`;\n            if (dayjs(dateAsString).isValid()) {\n                this.setDate(dayjs(dateAsString));\n            }\n        } else if (this.selectedDate) {\n            this.setDate(null);\n        }\n        this.updateNgModel(value);\n    }\n\n    updateNgModel(value: number[]): void {\n        this.model_ = value;\n        this.modelChange.emit(value);\n    }\n\n    isToday(date: dayjs.Dayjs): boolean {\n        return date.isToday();\n    }\n\n    isSelected(date: dayjs.Dayjs): boolean {\n        if (!this.selectedDate) {\n            return false;\n        }\n        return date.isSame(this.selectedDate);\n    }\n\n    handleUserInput(date: dayjs.Dayjs): void {\n        const dateAsArray = this.getDateAsArray(date);\n\n        this.userInput.next(dateAsArray);\n        this.updateNgModel(dateAsArray);\n    }\n\n    previousMonth(): void {\n        this.weeks = this.datePickerHelper.getPreviousWeeksOfMonth();\n    }\n\n    nextMonth(): void {\n        this.weeks = this.datePickerHelper.getNextWeeksOfMonth();\n    }\n\n    userInputMonth(month: string): void {\n        this.weeks = this.datePickerHelper.getWeeksOfMonth(\n            this.datePickerHelper.initialYear,\n            (+month + 1).toString(),\n            this.datePickerHelper.initialDay\n        );\n    }\n\n    userInputYear(year: string): void {\n        this.weeks = this.datePickerHelper.getWeeksOfMonth(\n            year,\n            this.datePickerHelper.initialMonth,\n            this.datePickerHelper.initialDay\n        );\n    }\n\n    getMonthAsReadable(monthIndex: string): string {\n        return this.monthListItem.find(elem => elem.value === monthIndex).label;\n    }\n\n    onDaysFocusin(): void {\n        this.keyboardNavigationAllowed = true;\n        this.datePickerNavigationHelper.currentFocusedElement =\n            document.activeElement;\n    }\n\n    onDaysFocusout(): void {\n        this.keyboardNavigationAllowed = false;\n    }\n\n    getDayTabIndex(day: DayMonth): number {\n        if (\n            this.selectedDate &&\n            this.selectedDate.month() === day.date.month() &&\n            this.selectedDate.year() === day.date.year()\n        ) {\n            if (this.selectedDate.date() === day.date.date()) {\n                return 0;\n            }\n            return -1;\n        } else if (this.isToday(day.date)) {\n            return 0;\n        } else if (\n            day.isCurrentMonth &&\n            day.dayOfMonth === 1 &&\n            (day.date.month() !== dayjs().month() ||\n                day.date.year() !== dayjs().year())\n        ) {\n            return 0;\n        }\n        return -1;\n    }\n\n    focusDefaultDay(): void {\n        // Have to wait for a micro task empty as we're affecting the DOM outside of the Angular lifecycle.\n        this.ngZone.onMicrotaskEmpty.pipe(first()).subscribe(() => {\n            if (this.isVisible && this.datepickerTriggerHtmlElement) {\n                this.datePickerNavigationHelper.focusDefaultDay(\n                    !!this.selectedDate\n                );\n            }\n        });\n    }\n\n    private initializeDatepicker(): void {\n        this.populateMonthList();\n        this.populateYearList();\n        this.weekDays = this.datePickerHelper.getWeekDays();\n        this.weeks = this.datePickerHelper.getWeeksOfMonth(\n            dayjs().format(this.datePickerHelper.YEAR_STRING_FORMAT),\n            dayjs().format(this.datePickerHelper.MONTH_STRING_NUMBER_FORMAT)\n        );\n    }\n\n    private setDate(date: dayjs.Dayjs): void {\n        this.selectedDate = date;\n\n        // Either we have a date to set or we take today\n        const dateToFormat = date ? date : dayjs();\n        this.weeks = this.datePickerHelper.getWeeksOfMonth(\n            dateToFormat.format(this.datePickerHelper.YEAR_STRING_FORMAT),\n            dateToFormat.format(\n                this.datePickerHelper.MONTH_STRING_NUMBER_FORMAT\n            ),\n            dateToFormat.format(this.datePickerHelper.DAY_STRING_NUMBER_FORMAT)\n        );\n    }\n\n    private getDateAsArray(date: dayjs.Dayjs): number[] {\n        return [\n            +date.format(this.datePickerHelper.YEAR_STRING_FORMAT),\n            +date.format(this.datePickerHelper.MONTH_STRING_NUMBER_FORMAT),\n            +date.format(this.datePickerHelper.DAY_STRING_NUMBER_FORMAT)\n        ];\n    }\n\n    private focusOnDatepickerTrigger(\n        wasOpen: boolean,\n        isVisible: boolean\n    ): void {\n        // Focus back on the trigger. No need for a setTimeout as the trigger should still be in the DOM.\n        // Only does it when the modal is closed from a open state to avoid to set\n        // the focus when the page loads.\n        if (wasOpen && !isVisible && this.datepickerTriggerHtmlElement) {\n            this.datepickerTriggerHtmlElement.focus();\n        }\n    }\n\n    private populateMonthList(): void {\n        this.monthListItem = dayjs()\n            .localeData()\n            .months()\n            .map((month: string, index: number) => ({\n                label: month,\n                value: index.toString()\n            }));\n    }\n\n    private populateYearList(): void {\n        const range = (start: number, end: number): number[] =>\n            Array.from({ length: end - start + 1 }, (v, k) => k + start);\n\n        this.yearListItem = range(this.minYear, this.maxYear).map(\n            (year: number) => ({\n                label: year.toString(),\n                value: year.toString()\n            })\n        );\n    }\n\n    private onKeyDownInner(keyEvent: KeyboardEvent): boolean {\n        // IE doesn't support keyEvent.code, and has different values\n        // in keyEvent.key (Down instead of ArrowDown for instance), hence the multi-support.\n        const ie11CompatibleCode = keyEvent.code || keyEvent.key;\n        switch (ie11CompatibleCode) {\n            case 'Down':\n            case 'ArrowDown':\n                this.datePickerNavigationHelper.focusNextWeekDay();\n                break;\n            case 'Up':\n            case 'ArrowUp':\n                this.datePickerNavigationHelper.focusPreviousWeekDay();\n                break;\n            case 'Space':\n            case 'Spacebar':\n            case 'Enter':\n                document.activeElement.dispatchEvent(new Event('click'));\n                break;\n            case 'Right':\n            case 'ArrowRight':\n                this.datePickerNavigationHelper.focusNextDay();\n                break;\n            case 'Left':\n            case 'ArrowLeft':\n                this.datePickerNavigationHelper.focusPreviousDay();\n                break;\n            default:\n                return true;\n        }\n\n        keyEvent.preventDefault();\n        keyEvent.stopPropagation();\n\n        return false;\n    }\n}\n","<div\n    id=\"datepicker_wrapper\"\n    *ngIf=\"isDatepickerVisible\"\n    [cdkTrapFocus]=\"!!datepickerTriggerHtmlElement\"\n    tabindex=\"-1\"\n    role=\"application\"\n    [attr.aria-label]=\"\n        'foehn-date-picker.container.aria-label' | fromDictionary\n    \"\n>\n    <button\n        *ngIf=\"closeable\"\n        (click)=\"isDatepickerVisible = false\"\n        type=\"button\"\n        class=\"btn close\"\n        [attr.aria-label]=\"\n            'foehn-date-picker.close-button.aria-label' | fromDictionary\n        \"\n        id=\"closeButton\"\n    >\n        <span aria-hidden=\"true\">&times;</span>\n    </button>\n    <div id=\"datepicker_header\" class=\"d-flex justify-content-between\">\n        <button\n            id=\"previous-month\"\n            class=\"btn btn-link\"\n            (click)=\"previousMonth()\"\n        >\n            <foehn-icon-chevron-left\n                [title]=\"\n                    'foehn-date-picker.previous-month-button.title'\n                        | fromDictionary\n                \"\n            ></foehn-icon-chevron-left>\n        </button>\n        <ng-container *ngIf=\"currentMonthYear | async as monthYear\">\n            <span id=\"month-year-label\" aria-live=\"polite\" class=\"sr-only\">\n                {{\n                    'foehn-date-picker.screen-reader.actual-month-displayed'\n                        | fromDictionary\n                }}\n                {{ getMonthAsReadable(monthYear.month) }} {{ monthYear.year }}\n            </span>\n            <foehn-select\n                id=\"month-input\"\n                class=\"align-self-center\"\n                [label]=\"\n                    'foehn-date-picker.screen-reader.month-input.label'\n                        | fromDictionary\n                \"\n                [isLabelSrOnly]=\"true\"\n                [elements]=\"monthListItem\"\n                [model]=\"monthYear.month\"\n                [required]=\"false\"\n                (userInput)=\"userInputMonth($event)\"\n            ></foehn-select>\n            <foehn-select\n                id=\"year-input\"\n                class=\"align-self-center\"\n                [label]=\"\n                    'foehn-date-picker.screen-reader.year-input.label'\n                        | fromDictionary\n                \"\n                [isLabelSrOnly]=\"true\"\n                [elements]=\"yearListItem\"\n                [model]=\"monthYear.year\"\n                [required]=\"false\"\n                (userInput)=\"userInputYear($event)\"\n            ></foehn-select>\n        </ng-container>\n        <button id=\"next-month\" class=\"btn btn-link\" (click)=\"nextMonth()\">\n            <foehn-icon-chevron-right\n                [title]=\"\n                    'foehn-date-picker.next-month-button.title' | fromDictionary\n                \"\n            ></foehn-icon-chevron-right>\n        </button>\n    </div>\n    <table\n        id=\"datepicker_table\"\n        role=\"grid\"\n        (focusin)=\"onDaysFocusin()\"\n        (focusout)=\"onDaysFocusout()\"\n    >\n        <thead role=\"presentation\" aria-hidden=\"true\">\n            <tr role=\"row\">\n                <th\n                    scope=\"col\"\n                    role=\"columnheader\"\n                    *ngFor=\"let weekday of weekDays\"\n                >\n                    <foehn-abbr\n                        [text]=\"weekday.substr(0, 2)\"\n                        [title]=\"weekday\"\n                    ></foehn-abbr>\n                </th>\n            </tr>\n        </thead>\n        <tbody role=\"presentation\">\n            <tr role=\"row\" *ngFor=\"let week of weeks; let indexRow = index\">\n                <td\n                    role=\"gridcell\"\n                    *ngFor=\"let dayOfWeek of week; let indexColumn = index\"\n                >\n                    <button\n                        class=\"btn w-100\"\n                        #dayButtonElemRef\n                        [id]=\"'day_' + indexRow + '_' + indexColumn\"\n                        [tabindex]=\"getDayTabIndex(dayOfWeek)\"\n                        [class.btn-info]=\"!isToday(dayOfWeek.date)\"\n                        [class.btn-secondary]=\"isToday(dayOfWeek.date)\"\n                        [class.btn-danger]=\"isSelected(dayOfWeek.date)\"\n                        [attr.aria-label]=\"\n                            weekDays[indexColumn] +\n                            ' ' +\n                            dayOfWeek.dateAsReadable\n                        \"\n                        [attr.data-is-today]=\"isToday(dayOfWeek.date)\"\n                        [attr.data-is-selected]=\"isSelected(dayOfWeek.date)\"\n                        [attr.data-row-index]=\"indexRow\"\n                        [attr.data-column-index]=\"indexColumn\"\n                        [attr.day-number]=\"dayOfWeek.dayOfMonth\"\n                        [disabled]=\"!dayOfWeek.isCurrentMonth\"\n                        (click)=\"handleUserInput(dayOfWeek.date)\"\n                    >\n                        {{ dayOfWeek.dayOfMonth }}\n                    </button>\n                </td>\n            </tr>\n        </tbody>\n    </table>\n</div>\n"]}
300
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"foehn-date-picker.component.js","sourceRoot":"","sources":["../../../../projects/prestations-ng/src/foehn-date-picker/foehn-date-picker.component.ts","../../../../projects/prestations-ng/src/foehn-date-picker/foehn-date-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    Component,\n    ElementRef,\n    EventEmitter,\n    HostListener,\n    Input,\n    NgZone,\n    OnDestroy,\n    OnInit,\n    Output,\n    QueryList,\n    ViewChildren\n} from '@angular/core';\nimport { DayMonth } from './day-month.type';\nimport { MonthYear } from './month-year.type';\nimport { DatePickerHelper } from './date-picker.helper';\nimport { SdkDictionaryService } from '../sdk-dictionary/sdk-dictionary.service';\nimport { Observable, Subscription } from 'rxjs';\nimport { distinctUntilChanged, first } from 'rxjs/operators';\nimport { FormSelectOption } from '../foehn-checkables/form-select-option';\n\nimport dayjs from 'dayjs';\nimport isToday from 'dayjs/plugin/isToday';\nimport { DatePickerNavigationHelper } from './date-picker-navigation.helper';\n\ndayjs.extend(isToday);\n\n@Component({\n    selector: 'foehn-date-picker',\n    templateUrl: './foehn-date-picker.component.html',\n    styleUrls: ['./foehn-date-picker.component.css']\n})\nexport class FoehnDatePickerComponent\n    implements OnInit, OnDestroy, AfterViewInit {\n    @Input()\n    minYear = dayjs().year() - 100;\n\n    @Input()\n    maxYear = dayjs().year() + 10;\n\n    @Input()\n    datepickerTriggerHtmlElement: HTMLElement;\n\n    @Input()\n    closeable = true;\n\n    @Output()\n    modelChange = new EventEmitter<number[]>();\n\n    @Output()\n    userInput = new EventEmitter<number[]>();\n\n    @Output()\n    isDatepickerVisibleChange = new EventEmitter();\n\n    @ViewChildren('dayButtonElemRef')\n    daysButtonsElemRef: QueryList<ElementRef>;\n\n    weekDays: string[] = [];\n    weeks: DayMonth[][];\n\n    selectedDate: dayjs.Dayjs;\n    currentMonthYear: Observable<MonthYear>;\n\n    model_: number[];\n    monthListItem: FormSelectOption[] = [];\n    yearListItem: FormSelectOption[] = [];\n\n    private isVisible = false;\n    private keyboardNavigationAllowed = false;\n    private currentLanguageCodeSubscription: Subscription;\n    private datePickerHelper = new DatePickerHelper();\n    private datePickerNavigationHelper = new DatePickerNavigationHelper();\n\n    private readonly displayNextMonthSubscription: Subscription;\n    private readonly displayPreviousMonthSubscription: Subscription;\n\n    constructor(\n        private dictionary: SdkDictionaryService,\n        private ngZone: NgZone\n    ) {\n        this.currentMonthYear = this.datePickerHelper.displayedMonthYear;\n        this.displayNextMonthSubscription = this.datePickerNavigationHelper.displayNextMonth.subscribe(\n            () => this.nextMonth()\n        );\n        this.displayPreviousMonthSubscription = this.datePickerNavigationHelper.displayPreviousMonth.subscribe(\n            () => this.previousMonth()\n        );\n    }\n\n    @HostListener('keyup', ['$event'])\n    handleKeyboardUpEvent(event: KeyboardEvent): void {\n        if (this.closeable && event.key === 'Escape') {\n            this.isDatepickerVisible = false;\n        }\n    }\n\n    @HostListener('keydown', ['$event'])\n    handleKeyboardDownEvent(event: KeyboardEvent): void {\n        if (this.keyboardNavigationAllowed) {\n            this.onKeyDownInner(event);\n        }\n    }\n\n    @Input()\n    get isDatepickerVisible(): boolean {\n        return this.isVisible;\n    }\n\n    set isDatepickerVisible(val: boolean) {\n        // Store the previous value to handle transitions from one state to another.\n        const wasOpen = this.isVisible;\n\n        // Ensure we always initialize date picker depending on it's model\n        if (!wasOpen && this.closeable) {\n            this.onModelChange(this.model);\n        }\n\n        this.isVisible = val;\n        this.isDatepickerVisibleChange.emit(this.isVisible);\n\n        this.focusDefaultDay();\n        this.focusOnDatepickerTrigger(wasOpen, val);\n    }\n\n    @Input()\n    set model(value: number[]) {\n        this.onModelChange(value);\n    }\n\n    get model(): number[] {\n        return this.model_;\n    }\n\n    ngOnInit(): void {\n        this.currentLanguageCodeSubscription = this.dictionary\n            .getCurrentLanguageCode()\n            .pipe(distinctUntilChanged())\n            .subscribe((code: string) => {\n                this.datePickerHelper\n                    .loadLocale(code)\n                    .catch(() => {\n                        console.warn(\n                            `locale '${code}' does not exist. Fallback to 'en.'`\n                        );\n                    })\n                    .then(() => {\n                        this.initializeDatepicker();\n                    });\n            });\n    }\n\n    ngAfterViewInit(): void {\n        this.daysButtonsElemRef.changes.subscribe(() => {\n            this.datePickerNavigationHelper.daysButtonsElemRef = this.daysButtonsElemRef;\n        });\n    }\n\n    ngOnDestroy(): void {\n        if (!!this.currentLanguageCodeSubscription) {\n            this.currentLanguageCodeSubscription.unsubscribe();\n        }\n        if (!!this.displayNextMonthSubscription) {\n            this.displayNextMonthSubscription.unsubscribe();\n        }\n        if (!!this.displayPreviousMonthSubscription) {\n            this.displayPreviousMonthSubscription.unsubscribe();\n        }\n    }\n\n    onModelChange(value: number[]): void {\n        if (\n            !!value &&\n            value.length > 2 &&\n            !!value[0] &&\n            value[0] >= this.minYear &&\n            !!value[1] &&\n            !!value[2]\n        ) {\n            const dateAsString = `${value[0]}-${value[1]}-${value[2]}`;\n            if (dayjs(dateAsString).isValid()) {\n                this.setDate(dayjs(dateAsString));\n            }\n        } else if (this.selectedDate) {\n            this.setDate(null);\n        }\n        this.updateNgModel(value);\n    }\n\n    updateNgModel(value: number[]): void {\n        this.model_ = value;\n        this.modelChange.emit(value);\n    }\n\n    isToday(date: dayjs.Dayjs): boolean {\n        return date.isToday();\n    }\n\n    isSelected(date: dayjs.Dayjs): boolean {\n        if (!this.selectedDate) {\n            return false;\n        }\n        return date.isSame(this.selectedDate);\n    }\n\n    handleUserInput(date: dayjs.Dayjs): void {\n        const dateAsArray = this.getDateAsArray(date);\n\n        this.userInput.next(dateAsArray);\n        this.updateNgModel(dateAsArray);\n    }\n\n    previousMonth(): void {\n        this.weeks = this.datePickerHelper.getPreviousWeeksOfMonth();\n    }\n\n    nextMonth(): void {\n        this.weeks = this.datePickerHelper.getNextWeeksOfMonth();\n    }\n\n    userInputMonth(month: string): void {\n        this.weeks = this.datePickerHelper.getWeeksOfMonth(\n            this.datePickerHelper.initialYear,\n            (+month + 1).toString(),\n            this.datePickerHelper.initialDay\n        );\n    }\n\n    userInputYear(year: string): void {\n        this.weeks = this.datePickerHelper.getWeeksOfMonth(\n            year,\n            this.datePickerHelper.initialMonth,\n            this.datePickerHelper.initialDay\n        );\n    }\n\n    getMonthAsReadable(monthIndex: string): string {\n        return this.monthListItem.find(elem => elem.value === monthIndex).label;\n    }\n\n    onDaysFocusin(): void {\n        this.keyboardNavigationAllowed = true;\n        this.datePickerNavigationHelper.currentFocusedElement =\n            document.activeElement;\n    }\n\n    onDaysFocusout(): void {\n        this.keyboardNavigationAllowed = false;\n    }\n\n    getDayTabIndex(day: DayMonth): number {\n        if (\n            this.selectedDate &&\n            this.selectedDate.month() === day.date.month() &&\n            this.selectedDate.year() === day.date.year()\n        ) {\n            if (this.selectedDate.date() === day.date.date()) {\n                return 0;\n            }\n            return -1;\n        } else if (this.isToday(day.date)) {\n            return 0;\n        } else if (\n            day.isCurrentMonth &&\n            day.dayOfMonth === 1 &&\n            (day.date.month() !== dayjs().month() ||\n                day.date.year() !== dayjs().year())\n        ) {\n            return 0;\n        }\n        return -1;\n    }\n\n    focusDefaultDay(): void {\n        // Have to wait for a micro task empty as we're affecting the DOM outside of the Angular lifecycle.\n        this.ngZone.onMicrotaskEmpty.pipe(first()).subscribe(() => {\n            if (this.isVisible && this.datepickerTriggerHtmlElement) {\n                this.datePickerNavigationHelper.focusDefaultDay(\n                    !!this.selectedDate\n                );\n            }\n        });\n    }\n\n    private initializeDatepicker(): void {\n        this.populateMonthList();\n        this.populateYearList();\n        this.weekDays = this.datePickerHelper.getWeekDays();\n        this.weeks = this.datePickerHelper.getWeeksOfMonth(\n            dayjs().format(this.datePickerHelper.YEAR_STRING_FORMAT),\n            dayjs().format(this.datePickerHelper.MONTH_STRING_NUMBER_FORMAT)\n        );\n    }\n\n    private setDate(date: dayjs.Dayjs): void {\n        this.selectedDate = date;\n\n        // Either we have a date to set or we take today\n        const dateToFormat = date ? date : dayjs();\n        this.weeks = this.datePickerHelper.getWeeksOfMonth(\n            dateToFormat.format(this.datePickerHelper.YEAR_STRING_FORMAT),\n            dateToFormat.format(\n                this.datePickerHelper.MONTH_STRING_NUMBER_FORMAT\n            ),\n            dateToFormat.format(this.datePickerHelper.DAY_STRING_NUMBER_FORMAT)\n        );\n    }\n\n    private getDateAsArray(date: dayjs.Dayjs): number[] {\n        return [\n            +date.format(this.datePickerHelper.YEAR_STRING_FORMAT),\n            +date.format(this.datePickerHelper.MONTH_STRING_NUMBER_FORMAT),\n            +date.format(this.datePickerHelper.DAY_STRING_NUMBER_FORMAT)\n        ];\n    }\n\n    private focusOnDatepickerTrigger(\n        wasOpen: boolean,\n        isVisible: boolean\n    ): void {\n        // Focus back on the trigger. No need for a setTimeout as the trigger should still be in the DOM.\n        // Only does it when the modal is closed from a open state to avoid to set\n        // the focus when the page loads.\n        if (wasOpen && !isVisible && this.datepickerTriggerHtmlElement) {\n            this.datepickerTriggerHtmlElement.focus();\n        }\n    }\n\n    private populateMonthList(): void {\n        this.monthListItem = dayjs()\n            .localeData()\n            .months()\n            .map((month: string, index: number) => ({\n                label: month,\n                value: index.toString()\n            }));\n    }\n\n    private populateYearList(): void {\n        const range = (start: number, end: number): number[] =>\n            Array.from({ length: end - start + 1 }, (v, k) => k + start);\n\n        this.yearListItem = range(this.minYear, this.maxYear).map(\n            (year: number) => ({\n                label: year.toString(),\n                value: year.toString()\n            })\n        );\n    }\n\n    private onKeyDownInner(keyEvent: KeyboardEvent): boolean {\n        // IE doesn't support keyEvent.code, and has different values\n        // in keyEvent.key (Down instead of ArrowDown for instance), hence the multi-support.\n        const ie11CompatibleCode = keyEvent.code || keyEvent.key;\n        switch (ie11CompatibleCode) {\n            case 'Down':\n            case 'ArrowDown':\n                this.datePickerNavigationHelper.focusNextWeekDay();\n                break;\n            case 'Up':\n            case 'ArrowUp':\n                this.datePickerNavigationHelper.focusPreviousWeekDay();\n                break;\n            case 'Space':\n            case 'Spacebar':\n            case 'Enter':\n                document.activeElement.dispatchEvent(new Event('click'));\n                break;\n            case 'Right':\n            case 'ArrowRight':\n                this.datePickerNavigationHelper.focusNextDay();\n                break;\n            case 'Left':\n            case 'ArrowLeft':\n                this.datePickerNavigationHelper.focusPreviousDay();\n                break;\n            default:\n                return true;\n        }\n\n        keyEvent.preventDefault();\n        keyEvent.stopPropagation();\n\n        return false;\n    }\n}\n","<div\n    id=\"datepicker_wrapper\"\n    *ngIf=\"isDatepickerVisible\"\n    [cdkTrapFocus]=\"!!datepickerTriggerHtmlElement\"\n    tabindex=\"-1\"\n    role=\"application\"\n    [attr.aria-label]=\"\n        'foehn-date-picker.container.aria-label' | fromDictionary\n    \"\n>\n    <button\n        *ngIf=\"closeable\"\n        (click)=\"isDatepickerVisible = false\"\n        type=\"button\"\n        class=\"btn close\"\n        [attr.aria-label]=\"\n            'foehn-date-picker.close-button.aria-label' | fromDictionary\n        \"\n        id=\"closeButton\"\n    >\n        <span aria-hidden=\"true\">&times;</span>\n    </button>\n    <div id=\"datepicker_header\" class=\"d-flex justify-content-between\">\n        <button\n            id=\"previous-month\"\n            class=\"btn btn-link\"\n            (click)=\"previousMonth()\"\n        >\n            <foehn-icon-chevron-left\n                [title]=\"\n                    'foehn-date-picker.previous-month-button.title'\n                        | fromDictionary\n                \"\n            ></foehn-icon-chevron-left>\n        </button>\n        <ng-container *ngIf=\"currentMonthYear | async as monthYear\">\n            <span id=\"month-year-label\" aria-live=\"polite\" class=\"sr-only\">\n                {{\n                    'foehn-date-picker.screen-reader.actual-month-displayed'\n                        | fromDictionary\n                }}\n                {{ getMonthAsReadable(monthYear.month) }} {{ monthYear.year }}\n            </span>\n            <foehn-select\n                id=\"month-input\"\n                class=\"align-self-center\"\n                [label]=\"\n                    'foehn-date-picker.screen-reader.month-input.label'\n                        | fromDictionary\n                \"\n                [isLabelSrOnly]=\"true\"\n                [elements]=\"monthListItem\"\n                [model]=\"monthYear.month\"\n                [required]=\"false\"\n                (userInput)=\"userInputMonth($event)\"\n            ></foehn-select>\n            <foehn-select\n                id=\"year-input\"\n                class=\"align-self-center\"\n                [label]=\"\n                    'foehn-date-picker.screen-reader.year-input.label'\n                        | fromDictionary\n                \"\n                [isLabelSrOnly]=\"true\"\n                [elements]=\"yearListItem\"\n                [model]=\"monthYear.year\"\n                [required]=\"false\"\n                (userInput)=\"userInputYear($event)\"\n            ></foehn-select>\n        </ng-container>\n        <button id=\"next-month\" class=\"btn btn-link\" (click)=\"nextMonth()\">\n            <foehn-icon-chevron-right\n                [title]=\"\n                    'foehn-date-picker.next-month-button.title' | fromDictionary\n                \"\n            ></foehn-icon-chevron-right>\n        </button>\n    </div>\n    <table\n        id=\"datepicker_table\"\n        role=\"grid\"\n        (focusin)=\"onDaysFocusin()\"\n        (focusout)=\"onDaysFocusout()\"\n    >\n        <thead role=\"presentation\" aria-hidden=\"true\">\n            <tr role=\"row\">\n                <th\n                    scope=\"col\"\n                    role=\"columnheader\"\n                    *ngFor=\"let weekday of weekDays\"\n                >\n                    <foehn-abbr\n                        [text]=\"weekday.substr(0, 2)\"\n                        [title]=\"weekday\"\n                    ></foehn-abbr>\n                </th>\n            </tr>\n        </thead>\n        <tbody role=\"presentation\">\n            <tr role=\"row\" *ngFor=\"let week of weeks; let indexRow = index\">\n                <td\n                    role=\"gridcell\"\n                    *ngFor=\"let dayOfWeek of week; let indexColumn = index\"\n                >\n                    <button\n                        class=\"btn w-100\"\n                        #dayButtonElemRef\n                        [id]=\"'day_' + indexRow + '_' + indexColumn\"\n                        [tabindex]=\"getDayTabIndex(dayOfWeek)\"\n                        [class.btn-info]=\"!isToday(dayOfWeek.date)\"\n                        [class.btn-secondary]=\"isToday(dayOfWeek.date)\"\n                        [class.btn-danger]=\"isSelected(dayOfWeek.date)\"\n                        [attr.aria-label]=\"\n                            weekDays[indexColumn] +\n                            ' ' +\n                            dayOfWeek.dateAsReadable\n                        \"\n                        [attr.data-is-today]=\"isToday(dayOfWeek.date)\"\n                        [attr.data-is-selected]=\"isSelected(dayOfWeek.date)\"\n                        [attr.data-row-index]=\"indexRow\"\n                        [attr.data-column-index]=\"indexColumn\"\n                        [attr.day-number]=\"dayOfWeek.dayOfMonth\"\n                        [attr.disabled]=\"!dayOfWeek.isCurrentMonth ? 'disabled' : null\"\n                        (click)=\"handleUserInput(dayOfWeek.date)\"\n                    >\n                        {{ dayOfWeek.dayOfMonth }}\n                    </button>\n                </td>\n            </tr>\n        </tbody>\n    </table>\n</div>\n"]}
@@ -36,7 +36,7 @@ FoehnInputEmailComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0
36
36
  useExisting: forwardRef(() => FoehnInputEmailComponent),
37
37
  multi: true
38
38
  }
39
- ], usesInheritance: true, ngImport: i0, template: "<div\n class=\"form-group clearable-input-form-group\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n [attr.id]=\"buildId('Container')\"\n tabindex=\"-1\"\n>\n <label\n [attr.for]=\"buildChildId()\"\n *ngIf=\"label && type !== 'hidden'\"\n [ngClass]=\"isLabelSrOnly ? 'sr-only' : labelStyleModifier\"\n >\n <span [innerHTML]=\"label\"></span>\n <span\n *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n aria-hidden=\"true\"\n >\n {{ 'foehn-input.optional' | fromDictionary }}\n </span>\n </label>\n\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n <small\n *ngIf=\"helpText && type !== 'hidden'\"\n [attr.id]=\"buildChildId() + 'Help'\"\n class=\"form-text text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-content></ng-content>\n\n <input\n [class.is-invalid]=\"hasErrorsToDisplay() || hasInheritErrorFromParent()\"\n [class.clearable-input]=\"displayClearButton() | async\"\n class=\"form-control\"\n [name]=\"name || label\"\n [attr.maxlength]=\"getMaxLength()\"\n [attr.autocomplete]=\"getAutoComplete()\"\n [attr.disabled]=\"disabled ? 'disabled' : null\"\n [attr.type]=\"type\"\n [attr.pattern]=\"pattern\"\n [attr.min]=\"min\"\n [attr.max]=\"max\"\n [attr.id]=\"buildChildId()\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n [attr.aria-required]=\"required || null\"\n [ngModel]=\"model\"\n (paste)=\"onPaste($event)\"\n (ngModelChange)=\"updateNgModel($event)\"\n (input)=\"handleChange(entryComponent.value)\"\n (keydown)=\"onKeydown($event)\"\n (blur)=\"onBlur($event)\"\n (focus)=\"onFocus($event)\"\n #entryComponent\n />\n\n <button\n type=\"button\"\n [id]=\"buildChildId() + 'ClearButton'\"\n *ngIf=\"displayClearButton() | async\"\n class=\"clearable-input-clear-button btn\"\n (click)=\"onClear()\"\n >\n <foehn-icon-times\n class=\"clearable-input-clear-button-icon\"\n title=\"R\u00E9initialiser le champs\"\n ></foehn-icon-times>\n </button>\n</div>\n", styles: ["input::-ms-clear{display:none}input.clearable-input{padding-right:30px}.clearable-input-form-group{position:relative}.clearable-input-clear-button{position:absolute;bottom:4px;right:4px;height:30px;width:30px;background:none;border:none}.clearable-input-clear-button-icon{top:4px;right:8px;position:absolute}:host ::ng-deep .clearable-input-clear-button.btn .svg-inline--fa{color:#595959!important}:host ::ng-deep .clearable-input-clear-button.btn:hover .svg-inline--fa{color:#000!important}.chars-remaining{color:#757575;font-size:.9rem}.char-count-exceeded{color:#c21f39}:host ::ng-deep .sameLine-list{display:inline;list-style:none;padding:0}:host ::ng-deep .sameLine-list li{display:inline;padding:3px}\n"], components: [{ type: i1.FoehnValidationAlertsComponent, selector: "foehn-validation-alerts", inputs: ["component", "shouldErrorsBeLive"] }, { type: i2.FoehnIconTimesComponent, selector: "foehn-icon-times" }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i4.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { type: i4.PatternValidator, selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: ["pattern"] }, { type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], pipes: { "fromDictionary": i5.SdkDictionaryPipe, "async": i3.AsyncPipe } });
39
+ ], usesInheritance: true, ngImport: i0, template: "<div\n class=\"form-group clearable-input-form-group\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n [attr.id]=\"buildId('Container')\"\n tabindex=\"-1\"\n>\n <label\n [attr.id]=\"buildChildId() + 'Label'\"\n [attr.for]=\"buildChildId()\"\n *ngIf=\"label && type !== 'hidden'\"\n [ngClass]=\"isLabelSrOnly ? 'sr-only' : labelStyleModifier\"\n >\n <span [innerHTML]=\"label\"></span>\n <span\n *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n aria-hidden=\"true\"\n >\n {{ 'foehn-input.optional' | fromDictionary }}\n </span>\n </label>\n\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n <small\n *ngIf=\"helpText && type !== 'hidden'\"\n [attr.id]=\"buildChildId() + 'Help'\"\n class=\"form-text text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-content></ng-content>\n\n <input\n [class.is-invalid]=\"hasErrorsToDisplay() || hasInheritErrorFromParent()\"\n [class.clearable-input]=\"displayClearButton() | async\"\n class=\"form-control\"\n [name]=\"name || label\"\n [attr.maxlength]=\"getMaxLength()\"\n [attr.autocomplete]=\"getAutoComplete()\"\n [attr.disabled]=\"disabled ? 'disabled' : null\"\n [attr.type]=\"type\"\n [attr.pattern]=\"pattern\"\n [attr.min]=\"min\"\n [attr.max]=\"max\"\n [attr.id]=\"buildChildId()\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n [attr.aria-required]=\"required || null\"\n [ngModel]=\"model\"\n (paste)=\"onPaste($event)\"\n (ngModelChange)=\"updateNgModel($event)\"\n (input)=\"handleChange(entryComponent.value)\"\n (keydown)=\"onKeydown($event)\"\n (blur)=\"onBlur($event)\"\n (focus)=\"onFocus($event)\"\n #entryComponent\n />\n\n <button\n type=\"button\"\n [id]=\"buildChildId() + 'ClearButton'\"\n *ngIf=\"displayClearButton() | async\"\n class=\"clearable-input-clear-button btn\"\n (click)=\"onClear()\"\n >\n <foehn-icon-times\n class=\"clearable-input-clear-button-icon\"\n title=\"R\u00E9initialiser le champs\"\n ></foehn-icon-times>\n </button>\n</div>\n", styles: ["input::-ms-clear{display:none}input.clearable-input{padding-right:30px}.clearable-input-form-group{position:relative}.clearable-input-clear-button{position:absolute;bottom:4px;right:4px;height:30px;width:30px;background:none;border:none}.clearable-input-clear-button-icon{top:4px;right:8px;position:absolute}:host ::ng-deep .clearable-input-clear-button.btn .svg-inline--fa{color:#595959!important}:host ::ng-deep .clearable-input-clear-button.btn:hover .svg-inline--fa{color:#000!important}.chars-remaining{color:#757575;font-size:.9rem}.char-count-exceeded{color:#c21f39}:host ::ng-deep .sameLine-list{display:inline;list-style:none;padding:0}:host ::ng-deep .sameLine-list li{display:inline;padding:3px}\n"], components: [{ type: i1.FoehnValidationAlertsComponent, selector: "foehn-validation-alerts", inputs: ["component", "shouldErrorsBeLive"] }, { type: i2.FoehnIconTimesComponent, selector: "foehn-icon-times" }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i4.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { type: i4.PatternValidator, selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: ["pattern"] }, { type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], pipes: { "fromDictionary": i5.SdkDictionaryPipe, "async": i3.AsyncPipe } });
40
40
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: FoehnInputEmailComponent, decorators: [{
41
41
  type: Component,
42
42
  args: [{
@@ -52,4 +52,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImpor
52
52
  ]
53
53
  }]
54
54
  }], ctorParameters: function () { return [{ type: i0.NgZone }]; } });
55
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9laG4taW5wdXQtZW1haWwuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJlc3RhdGlvbnMtbmcvc3JjL2ZvZWhuLWlucHV0L2ZvZWhuLWlucHV0LWVtYWlsLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uL3Byb2plY3RzL3ByZXN0YXRpb25zLW5nL3NyYy9mb2Vobi1pbnB1dC9mb2Vobi1pbnB1dC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBa0IsTUFBTSxlQUFlLENBQUM7QUFDdEUsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDM0UsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDOUQsT0FBTyxFQUFFLEtBQUssRUFBRSxNQUFNLGdCQUFnQixDQUFDOzs7Ozs7O0FBY3ZDLE1BQU0sT0FBTyx3QkFDVCxTQUFRLHlCQUF5QjtJQUVqQyxZQUFvQixNQUFjO1FBQzlCLEtBQUssRUFBRSxDQUFDO1FBRFEsV0FBTSxHQUFOLE1BQU0sQ0FBUTtJQUVsQyxDQUFDO0lBRUQsUUFBUTtRQUNKLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUNqQixJQUFJLENBQUMsSUFBSSxHQUFHLE9BQU8sQ0FBQztRQUNwQixJQUFJLENBQUMsWUFBWSxHQUFHLE9BQU8sQ0FBQztJQUNoQyxDQUFDO0lBRUQsYUFBYSxDQUFDLEtBQWE7UUFDdkIsSUFBSSxLQUFLLEtBQUssU0FBUyxJQUFJLENBQUMsQ0FBQyxLQUFLLEVBQUU7WUFDaEMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsQ0FBQztTQUM3QjthQUFNO1lBQ0gsSUFBSSxDQUFDLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO2dCQUN0RCxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxDQUFDO1lBQzdCLENBQUMsQ0FBQyxDQUFDO1NBQ047SUFDTCxDQUFDOztxSEFyQlEsd0JBQXdCO3lHQUF4Qix3QkFBd0IsNENBUnRCO1FBQ1A7WUFDSSxPQUFPLEVBQUUsbUJBQW1CO1lBQzVCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsd0JBQXdCLENBQUM7WUFDdkQsS0FBSyxFQUFFLElBQUk7U0FDZDtLQUNKLGlEQ2ZMLDIzRUF1RUE7MkZEdERhLHdCQUF3QjtrQkFacEMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsbUJBQW1CO29CQUM3QixXQUFXLEVBQUUsOEJBQThCO29CQUMzQyxTQUFTLEVBQUUsQ0FBQyw2QkFBNkIsQ0FBQztvQkFDMUMsU0FBUyxFQUFFO3dCQUNQOzRCQUNJLE9BQU8sRUFBRSxtQkFBbUI7NEJBQzVCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLHlCQUF5QixDQUFDOzRCQUN2RCxLQUFLLEVBQUUsSUFBSTt5QkFDZDtxQkFDSjtpQkFDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgZm9yd2FyZFJlZiwgTmdab25lLCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvZWhuSW5wdXRTdHJpbmdDb21wb25lbnQgfSBmcm9tICcuL2ZvZWhuLWlucHV0LXN0cmluZy5jb21wb25lbnQnO1xuaW1wb3J0IHsgRm9laG5JbnB1dENvbXBvbmVudCB9IGZyb20gJy4vZm9laG4taW5wdXQuY29tcG9uZW50JztcbmltcG9ydCB7IGZpcnN0IH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2ZvZWhuLWlucHV0LWVtYWlsJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vZm9laG4taW5wdXQuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL2ZvZWhuLWlucHV0LmNvbXBvbmVudC5jc3MnXSxcbiAgICBwcm92aWRlcnM6IFtcbiAgICAgICAge1xuICAgICAgICAgICAgcHJvdmlkZTogRm9laG5JbnB1dENvbXBvbmVudCxcbiAgICAgICAgICAgIHVzZUV4aXN0aW5nOiBmb3J3YXJkUmVmKCgpID0+IEZvZWhuSW5wdXRFbWFpbENvbXBvbmVudCksXG4gICAgICAgICAgICBtdWx0aTogdHJ1ZVxuICAgICAgICB9XG4gICAgXVxufSlcbmV4cG9ydCBjbGFzcyBGb2VobklucHV0RW1haWxDb21wb25lbnRcbiAgICBleHRlbmRzIEZvZWhuSW5wdXRTdHJpbmdDb21wb25lbnRcbiAgICBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBuZ1pvbmU6IE5nWm9uZSkge1xuICAgICAgICBzdXBlcigpO1xuICAgIH1cblxuICAgIG5nT25Jbml0KCk6IHZvaWQge1xuICAgICAgICBzdXBlci5uZ09uSW5pdCgpO1xuICAgICAgICB0aGlzLnR5cGUgPSAnZW1haWwnO1xuICAgICAgICB0aGlzLmF1dG9jb21wbGV0ZSA9ICdlbWFpbCc7XG4gICAgfVxuXG4gICAgb25Nb2RlbENoYW5nZSh2YWx1ZTogc3RyaW5nKTogdm9pZCB7XG4gICAgICAgIGlmICh2YWx1ZSA9PT0gdW5kZWZpbmVkIHx8ICEhdmFsdWUpIHtcbiAgICAgICAgICAgIHRoaXMudXBkYXRlTmdNb2RlbCh2YWx1ZSk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB0aGlzLm5nWm9uZS5vbk1pY3JvdGFza0VtcHR5LnBpcGUoZmlyc3QoKSkuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgICAgICAgICAgICB0aGlzLnVwZGF0ZU5nTW9kZWwobnVsbCk7XG4gICAgICAgICAgICB9KTtcbiAgICAgICAgfVxuICAgIH1cbn1cbiIsIjxkaXZcbiAgICBjbGFzcz1cImZvcm0tZ3JvdXAgY2xlYXJhYmxlLWlucHV0LWZvcm0tZ3JvdXBcIlxuICAgIFtjbGFzcy5oYXMtZGFuZ2VyXT1cImhhc0Vycm9yc1RvRGlzcGxheSgpXCJcbiAgICBbY2xhc3MudmQtZm9ybS1ncm91cC1kYW5nZXJdPVwiaGFzRXJyb3JzVG9EaXNwbGF5KClcIlxuICAgIFthdHRyLmlkXT1cImJ1aWxkSWQoJ0NvbnRhaW5lcicpXCJcbiAgICB0YWJpbmRleD1cIi0xXCJcbj5cbiAgICA8bGFiZWxcbiAgICAgICAgW2F0dHIuZm9yXT1cImJ1aWxkQ2hpbGRJZCgpXCJcbiAgICAgICAgKm5nSWY9XCJsYWJlbCAmJiB0eXBlICE9PSAnaGlkZGVuJ1wiXG4gICAgICAgIFtuZ0NsYXNzXT1cImlzTGFiZWxTck9ubHkgPyAnc3Itb25seScgOiBsYWJlbFN0eWxlTW9kaWZpZXJcIlxuICAgID5cbiAgICAgICAgPHNwYW4gW2lubmVySFRNTF09XCJsYWJlbFwiPjwvc3Bhbj5cbiAgICAgICAgPHNwYW5cbiAgICAgICAgICAgICpuZ0lmPVwiIXJlcXVpcmVkICYmICFoaWRlTm90UmVxdWlyZWRFeHRyYUxhYmVsXCJcbiAgICAgICAgICAgIGFyaWEtaGlkZGVuPVwidHJ1ZVwiXG4gICAgICAgID5cbiAgICAgICAgICAgIHt7ICdmb2Vobi1pbnB1dC5vcHRpb25hbCcgfCBmcm9tRGljdGlvbmFyeSB9fVxuICAgICAgICA8L3NwYW4+XG4gICAgPC9sYWJlbD5cblxuICAgIDxmb2Vobi12YWxpZGF0aW9uLWFsZXJ0cyBbY29tcG9uZW50XT1cInRoaXNcIj48L2ZvZWhuLXZhbGlkYXRpb24tYWxlcnRzPlxuXG4gICAgPHNtYWxsXG4gICAgICAgICpuZ0lmPVwiaGVscFRleHQgJiYgdHlwZSAhPT0gJ2hpZGRlbidcIlxuICAgICAgICBbYXR0ci5pZF09XCJidWlsZENoaWxkSWQoKSArICdIZWxwJ1wiXG4gICAgICAgIGNsYXNzPVwiZm9ybS10ZXh0IHRleHQtc2Vjb25kYXJ5XCJcbiAgICAgICAgW2lubmVySFRNTF09XCJoZWxwVGV4dFwiXG4gICAgPjwvc21hbGw+XG5cbiAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG5cbiAgICA8aW5wdXRcbiAgICAgICAgW2NsYXNzLmlzLWludmFsaWRdPVwiaGFzRXJyb3JzVG9EaXNwbGF5KCkgfHwgaGFzSW5oZXJpdEVycm9yRnJvbVBhcmVudCgpXCJcbiAgICAgICAgW2NsYXNzLmNsZWFyYWJsZS1pbnB1dF09XCJkaXNwbGF5Q2xlYXJCdXR0b24oKSB8IGFzeW5jXCJcbiAgICAgICAgY2xhc3M9XCJmb3JtLWNvbnRyb2xcIlxuICAgICAgICBbbmFtZV09XCJuYW1lIHx8IGxhYmVsXCJcbiAgICAgICAgW2F0dHIubWF4bGVuZ3RoXT1cImdldE1heExlbmd0aCgpXCJcbiAgICAgICAgW2F0dHIuYXV0b2NvbXBsZXRlXT1cImdldEF1dG9Db21wbGV0ZSgpXCJcbiAgICAgICAgW2F0dHIuZGlzYWJsZWRdPVwiZGlzYWJsZWQgPyAnZGlzYWJsZWQnIDogbnVsbFwiXG4gICAgICAgIFthdHRyLnR5cGVdPVwidHlwZVwiXG4gICAgICAgIFthdHRyLnBhdHRlcm5dPVwicGF0dGVyblwiXG4gICAgICAgIFthdHRyLm1pbl09XCJtaW5cIlxuICAgICAgICBbYXR0ci5tYXhdPVwibWF4XCJcbiAgICAgICAgW2F0dHIuaWRdPVwiYnVpbGRDaGlsZElkKClcIlxuICAgICAgICBbYXR0ci5hcmlhLWRlc2NyaWJlZGJ5XT1cImdldERlc2NyaWJlZEJ5KClcIlxuICAgICAgICBbYXR0ci5hcmlhLWludmFsaWRdPVwiaGFzRXJyb3JzVG9EaXNwbGF5KCkgfHwgbnVsbFwiXG4gICAgICAgIFthdHRyLmFyaWEtcmVxdWlyZWRdPVwicmVxdWlyZWQgfHwgbnVsbFwiXG4gICAgICAgIFtuZ01vZGVsXT1cIm1vZGVsXCJcbiAgICAgICAgKHBhc3RlKT1cIm9uUGFzdGUoJGV2ZW50KVwiXG4gICAgICAgIChuZ01vZGVsQ2hhbmdlKT1cInVwZGF0ZU5nTW9kZWwoJGV2ZW50KVwiXG4gICAgICAgIChpbnB1dCk9XCJoYW5kbGVDaGFuZ2UoZW50cnlDb21wb25lbnQudmFsdWUpXCJcbiAgICAgICAgKGtleWRvd24pPVwib25LZXlkb3duKCRldmVudClcIlxuICAgICAgICAoYmx1cik9XCJvbkJsdXIoJGV2ZW50KVwiXG4gICAgICAgIChmb2N1cyk9XCJvbkZvY3VzKCRldmVudClcIlxuICAgICAgICAjZW50cnlDb21wb25lbnRcbiAgICAvPlxuXG4gICAgPGJ1dHRvblxuICAgICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgICAgW2lkXT1cImJ1aWxkQ2hpbGRJZCgpICsgJ0NsZWFyQnV0dG9uJ1wiXG4gICAgICAgICpuZ0lmPVwiZGlzcGxheUNsZWFyQnV0dG9uKCkgfCBhc3luY1wiXG4gICAgICAgIGNsYXNzPVwiY2xlYXJhYmxlLWlucHV0LWNsZWFyLWJ1dHRvbiBidG5cIlxuICAgICAgICAoY2xpY2spPVwib25DbGVhcigpXCJcbiAgICA+XG4gICAgICAgIDxmb2Vobi1pY29uLXRpbWVzXG4gICAgICAgICAgICBjbGFzcz1cImNsZWFyYWJsZS1pbnB1dC1jbGVhci1idXR0b24taWNvblwiXG4gICAgICAgICAgICB0aXRsZT1cIlLDqWluaXRpYWxpc2VyIGxlIGNoYW1wc1wiXG4gICAgICAgID48L2ZvZWhuLWljb24tdGltZXM+XG4gICAgPC9idXR0b24+XG48L2Rpdj5cbiJdfQ==
55
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9laG4taW5wdXQtZW1haWwuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJlc3RhdGlvbnMtbmcvc3JjL2ZvZWhuLWlucHV0L2ZvZWhuLWlucHV0LWVtYWlsLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uL3Byb2plY3RzL3ByZXN0YXRpb25zLW5nL3NyYy9mb2Vobi1pbnB1dC9mb2Vobi1pbnB1dC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBa0IsTUFBTSxlQUFlLENBQUM7QUFDdEUsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDM0UsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDOUQsT0FBTyxFQUFFLEtBQUssRUFBRSxNQUFNLGdCQUFnQixDQUFDOzs7Ozs7O0FBY3ZDLE1BQU0sT0FBTyx3QkFDVCxTQUFRLHlCQUF5QjtJQUVqQyxZQUFvQixNQUFjO1FBQzlCLEtBQUssRUFBRSxDQUFDO1FBRFEsV0FBTSxHQUFOLE1BQU0sQ0FBUTtJQUVsQyxDQUFDO0lBRUQsUUFBUTtRQUNKLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUNqQixJQUFJLENBQUMsSUFBSSxHQUFHLE9BQU8sQ0FBQztRQUNwQixJQUFJLENBQUMsWUFBWSxHQUFHLE9BQU8sQ0FBQztJQUNoQyxDQUFDO0lBRUQsYUFBYSxDQUFDLEtBQWE7UUFDdkIsSUFBSSxLQUFLLEtBQUssU0FBUyxJQUFJLENBQUMsQ0FBQyxLQUFLLEVBQUU7WUFDaEMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsQ0FBQztTQUM3QjthQUFNO1lBQ0gsSUFBSSxDQUFDLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO2dCQUN0RCxJQUFJLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxDQUFDO1lBQzdCLENBQUMsQ0FBQyxDQUFDO1NBQ047SUFDTCxDQUFDOztxSEFyQlEsd0JBQXdCO3lHQUF4Qix3QkFBd0IsNENBUnRCO1FBQ1A7WUFDSSxPQUFPLEVBQUUsbUJBQW1CO1lBQzVCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsd0JBQXdCLENBQUM7WUFDdkQsS0FBSyxFQUFFLElBQUk7U0FDZDtLQUNKLGlEQ2ZMLDI2RUF3RUE7MkZEdkRhLHdCQUF3QjtrQkFacEMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsbUJBQW1CO29CQUM3QixXQUFXLEVBQUUsOEJBQThCO29CQUMzQyxTQUFTLEVBQUUsQ0FBQyw2QkFBNkIsQ0FBQztvQkFDMUMsU0FBUyxFQUFFO3dCQUNQOzRCQUNJLE9BQU8sRUFBRSxtQkFBbUI7NEJBQzVCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLHlCQUF5QixDQUFDOzRCQUN2RCxLQUFLLEVBQUUsSUFBSTt5QkFDZDtxQkFDSjtpQkFDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgZm9yd2FyZFJlZiwgTmdab25lLCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvZWhuSW5wdXRTdHJpbmdDb21wb25lbnQgfSBmcm9tICcuL2ZvZWhuLWlucHV0LXN0cmluZy5jb21wb25lbnQnO1xuaW1wb3J0IHsgRm9laG5JbnB1dENvbXBvbmVudCB9IGZyb20gJy4vZm9laG4taW5wdXQuY29tcG9uZW50JztcbmltcG9ydCB7IGZpcnN0IH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2ZvZWhuLWlucHV0LWVtYWlsJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vZm9laG4taW5wdXQuY29tcG9uZW50Lmh0bWwnLFxuICAgIHN0eWxlVXJsczogWycuL2ZvZWhuLWlucHV0LmNvbXBvbmVudC5jc3MnXSxcbiAgICBwcm92aWRlcnM6IFtcbiAgICAgICAge1xuICAgICAgICAgICAgcHJvdmlkZTogRm9laG5JbnB1dENvbXBvbmVudCxcbiAgICAgICAgICAgIHVzZUV4aXN0aW5nOiBmb3J3YXJkUmVmKCgpID0+IEZvZWhuSW5wdXRFbWFpbENvbXBvbmVudCksXG4gICAgICAgICAgICBtdWx0aTogdHJ1ZVxuICAgICAgICB9XG4gICAgXVxufSlcbmV4cG9ydCBjbGFzcyBGb2VobklucHV0RW1haWxDb21wb25lbnRcbiAgICBleHRlbmRzIEZvZWhuSW5wdXRTdHJpbmdDb21wb25lbnRcbiAgICBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBuZ1pvbmU6IE5nWm9uZSkge1xuICAgICAgICBzdXBlcigpO1xuICAgIH1cblxuICAgIG5nT25Jbml0KCk6IHZvaWQge1xuICAgICAgICBzdXBlci5uZ09uSW5pdCgpO1xuICAgICAgICB0aGlzLnR5cGUgPSAnZW1haWwnO1xuICAgICAgICB0aGlzLmF1dG9jb21wbGV0ZSA9ICdlbWFpbCc7XG4gICAgfVxuXG4gICAgb25Nb2RlbENoYW5nZSh2YWx1ZTogc3RyaW5nKTogdm9pZCB7XG4gICAgICAgIGlmICh2YWx1ZSA9PT0gdW5kZWZpbmVkIHx8ICEhdmFsdWUpIHtcbiAgICAgICAgICAgIHRoaXMudXBkYXRlTmdNb2RlbCh2YWx1ZSk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB0aGlzLm5nWm9uZS5vbk1pY3JvdGFza0VtcHR5LnBpcGUoZmlyc3QoKSkuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgICAgICAgICAgICB0aGlzLnVwZGF0ZU5nTW9kZWwobnVsbCk7XG4gICAgICAgICAgICB9KTtcbiAgICAgICAgfVxuICAgIH1cbn1cbiIsIjxkaXZcbiAgICBjbGFzcz1cImZvcm0tZ3JvdXAgY2xlYXJhYmxlLWlucHV0LWZvcm0tZ3JvdXBcIlxuICAgIFtjbGFzcy5oYXMtZGFuZ2VyXT1cImhhc0Vycm9yc1RvRGlzcGxheSgpXCJcbiAgICBbY2xhc3MudmQtZm9ybS1ncm91cC1kYW5nZXJdPVwiaGFzRXJyb3JzVG9EaXNwbGF5KClcIlxuICAgIFthdHRyLmlkXT1cImJ1aWxkSWQoJ0NvbnRhaW5lcicpXCJcbiAgICB0YWJpbmRleD1cIi0xXCJcbj5cbiAgICA8bGFiZWxcbiAgICAgICAgW2F0dHIuaWRdPVwiYnVpbGRDaGlsZElkKCkgKyAnTGFiZWwnXCJcbiAgICAgICAgW2F0dHIuZm9yXT1cImJ1aWxkQ2hpbGRJZCgpXCJcbiAgICAgICAgKm5nSWY9XCJsYWJlbCAmJiB0eXBlICE9PSAnaGlkZGVuJ1wiXG4gICAgICAgIFtuZ0NsYXNzXT1cImlzTGFiZWxTck9ubHkgPyAnc3Itb25seScgOiBsYWJlbFN0eWxlTW9kaWZpZXJcIlxuICAgID5cbiAgICAgICAgPHNwYW4gW2lubmVySFRNTF09XCJsYWJlbFwiPjwvc3Bhbj5cbiAgICAgICAgPHNwYW5cbiAgICAgICAgICAgICpuZ0lmPVwiIXJlcXVpcmVkICYmICFoaWRlTm90UmVxdWlyZWRFeHRyYUxhYmVsXCJcbiAgICAgICAgICAgIGFyaWEtaGlkZGVuPVwidHJ1ZVwiXG4gICAgICAgID5cbiAgICAgICAgICAgIHt7ICdmb2Vobi1pbnB1dC5vcHRpb25hbCcgfCBmcm9tRGljdGlvbmFyeSB9fVxuICAgICAgICA8L3NwYW4+XG4gICAgPC9sYWJlbD5cblxuICAgIDxmb2Vobi12YWxpZGF0aW9uLWFsZXJ0cyBbY29tcG9uZW50XT1cInRoaXNcIj48L2ZvZWhuLXZhbGlkYXRpb24tYWxlcnRzPlxuXG4gICAgPHNtYWxsXG4gICAgICAgICpuZ0lmPVwiaGVscFRleHQgJiYgdHlwZSAhPT0gJ2hpZGRlbidcIlxuICAgICAgICBbYXR0ci5pZF09XCJidWlsZENoaWxkSWQoKSArICdIZWxwJ1wiXG4gICAgICAgIGNsYXNzPVwiZm9ybS10ZXh0IHRleHQtc2Vjb25kYXJ5XCJcbiAgICAgICAgW2lubmVySFRNTF09XCJoZWxwVGV4dFwiXG4gICAgPjwvc21hbGw+XG5cbiAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG5cbiAgICA8aW5wdXRcbiAgICAgICAgW2NsYXNzLmlzLWludmFsaWRdPVwiaGFzRXJyb3JzVG9EaXNwbGF5KCkgfHwgaGFzSW5oZXJpdEVycm9yRnJvbVBhcmVudCgpXCJcbiAgICAgICAgW2NsYXNzLmNsZWFyYWJsZS1pbnB1dF09XCJkaXNwbGF5Q2xlYXJCdXR0b24oKSB8IGFzeW5jXCJcbiAgICAgICAgY2xhc3M9XCJmb3JtLWNvbnRyb2xcIlxuICAgICAgICBbbmFtZV09XCJuYW1lIHx8IGxhYmVsXCJcbiAgICAgICAgW2F0dHIubWF4bGVuZ3RoXT1cImdldE1heExlbmd0aCgpXCJcbiAgICAgICAgW2F0dHIuYXV0b2NvbXBsZXRlXT1cImdldEF1dG9Db21wbGV0ZSgpXCJcbiAgICAgICAgW2F0dHIuZGlzYWJsZWRdPVwiZGlzYWJsZWQgPyAnZGlzYWJsZWQnIDogbnVsbFwiXG4gICAgICAgIFthdHRyLnR5cGVdPVwidHlwZVwiXG4gICAgICAgIFthdHRyLnBhdHRlcm5dPVwicGF0dGVyblwiXG4gICAgICAgIFthdHRyLm1pbl09XCJtaW5cIlxuICAgICAgICBbYXR0ci5tYXhdPVwibWF4XCJcbiAgICAgICAgW2F0dHIuaWRdPVwiYnVpbGRDaGlsZElkKClcIlxuICAgICAgICBbYXR0ci5hcmlhLWRlc2NyaWJlZGJ5XT1cImdldERlc2NyaWJlZEJ5KClcIlxuICAgICAgICBbYXR0ci5hcmlhLWludmFsaWRdPVwiaGFzRXJyb3JzVG9EaXNwbGF5KCkgfHwgbnVsbFwiXG4gICAgICAgIFthdHRyLmFyaWEtcmVxdWlyZWRdPVwicmVxdWlyZWQgfHwgbnVsbFwiXG4gICAgICAgIFtuZ01vZGVsXT1cIm1vZGVsXCJcbiAgICAgICAgKHBhc3RlKT1cIm9uUGFzdGUoJGV2ZW50KVwiXG4gICAgICAgIChuZ01vZGVsQ2hhbmdlKT1cInVwZGF0ZU5nTW9kZWwoJGV2ZW50KVwiXG4gICAgICAgIChpbnB1dCk9XCJoYW5kbGVDaGFuZ2UoZW50cnlDb21wb25lbnQudmFsdWUpXCJcbiAgICAgICAgKGtleWRvd24pPVwib25LZXlkb3duKCRldmVudClcIlxuICAgICAgICAoYmx1cik9XCJvbkJsdXIoJGV2ZW50KVwiXG4gICAgICAgIChmb2N1cyk9XCJvbkZvY3VzKCRldmVudClcIlxuICAgICAgICAjZW50cnlDb21wb25lbnRcbiAgICAvPlxuXG4gICAgPGJ1dHRvblxuICAgICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgICAgW2lkXT1cImJ1aWxkQ2hpbGRJZCgpICsgJ0NsZWFyQnV0dG9uJ1wiXG4gICAgICAgICpuZ0lmPVwiZGlzcGxheUNsZWFyQnV0dG9uKCkgfCBhc3luY1wiXG4gICAgICAgIGNsYXNzPVwiY2xlYXJhYmxlLWlucHV0LWNsZWFyLWJ1dHRvbiBidG5cIlxuICAgICAgICAoY2xpY2spPVwib25DbGVhcigpXCJcbiAgICA+XG4gICAgICAgIDxmb2Vobi1pY29uLXRpbWVzXG4gICAgICAgICAgICBjbGFzcz1cImNsZWFyYWJsZS1pbnB1dC1jbGVhci1idXR0b24taWNvblwiXG4gICAgICAgICAgICB0aXRsZT1cIlLDqWluaXRpYWxpc2VyIGxlIGNoYW1wc1wiXG4gICAgICAgID48L2ZvZWhuLWljb24tdGltZXM+XG4gICAgPC9idXR0b24+XG48L2Rpdj5cbiJdfQ==
@@ -39,7 +39,7 @@ FoehnInputHiddenComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.
39
39
  useExisting: forwardRef(() => FoehnInputHiddenComponent),
40
40
  multi: true
41
41
  }
42
- ], usesInheritance: true, ngImport: i0, template: "<div\n class=\"form-group clearable-input-form-group\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n [attr.id]=\"buildId('Container')\"\n tabindex=\"-1\"\n>\n <label\n [attr.for]=\"buildChildId()\"\n *ngIf=\"label && type !== 'hidden'\"\n [ngClass]=\"isLabelSrOnly ? 'sr-only' : labelStyleModifier\"\n >\n <span [innerHTML]=\"label\"></span>\n <span\n *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n aria-hidden=\"true\"\n >\n {{ 'foehn-input.optional' | fromDictionary }}\n </span>\n </label>\n\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n <small\n *ngIf=\"helpText && type !== 'hidden'\"\n [attr.id]=\"buildChildId() + 'Help'\"\n class=\"form-text text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-content></ng-content>\n\n <input\n [class.is-invalid]=\"hasErrorsToDisplay() || hasInheritErrorFromParent()\"\n [class.clearable-input]=\"displayClearButton() | async\"\n class=\"form-control\"\n [name]=\"name || label\"\n [attr.maxlength]=\"getMaxLength()\"\n [attr.autocomplete]=\"getAutoComplete()\"\n [attr.disabled]=\"disabled ? 'disabled' : null\"\n [attr.type]=\"type\"\n [attr.pattern]=\"pattern\"\n [attr.min]=\"min\"\n [attr.max]=\"max\"\n [attr.id]=\"buildChildId()\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n [attr.aria-required]=\"required || null\"\n [ngModel]=\"model\"\n (paste)=\"onPaste($event)\"\n (ngModelChange)=\"updateNgModel($event)\"\n (input)=\"handleChange(entryComponent.value)\"\n (keydown)=\"onKeydown($event)\"\n (blur)=\"onBlur($event)\"\n (focus)=\"onFocus($event)\"\n #entryComponent\n />\n\n <button\n type=\"button\"\n [id]=\"buildChildId() + 'ClearButton'\"\n *ngIf=\"displayClearButton() | async\"\n class=\"clearable-input-clear-button btn\"\n (click)=\"onClear()\"\n >\n <foehn-icon-times\n class=\"clearable-input-clear-button-icon\"\n title=\"R\u00E9initialiser le champs\"\n ></foehn-icon-times>\n </button>\n</div>\n", components: [{ type: i1.FoehnValidationAlertsComponent, selector: "foehn-validation-alerts", inputs: ["component", "shouldErrorsBeLive"] }, { type: i2.FoehnIconTimesComponent, selector: "foehn-icon-times" }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i4.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { type: i4.PatternValidator, selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: ["pattern"] }, { type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], pipes: { "fromDictionary": i5.SdkDictionaryPipe, "async": i3.AsyncPipe } });
42
+ ], usesInheritance: true, ngImport: i0, template: "<div\n class=\"form-group clearable-input-form-group\"\n [class.has-danger]=\"hasErrorsToDisplay()\"\n [class.vd-form-group-danger]=\"hasErrorsToDisplay()\"\n [attr.id]=\"buildId('Container')\"\n tabindex=\"-1\"\n>\n <label\n [attr.id]=\"buildChildId() + 'Label'\"\n [attr.for]=\"buildChildId()\"\n *ngIf=\"label && type !== 'hidden'\"\n [ngClass]=\"isLabelSrOnly ? 'sr-only' : labelStyleModifier\"\n >\n <span [innerHTML]=\"label\"></span>\n <span\n *ngIf=\"!required && !hideNotRequiredExtraLabel\"\n aria-hidden=\"true\"\n >\n {{ 'foehn-input.optional' | fromDictionary }}\n </span>\n </label>\n\n <foehn-validation-alerts [component]=\"this\"></foehn-validation-alerts>\n\n <small\n *ngIf=\"helpText && type !== 'hidden'\"\n [attr.id]=\"buildChildId() + 'Help'\"\n class=\"form-text text-secondary\"\n [innerHTML]=\"helpText\"\n ></small>\n\n <ng-content></ng-content>\n\n <input\n [class.is-invalid]=\"hasErrorsToDisplay() || hasInheritErrorFromParent()\"\n [class.clearable-input]=\"displayClearButton() | async\"\n class=\"form-control\"\n [name]=\"name || label\"\n [attr.maxlength]=\"getMaxLength()\"\n [attr.autocomplete]=\"getAutoComplete()\"\n [attr.disabled]=\"disabled ? 'disabled' : null\"\n [attr.type]=\"type\"\n [attr.pattern]=\"pattern\"\n [attr.min]=\"min\"\n [attr.max]=\"max\"\n [attr.id]=\"buildChildId()\"\n [attr.aria-describedby]=\"getDescribedBy()\"\n [attr.aria-invalid]=\"hasErrorsToDisplay() || null\"\n [attr.aria-required]=\"required || null\"\n [ngModel]=\"model\"\n (paste)=\"onPaste($event)\"\n (ngModelChange)=\"updateNgModel($event)\"\n (input)=\"handleChange(entryComponent.value)\"\n (keydown)=\"onKeydown($event)\"\n (blur)=\"onBlur($event)\"\n (focus)=\"onFocus($event)\"\n #entryComponent\n />\n\n <button\n type=\"button\"\n [id]=\"buildChildId() + 'ClearButton'\"\n *ngIf=\"displayClearButton() | async\"\n class=\"clearable-input-clear-button btn\"\n (click)=\"onClear()\"\n >\n <foehn-icon-times\n class=\"clearable-input-clear-button-icon\"\n title=\"R\u00E9initialiser le champs\"\n ></foehn-icon-times>\n </button>\n</div>\n", components: [{ type: i1.FoehnValidationAlertsComponent, selector: "foehn-validation-alerts", inputs: ["component", "shouldErrorsBeLive"] }, { type: i2.FoehnIconTimesComponent, selector: "foehn-icon-times" }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i4.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { type: i4.PatternValidator, selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: ["pattern"] }, { type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], pipes: { "fromDictionary": i5.SdkDictionaryPipe, "async": i3.AsyncPipe } });
43
43
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImport: i0, type: FoehnInputHiddenComponent, decorators: [{
44
44
  type: Component,
45
45
  args: [{
@@ -54,4 +54,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.4", ngImpor
54
54
  ]
55
55
  }]
56
56
  }], ctorParameters: function () { return [{ type: i0.NgZone }]; } });
57
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9laG4taW5wdXQtaGlkZGVuLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3ByZXN0YXRpb25zLW5nL3NyYy9mb2Vobi1pbnB1dC9mb2Vobi1pbnB1dC1oaWRkZW4uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJlc3RhdGlvbnMtbmcvc3JjL2ZvZWhuLWlucHV0L2ZvZWhuLWlucHV0LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFrQixNQUFNLGVBQWUsQ0FBQztBQUN0RSxPQUFPLEVBQWMsRUFBRSxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQ3RDLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQzNFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQzlELE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7Ozs7OztBQWF2QyxNQUFNLE9BQU8seUJBQ1QsU0FBUSx5QkFBeUI7SUFFakMsWUFBb0IsTUFBYztRQUM5QixLQUFLLEVBQUUsQ0FBQztRQURRLFdBQU0sR0FBTixNQUFNLENBQVE7SUFFbEMsQ0FBQztJQUVELFFBQVE7UUFDSixLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDakIsSUFBSSxDQUFDLElBQUksR0FBRyxRQUFRLENBQUM7SUFDekIsQ0FBQztJQUVELGFBQWEsQ0FBQyxLQUFhO1FBQ3ZCLElBQUksS0FBSyxLQUFLLFNBQVMsSUFBSSxDQUFDLENBQUMsS0FBSyxFQUFFO1lBQ2hDLElBQUksQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLENBQUM7U0FDN0I7YUFBTTtZQUNILElBQUksQ0FBQyxNQUFNLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRTtnQkFDdEQsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUM3QixDQUFDLENBQUMsQ0FBQztTQUNOO0lBQ0wsQ0FBQztJQUVELGtCQUFrQjtRQUNkLE9BQU8sRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3JCLENBQUM7O3NIQXhCUSx5QkFBeUI7MEdBQXpCLHlCQUF5Qiw2Q0FSdkI7UUFDUDtZQUNJLE9BQU8sRUFBRSxtQkFBbUI7WUFDNUIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyx5QkFBeUIsQ0FBQztZQUN4RCxLQUFLLEVBQUUsSUFBSTtTQUNkO0tBQ0osaURDZkwsMjNFQXVFQTsyRkR0RGEseUJBQXlCO2tCQVhyQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxvQkFBb0I7b0JBQzlCLFdBQVcsRUFBRSw4QkFBOEI7b0JBQzNDLFNBQVMsRUFBRTt3QkFDUDs0QkFDSSxPQUFPLEVBQUUsbUJBQW1COzRCQUM1QixXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSwwQkFBMEIsQ0FBQzs0QkFDeEQsS0FBSyxFQUFFLElBQUk7eUJBQ2Q7cUJBQ0o7aUJBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIGZvcndhcmRSZWYsIE5nWm9uZSwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBPYnNlcnZhYmxlLCBvZiB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgRm9laG5JbnB1dFN0cmluZ0NvbXBvbmVudCB9IGZyb20gJy4vZm9laG4taW5wdXQtc3RyaW5nLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBGb2VobklucHV0Q29tcG9uZW50IH0gZnJvbSAnLi9mb2Vobi1pbnB1dC5jb21wb25lbnQnO1xuaW1wb3J0IHsgZmlyc3QgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnZm9laG4taW5wdXQtaGlkZGVuJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vZm9laG4taW5wdXQuY29tcG9uZW50Lmh0bWwnLFxuICAgIHByb3ZpZGVyczogW1xuICAgICAgICB7XG4gICAgICAgICAgICBwcm92aWRlOiBGb2VobklucHV0Q29tcG9uZW50LFxuICAgICAgICAgICAgdXNlRXhpc3Rpbmc6IGZvcndhcmRSZWYoKCkgPT4gRm9laG5JbnB1dEhpZGRlbkNvbXBvbmVudCksXG4gICAgICAgICAgICBtdWx0aTogdHJ1ZVxuICAgICAgICB9XG4gICAgXVxufSlcbmV4cG9ydCBjbGFzcyBGb2VobklucHV0SGlkZGVuQ29tcG9uZW50XG4gICAgZXh0ZW5kcyBGb2VobklucHV0U3RyaW5nQ29tcG9uZW50XG4gICAgaW1wbGVtZW50cyBPbkluaXQge1xuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgbmdab25lOiBOZ1pvbmUpIHtcbiAgICAgICAgc3VwZXIoKTtcbiAgICB9XG5cbiAgICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICAgICAgc3VwZXIubmdPbkluaXQoKTtcbiAgICAgICAgdGhpcy50eXBlID0gJ2hpZGRlbic7XG4gICAgfVxuXG4gICAgb25Nb2RlbENoYW5nZSh2YWx1ZTogc3RyaW5nKTogdm9pZCB7XG4gICAgICAgIGlmICh2YWx1ZSA9PT0gdW5kZWZpbmVkIHx8ICEhdmFsdWUpIHtcbiAgICAgICAgICAgIHRoaXMudXBkYXRlTmdNb2RlbCh2YWx1ZSk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB0aGlzLm5nWm9uZS5vbk1pY3JvdGFza0VtcHR5LnBpcGUoZmlyc3QoKSkuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgICAgICAgICAgICB0aGlzLnVwZGF0ZU5nTW9kZWwobnVsbCk7XG4gICAgICAgICAgICB9KTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIGRpc3BsYXlDbGVhckJ1dHRvbigpOiBPYnNlcnZhYmxlPGJvb2xlYW4+IHtcbiAgICAgICAgcmV0dXJuIG9mKGZhbHNlKTtcbiAgICB9XG59XG4iLCI8ZGl2XG4gICAgY2xhc3M9XCJmb3JtLWdyb3VwIGNsZWFyYWJsZS1pbnB1dC1mb3JtLWdyb3VwXCJcbiAgICBbY2xhc3MuaGFzLWRhbmdlcl09XCJoYXNFcnJvcnNUb0Rpc3BsYXkoKVwiXG4gICAgW2NsYXNzLnZkLWZvcm0tZ3JvdXAtZGFuZ2VyXT1cImhhc0Vycm9yc1RvRGlzcGxheSgpXCJcbiAgICBbYXR0ci5pZF09XCJidWlsZElkKCdDb250YWluZXInKVwiXG4gICAgdGFiaW5kZXg9XCItMVwiXG4+XG4gICAgPGxhYmVsXG4gICAgICAgIFthdHRyLmZvcl09XCJidWlsZENoaWxkSWQoKVwiXG4gICAgICAgICpuZ0lmPVwibGFiZWwgJiYgdHlwZSAhPT0gJ2hpZGRlbidcIlxuICAgICAgICBbbmdDbGFzc109XCJpc0xhYmVsU3JPbmx5ID8gJ3NyLW9ubHknIDogbGFiZWxTdHlsZU1vZGlmaWVyXCJcbiAgICA+XG4gICAgICAgIDxzcGFuIFtpbm5lckhUTUxdPVwibGFiZWxcIj48L3NwYW4+XG4gICAgICAgIDxzcGFuXG4gICAgICAgICAgICAqbmdJZj1cIiFyZXF1aXJlZCAmJiAhaGlkZU5vdFJlcXVpcmVkRXh0cmFMYWJlbFwiXG4gICAgICAgICAgICBhcmlhLWhpZGRlbj1cInRydWVcIlxuICAgICAgICA+XG4gICAgICAgICAgICB7eyAnZm9laG4taW5wdXQub3B0aW9uYWwnIHwgZnJvbURpY3Rpb25hcnkgfX1cbiAgICAgICAgPC9zcGFuPlxuICAgIDwvbGFiZWw+XG5cbiAgICA8Zm9laG4tdmFsaWRhdGlvbi1hbGVydHMgW2NvbXBvbmVudF09XCJ0aGlzXCI+PC9mb2Vobi12YWxpZGF0aW9uLWFsZXJ0cz5cblxuICAgIDxzbWFsbFxuICAgICAgICAqbmdJZj1cImhlbHBUZXh0ICYmIHR5cGUgIT09ICdoaWRkZW4nXCJcbiAgICAgICAgW2F0dHIuaWRdPVwiYnVpbGRDaGlsZElkKCkgKyAnSGVscCdcIlxuICAgICAgICBjbGFzcz1cImZvcm0tdGV4dCB0ZXh0LXNlY29uZGFyeVwiXG4gICAgICAgIFtpbm5lckhUTUxdPVwiaGVscFRleHRcIlxuICAgID48L3NtYWxsPlxuXG4gICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuXG4gICAgPGlucHV0XG4gICAgICAgIFtjbGFzcy5pcy1pbnZhbGlkXT1cImhhc0Vycm9yc1RvRGlzcGxheSgpIHx8IGhhc0luaGVyaXRFcnJvckZyb21QYXJlbnQoKVwiXG4gICAgICAgIFtjbGFzcy5jbGVhcmFibGUtaW5wdXRdPVwiZGlzcGxheUNsZWFyQnV0dG9uKCkgfCBhc3luY1wiXG4gICAgICAgIGNsYXNzPVwiZm9ybS1jb250cm9sXCJcbiAgICAgICAgW25hbWVdPVwibmFtZSB8fCBsYWJlbFwiXG4gICAgICAgIFthdHRyLm1heGxlbmd0aF09XCJnZXRNYXhMZW5ndGgoKVwiXG4gICAgICAgIFthdHRyLmF1dG9jb21wbGV0ZV09XCJnZXRBdXRvQ29tcGxldGUoKVwiXG4gICAgICAgIFthdHRyLmRpc2FibGVkXT1cImRpc2FibGVkID8gJ2Rpc2FibGVkJyA6IG51bGxcIlxuICAgICAgICBbYXR0ci50eXBlXT1cInR5cGVcIlxuICAgICAgICBbYXR0ci5wYXR0ZXJuXT1cInBhdHRlcm5cIlxuICAgICAgICBbYXR0ci5taW5dPVwibWluXCJcbiAgICAgICAgW2F0dHIubWF4XT1cIm1heFwiXG4gICAgICAgIFthdHRyLmlkXT1cImJ1aWxkQ2hpbGRJZCgpXCJcbiAgICAgICAgW2F0dHIuYXJpYS1kZXNjcmliZWRieV09XCJnZXREZXNjcmliZWRCeSgpXCJcbiAgICAgICAgW2F0dHIuYXJpYS1pbnZhbGlkXT1cImhhc0Vycm9yc1RvRGlzcGxheSgpIHx8IG51bGxcIlxuICAgICAgICBbYXR0ci5hcmlhLXJlcXVpcmVkXT1cInJlcXVpcmVkIHx8IG51bGxcIlxuICAgICAgICBbbmdNb2RlbF09XCJtb2RlbFwiXG4gICAgICAgIChwYXN0ZSk9XCJvblBhc3RlKCRldmVudClcIlxuICAgICAgICAobmdNb2RlbENoYW5nZSk9XCJ1cGRhdGVOZ01vZGVsKCRldmVudClcIlxuICAgICAgICAoaW5wdXQpPVwiaGFuZGxlQ2hhbmdlKGVudHJ5Q29tcG9uZW50LnZhbHVlKVwiXG4gICAgICAgIChrZXlkb3duKT1cIm9uS2V5ZG93bigkZXZlbnQpXCJcbiAgICAgICAgKGJsdXIpPVwib25CbHVyKCRldmVudClcIlxuICAgICAgICAoZm9jdXMpPVwib25Gb2N1cygkZXZlbnQpXCJcbiAgICAgICAgI2VudHJ5Q29tcG9uZW50XG4gICAgLz5cblxuICAgIDxidXR0b25cbiAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICAgIFtpZF09XCJidWlsZENoaWxkSWQoKSArICdDbGVhckJ1dHRvbidcIlxuICAgICAgICAqbmdJZj1cImRpc3BsYXlDbGVhckJ1dHRvbigpIHwgYXN5bmNcIlxuICAgICAgICBjbGFzcz1cImNsZWFyYWJsZS1pbnB1dC1jbGVhci1idXR0b24gYnRuXCJcbiAgICAgICAgKGNsaWNrKT1cIm9uQ2xlYXIoKVwiXG4gICAgPlxuICAgICAgICA8Zm9laG4taWNvbi10aW1lc1xuICAgICAgICAgICAgY2xhc3M9XCJjbGVhcmFibGUtaW5wdXQtY2xlYXItYnV0dG9uLWljb25cIlxuICAgICAgICAgICAgdGl0bGU9XCJSw6lpbml0aWFsaXNlciBsZSBjaGFtcHNcIlxuICAgICAgICA+PC9mb2Vobi1pY29uLXRpbWVzPlxuICAgIDwvYnV0dG9uPlxuPC9kaXY+XG4iXX0=
57
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9laG4taW5wdXQtaGlkZGVuLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3ByZXN0YXRpb25zLW5nL3NyYy9mb2Vobi1pbnB1dC9mb2Vobi1pbnB1dC1oaWRkZW4uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vcHJvamVjdHMvcHJlc3RhdGlvbnMtbmcvc3JjL2ZvZWhuLWlucHV0L2ZvZWhuLWlucHV0LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFrQixNQUFNLGVBQWUsQ0FBQztBQUN0RSxPQUFPLEVBQWMsRUFBRSxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQ3RDLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQzNFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQzlELE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7Ozs7OztBQWF2QyxNQUFNLE9BQU8seUJBQ1QsU0FBUSx5QkFBeUI7SUFFakMsWUFBb0IsTUFBYztRQUM5QixLQUFLLEVBQUUsQ0FBQztRQURRLFdBQU0sR0FBTixNQUFNLENBQVE7SUFFbEMsQ0FBQztJQUVELFFBQVE7UUFDSixLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7UUFDakIsSUFBSSxDQUFDLElBQUksR0FBRyxRQUFRLENBQUM7SUFDekIsQ0FBQztJQUVELGFBQWEsQ0FBQyxLQUFhO1FBQ3ZCLElBQUksS0FBSyxLQUFLLFNBQVMsSUFBSSxDQUFDLENBQUMsS0FBSyxFQUFFO1lBQ2hDLElBQUksQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLENBQUM7U0FDN0I7YUFBTTtZQUNILElBQUksQ0FBQyxNQUFNLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRTtnQkFDdEQsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUM3QixDQUFDLENBQUMsQ0FBQztTQUNOO0lBQ0wsQ0FBQztJQUVELGtCQUFrQjtRQUNkLE9BQU8sRUFBRSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3JCLENBQUM7O3NIQXhCUSx5QkFBeUI7MEdBQXpCLHlCQUF5Qiw2Q0FSdkI7UUFDUDtZQUNJLE9BQU8sRUFBRSxtQkFBbUI7WUFDNUIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyx5QkFBeUIsQ0FBQztZQUN4RCxLQUFLLEVBQUUsSUFBSTtTQUNkO0tBQ0osaURDZkwsMjZFQXdFQTsyRkR2RGEseUJBQXlCO2tCQVhyQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxvQkFBb0I7b0JBQzlCLFdBQVcsRUFBRSw4QkFBOEI7b0JBQzNDLFNBQVMsRUFBRTt3QkFDUDs0QkFDSSxPQUFPLEVBQUUsbUJBQW1COzRCQUM1QixXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSwwQkFBMEIsQ0FBQzs0QkFDeEQsS0FBSyxFQUFFLElBQUk7eUJBQ2Q7cUJBQ0o7aUJBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIGZvcndhcmRSZWYsIE5nWm9uZSwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBPYnNlcnZhYmxlLCBvZiB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgRm9laG5JbnB1dFN0cmluZ0NvbXBvbmVudCB9IGZyb20gJy4vZm9laG4taW5wdXQtc3RyaW5nLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBGb2VobklucHV0Q29tcG9uZW50IH0gZnJvbSAnLi9mb2Vobi1pbnB1dC5jb21wb25lbnQnO1xuaW1wb3J0IHsgZmlyc3QgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnZm9laG4taW5wdXQtaGlkZGVuJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vZm9laG4taW5wdXQuY29tcG9uZW50Lmh0bWwnLFxuICAgIHByb3ZpZGVyczogW1xuICAgICAgICB7XG4gICAgICAgICAgICBwcm92aWRlOiBGb2VobklucHV0Q29tcG9uZW50LFxuICAgICAgICAgICAgdXNlRXhpc3Rpbmc6IGZvcndhcmRSZWYoKCkgPT4gRm9laG5JbnB1dEhpZGRlbkNvbXBvbmVudCksXG4gICAgICAgICAgICBtdWx0aTogdHJ1ZVxuICAgICAgICB9XG4gICAgXVxufSlcbmV4cG9ydCBjbGFzcyBGb2VobklucHV0SGlkZGVuQ29tcG9uZW50XG4gICAgZXh0ZW5kcyBGb2VobklucHV0U3RyaW5nQ29tcG9uZW50XG4gICAgaW1wbGVtZW50cyBPbkluaXQge1xuICAgIGNvbnN0cnVjdG9yKHByaXZhdGUgbmdab25lOiBOZ1pvbmUpIHtcbiAgICAgICAgc3VwZXIoKTtcbiAgICB9XG5cbiAgICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICAgICAgc3VwZXIubmdPbkluaXQoKTtcbiAgICAgICAgdGhpcy50eXBlID0gJ2hpZGRlbic7XG4gICAgfVxuXG4gICAgb25Nb2RlbENoYW5nZSh2YWx1ZTogc3RyaW5nKTogdm9pZCB7XG4gICAgICAgIGlmICh2YWx1ZSA9PT0gdW5kZWZpbmVkIHx8ICEhdmFsdWUpIHtcbiAgICAgICAgICAgIHRoaXMudXBkYXRlTmdNb2RlbCh2YWx1ZSk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICB0aGlzLm5nWm9uZS5vbk1pY3JvdGFza0VtcHR5LnBpcGUoZmlyc3QoKSkuc3Vic2NyaWJlKCgpID0+IHtcbiAgICAgICAgICAgICAgICB0aGlzLnVwZGF0ZU5nTW9kZWwobnVsbCk7XG4gICAgICAgICAgICB9KTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIGRpc3BsYXlDbGVhckJ1dHRvbigpOiBPYnNlcnZhYmxlPGJvb2xlYW4+IHtcbiAgICAgICAgcmV0dXJuIG9mKGZhbHNlKTtcbiAgICB9XG59XG4iLCI8ZGl2XG4gICAgY2xhc3M9XCJmb3JtLWdyb3VwIGNsZWFyYWJsZS1pbnB1dC1mb3JtLWdyb3VwXCJcbiAgICBbY2xhc3MuaGFzLWRhbmdlcl09XCJoYXNFcnJvcnNUb0Rpc3BsYXkoKVwiXG4gICAgW2NsYXNzLnZkLWZvcm0tZ3JvdXAtZGFuZ2VyXT1cImhhc0Vycm9yc1RvRGlzcGxheSgpXCJcbiAgICBbYXR0ci5pZF09XCJidWlsZElkKCdDb250YWluZXInKVwiXG4gICAgdGFiaW5kZXg9XCItMVwiXG4+XG4gICAgPGxhYmVsXG4gICAgICAgIFthdHRyLmlkXT1cImJ1aWxkQ2hpbGRJZCgpICsgJ0xhYmVsJ1wiXG4gICAgICAgIFthdHRyLmZvcl09XCJidWlsZENoaWxkSWQoKVwiXG4gICAgICAgICpuZ0lmPVwibGFiZWwgJiYgdHlwZSAhPT0gJ2hpZGRlbidcIlxuICAgICAgICBbbmdDbGFzc109XCJpc0xhYmVsU3JPbmx5ID8gJ3NyLW9ubHknIDogbGFiZWxTdHlsZU1vZGlmaWVyXCJcbiAgICA+XG4gICAgICAgIDxzcGFuIFtpbm5lckhUTUxdPVwibGFiZWxcIj48L3NwYW4+XG4gICAgICAgIDxzcGFuXG4gICAgICAgICAgICAqbmdJZj1cIiFyZXF1aXJlZCAmJiAhaGlkZU5vdFJlcXVpcmVkRXh0cmFMYWJlbFwiXG4gICAgICAgICAgICBhcmlhLWhpZGRlbj1cInRydWVcIlxuICAgICAgICA+XG4gICAgICAgICAgICB7eyAnZm9laG4taW5wdXQub3B0aW9uYWwnIHwgZnJvbURpY3Rpb25hcnkgfX1cbiAgICAgICAgPC9zcGFuPlxuICAgIDwvbGFiZWw+XG5cbiAgICA8Zm9laG4tdmFsaWRhdGlvbi1hbGVydHMgW2NvbXBvbmVudF09XCJ0aGlzXCI+PC9mb2Vobi12YWxpZGF0aW9uLWFsZXJ0cz5cblxuICAgIDxzbWFsbFxuICAgICAgICAqbmdJZj1cImhlbHBUZXh0ICYmIHR5cGUgIT09ICdoaWRkZW4nXCJcbiAgICAgICAgW2F0dHIuaWRdPVwiYnVpbGRDaGlsZElkKCkgKyAnSGVscCdcIlxuICAgICAgICBjbGFzcz1cImZvcm0tdGV4dCB0ZXh0LXNlY29uZGFyeVwiXG4gICAgICAgIFtpbm5lckhUTUxdPVwiaGVscFRleHRcIlxuICAgID48L3NtYWxsPlxuXG4gICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuXG4gICAgPGlucHV0XG4gICAgICAgIFtjbGFzcy5pcy1pbnZhbGlkXT1cImhhc0Vycm9yc1RvRGlzcGxheSgpIHx8IGhhc0luaGVyaXRFcnJvckZyb21QYXJlbnQoKVwiXG4gICAgICAgIFtjbGFzcy5jbGVhcmFibGUtaW5wdXRdPVwiZGlzcGxheUNsZWFyQnV0dG9uKCkgfCBhc3luY1wiXG4gICAgICAgIGNsYXNzPVwiZm9ybS1jb250cm9sXCJcbiAgICAgICAgW25hbWVdPVwibmFtZSB8fCBsYWJlbFwiXG4gICAgICAgIFthdHRyLm1heGxlbmd0aF09XCJnZXRNYXhMZW5ndGgoKVwiXG4gICAgICAgIFthdHRyLmF1dG9jb21wbGV0ZV09XCJnZXRBdXRvQ29tcGxldGUoKVwiXG4gICAgICAgIFthdHRyLmRpc2FibGVkXT1cImRpc2FibGVkID8gJ2Rpc2FibGVkJyA6IG51bGxcIlxuICAgICAgICBbYXR0ci50eXBlXT1cInR5cGVcIlxuICAgICAgICBbYXR0ci5wYXR0ZXJuXT1cInBhdHRlcm5cIlxuICAgICAgICBbYXR0ci5taW5dPVwibWluXCJcbiAgICAgICAgW2F0dHIubWF4XT1cIm1heFwiXG4gICAgICAgIFthdHRyLmlkXT1cImJ1aWxkQ2hpbGRJZCgpXCJcbiAgICAgICAgW2F0dHIuYXJpYS1kZXNjcmliZWRieV09XCJnZXREZXNjcmliZWRCeSgpXCJcbiAgICAgICAgW2F0dHIuYXJpYS1pbnZhbGlkXT1cImhhc0Vycm9yc1RvRGlzcGxheSgpIHx8IG51bGxcIlxuICAgICAgICBbYXR0ci5hcmlhLXJlcXVpcmVkXT1cInJlcXVpcmVkIHx8IG51bGxcIlxuICAgICAgICBbbmdNb2RlbF09XCJtb2RlbFwiXG4gICAgICAgIChwYXN0ZSk9XCJvblBhc3RlKCRldmVudClcIlxuICAgICAgICAobmdNb2RlbENoYW5nZSk9XCJ1cGRhdGVOZ01vZGVsKCRldmVudClcIlxuICAgICAgICAoaW5wdXQpPVwiaGFuZGxlQ2hhbmdlKGVudHJ5Q29tcG9uZW50LnZhbHVlKVwiXG4gICAgICAgIChrZXlkb3duKT1cIm9uS2V5ZG93bigkZXZlbnQpXCJcbiAgICAgICAgKGJsdXIpPVwib25CbHVyKCRldmVudClcIlxuICAgICAgICAoZm9jdXMpPVwib25Gb2N1cygkZXZlbnQpXCJcbiAgICAgICAgI2VudHJ5Q29tcG9uZW50XG4gICAgLz5cblxuICAgIDxidXR0b25cbiAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICAgIFtpZF09XCJidWlsZENoaWxkSWQoKSArICdDbGVhckJ1dHRvbidcIlxuICAgICAgICAqbmdJZj1cImRpc3BsYXlDbGVhckJ1dHRvbigpIHwgYXN5bmNcIlxuICAgICAgICBjbGFzcz1cImNsZWFyYWJsZS1pbnB1dC1jbGVhci1idXR0b24gYnRuXCJcbiAgICAgICAgKGNsaWNrKT1cIm9uQ2xlYXIoKVwiXG4gICAgPlxuICAgICAgICA8Zm9laG4taWNvbi10aW1lc1xuICAgICAgICAgICAgY2xhc3M9XCJjbGVhcmFibGUtaW5wdXQtY2xlYXItYnV0dG9uLWljb25cIlxuICAgICAgICAgICAgdGl0bGU9XCJSw6lpbml0aWFsaXNlciBsZSBjaGFtcHNcIlxuICAgICAgICA+PC9mb2Vobi1pY29uLXRpbWVzPlxuICAgIDwvYnV0dG9uPlxuPC9kaXY+XG4iXX0=