desy-angular 14.0.1 → 14.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,12 +1,12 @@
1
1
  import { __decorate, __metadata } from "tslib";
2
2
  import { ChangeDetectorRef, Component, ContentChildren, ElementRef, EventEmitter, HostBinding, Input, Output, QueryList, ViewChild } from '@angular/core';
3
3
  import { ContentComponent } from '../../../../desy-commons/components/content/content.component';
4
- import { LabelComponent } from '../../label/label.component';
5
- import { HintComponent } from '../../hint/hint.component';
6
4
  import { AccessibilityComponent } from '../../../../shared/components';
7
5
  import { DesyOnInputChange } from "../../../../shared/decorators/desy-on-input-change.decorator";
8
- import { CheckboxesParentComponent } from '../checkboxes-parent.component';
9
6
  import { MakeHtmlListPipe } from '../../../../shared/pipes/make-html-list.pipe';
7
+ import { HintComponent } from '../../hint/hint.component';
8
+ import { LabelComponent } from '../../label/label.component';
9
+ import { CheckboxesParentComponent } from '../checkboxes-parent.component';
10
10
  import * as i0 from "@angular/core";
11
11
  import * as i1 from "../checkboxes-parent.component";
12
12
  import * as i2 from "@angular/common";
@@ -19,6 +19,7 @@ export class CheckboxItemComponent extends AccessibilityComponent {
19
19
  super();
20
20
  this.checkboxes = checkboxes;
21
21
  this.changeDetectorRef = changeDetectorRef;
22
+ this.checked = false;
22
23
  this.checkedChange = new EventEmitter();
23
24
  this.indeterminateChange = new EventEmitter();
24
25
  }
@@ -185,4 +186,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
185
186
  }], indeterminateChange: [{
186
187
  type: Output
187
188
  }] } });
188
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox-item.component.js","sourceRoot":"","sources":["../../../../../../../../projects/desy-angular/src/lib/desy-forms/components/checkboxes/checkbox-item/checkbox-item.component.ts","../../../../../../../../projects/desy-angular/src/lib/desy-forms/components/checkboxes/checkbox-item/checkbox-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit, ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Input, OnChanges, OnDestroy, OnInit,\n  Output, QueryList, SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport {ItemCheckboxData} from '../../../interfaces';\nimport {ContentComponent} from '../../../../desy-commons/components/content/content.component';\nimport {LabelComponent} from '../../label/label.component';\nimport {HintComponent} from '../../hint/hint.component';\nimport {AccessibilityComponent} from '../../../../shared/components';\nimport {DesyOnInputChange} from \"../../../../shared/decorators/desy-on-input-change.decorator\";\nimport { CheckboxesParentComponent } from '../checkboxes-parent.component';\nimport {MakeHtmlListPipe} from '../../../../shared/pipes/make-html-list.pipe';\n\n@Component({\n  selector: 'desy-checkbox-item',\n  templateUrl: './checkbox-item.component.html'\n})\nexport class CheckboxItemComponent extends AccessibilityComponent implements OnInit, OnDestroy, OnChanges, AfterViewInit, ItemCheckboxData {\n\n  @ViewChild('input') inputElement: ElementRef;\n\n  @Input() id: string;\n  @Input() value: any;\n  @Input() name: string;\n  @Input() conditional: boolean;\n  @Input() disabled: boolean;\n  @Input() isIndeterminate: boolean;\n\n  @DesyOnInputChange('setIndeterminateStatus')\n  @Input() indeterminateChecked: boolean;\n  @Input() classes: any;\n  @HostBinding('class') classesHost: any;\n\n  @ContentChildren(LabelComponent) labelComponentList: QueryList<LabelComponent>;\n  @ContentChildren(HintComponent) hintComponentList: QueryList<HintComponent>;\n  @ContentChildren(ContentComponent) conditionalContentList: QueryList<ContentComponent>;\n\n  @Input() checked: boolean;\n\n  @Output() checkedChange: EventEmitter<any> = new EventEmitter<any>();\n  @Output() indeterminateChange: EventEmitter<any> = new EventEmitter<any>();\n\n  lastChecked;\n  lastIndeterminate;\n  lastValue;\n  checkboxId;\n\n  parentDisabled: boolean;\n\n  constructor(private checkboxes: CheckboxesParentComponent, private changeDetectorRef: ChangeDetectorRef) {\n    super();\n  }\n\n  ngOnInit(): void {\n    this.checkboxes.markForUpdateCheckboxIds();\n  }\n\n  ngOnDestroy(): void {\n    this.checkboxes.markForUpdateCheckboxIds();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    this.classesHost = new MakeHtmlListPipe().transform(['block', this.checkboxes.hasDividers ? 'border-t border-b border-neutral-base -mb-px' : null, this.classes], null);\n    if (this.checked !== this.lastChecked && this.isInit()) {\n       this.setChecked(this.checked);\n      this.checkboxes.updateValueFromCheckboxItems();\n     } else if (this.lastValue !== undefined && this.lastValue !== this.value) {\n      this.checkboxes.updateValueFromCheckboxItems();\n     }\n\n     if(this.indeterminateChecked !== this.lastIndeterminate && this.isInit()){\n       this.setIndeterminateChecked(this.indeterminateChecked);\n      this.checkboxes.updateValueFromCheckboxItems();\n     }\n\n\n     this.lastValue = this.value;\n\n     if (this.id !== this.checkboxId) {\n      this.checkboxes.markForUpdateCheckboxIds();\n     }\n  }\n\n  ngAfterViewInit(): void {\n    this.setChecked(this.checked);\n    this.setIndeterminateChecked(this.indeterminateChecked);\n    if (this.checked !== null && this.checked !== undefined) {\n      this.checkboxes.updateValueFromCheckboxItems();\n    }\n  }\n\n  getItemHintId(): string {\n    return this.hintComponentList && this.hintComponentList.length > 0 && this.checkboxId ? this.checkboxId + '-item-hint' : null;\n  }\n\n  hasChanged(): void {\n    // Se establece el cambio a visualizar en el input\n    const input = this.inputElement.nativeElement;\n    if (this.isIndeterminate) {\n      if (input.readOnly) {\n        input.checked = false;\n        input.readOnly = false;\n      } else if (!input.checked) {\n        input.readOnly = true;\n        input.indeterminate = true;\n      }\n    }\n    this.setChecked(input.checked);\n    this.setIndeterminateChecked(input.indeterminate);\n    this.checkboxes.updateValueFromCheckboxItems();\n  }\n\n  setChecked(checked: boolean): void {\n    this.checked = checked;\n    this.lastChecked = checked;\n    this.checkedChange.emit(checked);\n    this.changeDetectorRef.detectChanges(); // Avisa al elemento input para que actualice su estado\n  }\n\n  setIndeterminateChecked(indeterminateChecked: boolean): void {\n    this.indeterminateChecked = indeterminateChecked;\n    this.lastIndeterminate = indeterminateChecked;\n    this.indeterminateChange.emit(indeterminateChecked);\n    this.changeDetectorRef.detectChanges(); // Avisa al elemento input para que actualice su estado\n  }\n\n  setIndeterminateStatus(): void {\n    const input = this.inputElement?.nativeElement;\n    if (input) {\n      if (this.indeterminateChecked) {\n        input.readOnly = true;\n        input.indeterminate = true;\n      } else if (input.readOnly) {\n        input.readOnly = false;\n        input.indeterminate = false;\n      }\n    }\n  }\n\n  isInit(): boolean {\n    return !!this.inputElement;\n  }\n\n  getValue(): any {\n    const input = this.inputElement.nativeElement;\n    return input.checked || input.indeterminate ? this.value : null;\n  }\n\n  updateCheckboxId(index?: number): void {\n    if (this.id) {\n       this.checkboxId = this.id;\n    } else {\n      const idPrefix = this.checkboxes.idPrefix ? this.checkboxes.idPrefix : this.checkboxes.name;\n      if (index === 0) {\n        this.checkboxId = idPrefix;\n      } else {\n        this.checkboxId = `${idPrefix}-${index}`;\n      }\n    }\n\n    if (this.labelComponentList && this.labelComponentList.length > 0) {\n      this.labelComponentList.first.for = this.checkboxId;\n    }\n\n    if (this.hintComponentList && this.hintComponentList.length > 0) {\n      this.hintComponentList.first.id = this.getItemHintId();\n    }\n\n    this.changeDetectorRef.detectChanges();\n  }\n\n  /*\n   * Funciones para aportar información desde el componente checkboxes que lo contiene\n   */\n\n  hasDividers(): boolean {\n    return this.checkboxes.hasDividers;    \n  }\n\n  hasError(): boolean {\n    return this.checkboxes.hasErrorsMessage();\n  }\n\n  getNameCheckbox(): string {\n    return this.checkboxes.name;\n  }\n\n  getDescribedBy(): string {\n    return !this.checkboxes.hasFieldset() ? this.checkboxes.describedBy : null;\n  }\n}\n","<div class=\"relative flex items-start py-base\">\n    <div class=\"flex items-center mx-sm\">\n      <input #input class=\"w-6 h-6 transition duration-150 ease-in-out border-black focus:border-black focus:shadow-outline-focus-input focus:ring-4 focus:ring-offset-0 focus:ring-warning-base disabled:bg-neutral-base disabled:border-neutral-base text-primary-base\"\n              [checked]=\"checked\"\n              [attr.id]=\"checkboxId\"\n              [attr.name]=\"name ? name : getNameCheckbox()\"\n              type=\"checkbox\"\n              [value]=\"value\" (change)=\"hasChanged()\"\n              [attr.disabled]=\"disabled || parentDisabled ? true : null\"\n              [attr.aria-controls]=\"conditionalContentList && conditionalContentList.length > 0 ? 'conditional-' + checkboxId : null\"\n              [attr.aria-describedby]=\"[getDescribedBy(), getItemHintId()] | makeHtmlList:null\"\n              [attr.aria-invalid]=\"hasError() ? true : null\"\n              [desyAppAccessibility]=\"this\">\n    </div>\n    <div class=\"pt-0.5 leading-5\">\n      <ng-container *ngIf=\"labelComponentList && labelComponentList.length > 0\">\n        <ng-content select=\"desy-label\"></ng-content>\n      </ng-container>\n      <ng-container *ngIf=\"!(labelComponentList && labelComponentList.length > 0)\">\n        <desy-label [for]=\"checkboxId\">\n          <ng-content></ng-content>\n        </desy-label>\n      </ng-container>\n      <ng-content select=\"desy-hint\"></ng-content>\n    </div>\n</div>\n\n<div *ngIf=\"conditional && conditionalContentList && conditionalContentList.length > 0 && (input.checked || input.indeterminate)\"\n      class=\"mb-base ml-5 py-sm pl-6 origin-top-left border-l-2 border-primary-base\"\n      [attr.id]=\"'conditional-' + checkboxId\">\n  <ng-container *desyCustomInnerContent=\"{ component: conditionalContentList.first }\"></ng-container>\n</div>\n"]}
189
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox-item.component.js","sourceRoot":"","sources":["../../../../../../../../projects/desy-angular/src/lib/desy-forms/components/checkboxes/checkbox-item/checkbox-item.component.ts","../../../../../../../../projects/desy-angular/src/lib/desy-forms/components/checkboxes/checkbox-item/checkbox-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit, ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Input, OnChanges, OnDestroy, OnInit,\n  Output, QueryList, SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport { ContentComponent } from '../../../../desy-commons/components/content/content.component';\nimport { AccessibilityComponent } from '../../../../shared/components';\nimport { DesyOnInputChange } from \"../../../../shared/decorators/desy-on-input-change.decorator\";\nimport { MakeHtmlListPipe } from '../../../../shared/pipes/make-html-list.pipe';\nimport { ItemCheckboxData } from '../../../interfaces';\nimport { HintComponent } from '../../hint/hint.component';\nimport { LabelComponent } from '../../label/label.component';\nimport { CheckboxesParentComponent } from '../checkboxes-parent.component';\n\n@Component({\n  selector: 'desy-checkbox-item',\n  templateUrl: './checkbox-item.component.html'\n})\nexport class CheckboxItemComponent extends AccessibilityComponent implements OnInit, OnDestroy, OnChanges, AfterViewInit, ItemCheckboxData {\n\n  @ViewChild('input') inputElement: ElementRef;\n\n  @Input() id: string;\n  @Input() value: any;\n  @Input() name: string;\n  @Input() conditional: boolean;\n  @Input() disabled: boolean;\n  @Input() isIndeterminate: boolean;\n\n  @DesyOnInputChange('setIndeterminateStatus')\n  @Input() indeterminateChecked: boolean;\n  @Input() classes: any;\n  @HostBinding('class') classesHost: any;\n\n  @ContentChildren(LabelComponent) labelComponentList: QueryList<LabelComponent>;\n  @ContentChildren(HintComponent) hintComponentList: QueryList<HintComponent>;\n  @ContentChildren(ContentComponent) conditionalContentList: QueryList<ContentComponent>;\n\n  @Input() checked: boolean = false;\n\n  @Output() checkedChange: EventEmitter<any> = new EventEmitter<any>();\n  @Output() indeterminateChange: EventEmitter<any> = new EventEmitter<any>();\n\n  lastChecked;\n  lastIndeterminate;\n  lastValue;\n  checkboxId;\n\n  parentDisabled: boolean;\n\n  constructor(private checkboxes: CheckboxesParentComponent, private changeDetectorRef: ChangeDetectorRef) {\n    super();\n  }\n\n  ngOnInit(): void {\n    this.checkboxes.markForUpdateCheckboxIds();\n  }\n\n  ngOnDestroy(): void {\n    this.checkboxes.markForUpdateCheckboxIds();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    this.classesHost = new MakeHtmlListPipe().transform(['block', this.checkboxes.hasDividers ? 'border-t border-b border-neutral-base -mb-px' : null, this.classes], null);\n    if (this.checked !== this.lastChecked && this.isInit()) {\n       this.setChecked(this.checked);\n      this.checkboxes.updateValueFromCheckboxItems();\n     } else if (this.lastValue !== undefined && this.lastValue !== this.value) {\n      this.checkboxes.updateValueFromCheckboxItems();\n     }\n\n     if(this.indeterminateChecked !== this.lastIndeterminate && this.isInit()){\n       this.setIndeterminateChecked(this.indeterminateChecked);\n      this.checkboxes.updateValueFromCheckboxItems();\n     }\n\n\n     this.lastValue = this.value;\n\n     if (this.id !== this.checkboxId) {\n      this.checkboxes.markForUpdateCheckboxIds();\n     }\n  }\n\n  ngAfterViewInit(): void {\n    this.setChecked(this.checked);\n    this.setIndeterminateChecked(this.indeterminateChecked);\n    if (this.checked !== null && this.checked !== undefined) {\n      this.checkboxes.updateValueFromCheckboxItems();\n    }\n  }\n\n  getItemHintId(): string {\n    return this.hintComponentList && this.hintComponentList.length > 0 && this.checkboxId ? this.checkboxId + '-item-hint' : null;\n  }\n\n  hasChanged(): void {\n    // Se establece el cambio a visualizar en el input\n    const input = this.inputElement.nativeElement;\n    if (this.isIndeterminate) {\n      if (input.readOnly) {\n        input.checked = false;\n        input.readOnly = false;\n      } else if (!input.checked) {\n        input.readOnly = true;\n        input.indeterminate = true;\n      }\n    }\n    this.setChecked(input.checked);\n    this.setIndeterminateChecked(input.indeterminate);\n    this.checkboxes.updateValueFromCheckboxItems();\n  }\n\n  setChecked(checked: boolean): void {\n    this.checked = checked;\n    this.lastChecked = checked;\n    this.checkedChange.emit(checked);\n    this.changeDetectorRef.detectChanges(); // Avisa al elemento input para que actualice su estado\n  }\n\n  setIndeterminateChecked(indeterminateChecked: boolean): void {\n    this.indeterminateChecked = indeterminateChecked;\n    this.lastIndeterminate = indeterminateChecked;\n    this.indeterminateChange.emit(indeterminateChecked);\n    this.changeDetectorRef.detectChanges(); // Avisa al elemento input para que actualice su estado\n  }\n\n  setIndeterminateStatus(): void {\n    const input = this.inputElement?.nativeElement;\n    if (input) {\n      if (this.indeterminateChecked) {\n        input.readOnly = true;\n        input.indeterminate = true;\n      } else if (input.readOnly) {\n        input.readOnly = false;\n        input.indeterminate = false;\n      }\n    }\n  }\n\n  isInit(): boolean {\n    return !!this.inputElement;\n  }\n\n  getValue(): any {\n    const input = this.inputElement.nativeElement;\n    return input.checked || input.indeterminate ? this.value : null;\n  }\n\n  updateCheckboxId(index?: number): void {\n    if (this.id) {\n       this.checkboxId = this.id;\n    } else {\n      const idPrefix = this.checkboxes.idPrefix ? this.checkboxes.idPrefix : this.checkboxes.name;\n      if (index === 0) {\n        this.checkboxId = idPrefix;\n      } else {\n        this.checkboxId = `${idPrefix}-${index}`;\n      }\n    }\n\n    if (this.labelComponentList && this.labelComponentList.length > 0) {\n      this.labelComponentList.first.for = this.checkboxId;\n    }\n\n    if (this.hintComponentList && this.hintComponentList.length > 0) {\n      this.hintComponentList.first.id = this.getItemHintId();\n    }\n\n    this.changeDetectorRef.detectChanges();\n  }\n\n  /*\n   * Funciones para aportar información desde el componente checkboxes que lo contiene\n   */\n\n  hasDividers(): boolean {\n    return this.checkboxes.hasDividers;    \n  }\n\n  hasError(): boolean {\n    return this.checkboxes.hasErrorsMessage();\n  }\n\n  getNameCheckbox(): string {\n    return this.checkboxes.name;\n  }\n\n  getDescribedBy(): string {\n    return !this.checkboxes.hasFieldset() ? this.checkboxes.describedBy : null;\n  }\n}\n","<div class=\"relative flex items-start py-base\">\n    <div class=\"flex items-center mx-sm\">\n      <input #input class=\"w-6 h-6 transition duration-150 ease-in-out border-black focus:border-black focus:shadow-outline-focus-input focus:ring-4 focus:ring-offset-0 focus:ring-warning-base disabled:bg-neutral-base disabled:border-neutral-base text-primary-base\"\n              [checked]=\"checked\"\n              [attr.id]=\"checkboxId\"\n              [attr.name]=\"name ? name : getNameCheckbox()\"\n              type=\"checkbox\"\n              [value]=\"value\" (change)=\"hasChanged()\"\n              [attr.disabled]=\"disabled || parentDisabled ? true : null\"\n              [attr.aria-controls]=\"conditionalContentList && conditionalContentList.length > 0 ? 'conditional-' + checkboxId : null\"\n              [attr.aria-describedby]=\"[getDescribedBy(), getItemHintId()] | makeHtmlList:null\"\n              [attr.aria-invalid]=\"hasError() ? true : null\"\n              [desyAppAccessibility]=\"this\">\n    </div>\n    <div class=\"pt-0.5 leading-5\">\n      <ng-container *ngIf=\"labelComponentList && labelComponentList.length > 0\">\n        <ng-content select=\"desy-label\"></ng-content>\n      </ng-container>\n      <ng-container *ngIf=\"!(labelComponentList && labelComponentList.length > 0)\">\n        <desy-label [for]=\"checkboxId\">\n          <ng-content></ng-content>\n        </desy-label>\n      </ng-container>\n      <ng-content select=\"desy-hint\"></ng-content>\n    </div>\n</div>\n\n<div *ngIf=\"conditional && conditionalContentList && conditionalContentList.length > 0 && (input.checked || input.indeterminate)\"\n      class=\"mb-base ml-5 py-sm pl-6 origin-top-left border-l-2 border-primary-base\"\n      [attr.id]=\"'conditional-' + checkboxId\">\n  <ng-container *desyCustomInnerContent=\"{ component: conditionalContentList.first }\"></ng-container>\n</div>\n"]}
@@ -1,7 +1,7 @@
1
1
  import { Component, ContentChildren, EventEmitter, forwardRef, Input, Output, QueryList } from '@angular/core';
2
2
  import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
- import { FormFieldComponent } from '../form-field/form-field.component';
4
3
  import { ButtonComponent } from '../../../desy-buttons/components/button/button.component';
4
+ import { FormFieldComponent } from '../form-field/form-field.component';
5
5
  import * as i0 from "@angular/core";
6
6
  import * as i1 from "@angular/common";
7
7
  import * as i2 from "../../../shared/directives/accessibility-directive";
@@ -14,6 +14,10 @@ export class SearchBarComponent extends FormFieldComponent {
14
14
  this.clickEvent = new EventEmitter();
15
15
  this.value = '';
16
16
  }
17
+ writeValue(value) {
18
+ this.value = value;
19
+ this.onChange(value);
20
+ }
17
21
  onClick(event) {
18
22
  if (!this.disabled) {
19
23
  this.clickEvent.emit(event);
@@ -58,4 +62,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
58
62
  }], clickEvent: [{
59
63
  type: Output
60
64
  }] } });
61
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-bar.component.js","sourceRoot":"","sources":["../../../../../../../projects/desy-angular/src/lib/desy-forms/components/search-bar/search-bar.component.ts","../../../../../../../projects/desy-angular/src/lib/desy-forms/components/search-bar/search-bar.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,eAAe,EACf,YAAY,EACZ,UAAU,EACV,KAAK,EACL,MAAM,EAAE,SAAS,EAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAE,kBAAkB,EAAE,MAAM,oCAAoC,CAAC;AACxE,OAAO,EAAE,eAAe,EAAE,MAAM,0DAA0D,CAAC;;;;;;;AAa3F,MAAM,OAAO,kBAAmB,SAAQ,kBAA0B;IAXlE;;QAmBY,eAAU,GAAG,IAAI,YAAY,EAAE,CAAC;QAE1C,UAAK,GAAG,EAAE,CAAC;KAgBZ;IAdC,OAAO,CAAC,KAAU;QAChB,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC9B,CAAC;IACH,CAAC;IAED,SAAS;QACP,OAAO,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC;IAC/C,CAAC;IAED,OAAO,CAAC,KAAU;QAChB,IAAI,CAAC,KAAK,GAAI,KAAK,CAAC,MAA2B,CAAC,KAAK,CAAC;QACtD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC5B,CAAC;+GAzBU,kBAAkB;mGAAlB,kBAAkB,yMARlB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,kBAAkB,CAAC;gBACjD,KAAK,EAAE,IAAI;aACZ;SACF,iDAIgB,eAAe,oDCzBlC,4wJAwEA;;4FDjDa,kBAAkB;kBAX9B,SAAS;+BACE,iBAAiB,aAEhB;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,mBAAmB,CAAC;4BACjD,KAAK,EAAE,IAAI;yBACZ;qBACF;8BAIiC,MAAM;sBAAvC,eAAe;uBAAC,eAAe;gBAEvB,WAAW;sBAAnB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACI,UAAU;sBAAnB,MAAM","sourcesContent":["import {\n  Component,\n  ContentChildren,\n  EventEmitter,\n  forwardRef,\n  Input,\n  Output, QueryList\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { FormFieldComponent } from '../form-field/form-field.component';\nimport { ButtonComponent } from '../../../desy-buttons/components/button/button.component';\n\n@Component({\n  selector: 'desy-search-bar',\n  templateUrl: './search-bar.component.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => SearchBarComponent),\n      multi: true\n    }\n  ]\n})\nexport class SearchBarComponent extends FormFieldComponent<string>{  \n  \n  @ContentChildren(ButtonComponent) button: QueryList<ButtonComponent>;\n\n  @Input() describedBy: string;\n  @Input() classes: any;\n  @Input() buttonClasses: string;\n  @Input() placeholder: string;\n  @Output() clickEvent = new EventEmitter();\n  \n  value = '';\n  \n  onClick(event: any): void {\n    if (!this.disabled) {\n      this.clickEvent.emit(event);\n    }\n  }\n\n  hasButton(): boolean {\n    return this.button && this.button.length > 0;\n  }\n\n  onInput(event: any): void {\n    this.value = (event.target as HTMLInputElement).value;\n    this.onChange(this.value);\n  }\n}\n","<!-- searchbar -->\n<ng-content select=\"desy-label\"></ng-content>\n<ng-container *ngTemplateOutlet=\"labelRef\"></ng-container>\n<desy-label *ngIf=\"!labelRef && labelData\"\n            [text]=\"labelData.text\"\n            [html]=\"labelData.html\"\n            [classes]=\"['sr-only', labelData.classes] | makeHtmlList\"\n            [isPageHeading]=\"labelData.isPageHeading\"\n            [for]=\"id\"\n            [role]=\"labelData.role\"\n            [ariaLabel]=\"labelData.ariaLabel\"\n            [ariaDescribedBy]=\"labelData.ariaDescribedBy\"\n            [ariaLabelledBy]=\"labelData.ariaLabelledBy\"\n            [ariaHidden]=\"labelData.ariaHidden\"\n            [ariaDisabled]=\"labelData.ariaDisabled\"\n            [ariaControls]=\"labelData.ariaControls\"\n            [ariaCurrent]=\"labelData.ariaCurrent\"\n            [ariaLive]=\"labelData.ariaLive\"\n            [ariaExpanded]=\"labelData.ariaExpanded\"\n            [ariaErrorMessage]=\"labelData.ariaErrorMessage\"\n            [ariaHasPopup]=\"labelData.ariaHasPopup\"\n            [tabindex]=\"labelData.tabindex\"></desy-label>\n<desy-label *ngIf=\"!labelRef && !labelData && labelText\" [text]=\"labelText\" classes=\"sr-only\" [for]=\"id\"></desy-label>\n\n<div class=\"relative\" [ngClass]=\"{'flex flex-wrap items-end gap-sm': hasButton()}\">\n  <input type=\"search\"\n         [class]=\"['c-input block border-black rounded font-semibold placeholder-neutral-dark focus:border-black focus:shadow-outline-focus-input focus:ring-4 focus:ring-warning-base disabled:bg-neutral-light disabled:border-neutral-base', classes] | makeHtmlList\"\n         [ngClass]=\"{'border-alert-base ring-2 ring-alert-base': hasErrorsMessage(),'pr-12 w-full': !hasButton()}\"\n         [value]=\"value\" (input)=\"onInput($event)\"\n         [attr.id]=\"id ? id : null\"\n         [attr.name]=\"id ? id : null\"\n         [attr.aria-describedby]=\"[describedBy, getErrorId()] | makeHtmlList:null\"\n         [attr.aria-errormessage]=\"hasErrorsMessage() ? getErrorId() : null\"\n         [attr.aria-invalid]=\"hasErrorsMessage() ? true : null\"\n         [attr.disabled]=\"disabled ? true : null\"\n         [desyAppAccessibility]=\"this\">\n  <ng-container *ngIf=\"hasButton(); else defaultButton\">\n    <ng-content select=\"desy-button\"></ng-content>\n  </ng-container>\n  <ng-template #defaultButton>\n    <button type=\"submit\" [attr.disabled]=\"disabled ? 'disabled' : null\" [attr.aria-disabled]=\"disabled ? 'true' : null\"\n            (click)=\"onClick($event)\"\n            [class]=\"['absolute top-0 right-0 m-sm p-0.5 text-primary-base hover:text-primary-dark focus:bg-warning-base focus:outline-none focus:shadow-outline-focus', buttonClasses] | makeHtmlList\">\n      <span class=\"sr-only\">Buscar</span>\n      <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" width=\"1.375em\" height=\"1.375em\" aria-hidden=\"true\"><path d=\"M23.498 23.487a1.713 1.713 0 000-2.421l-4.572-4.575a.43.43 0 01-.062-.539 10.283 10.283 0 10-2.911 2.911.43.43 0 01.539.055l4.574 4.574a1.712 1.712 0 002.433-.005zM3.451 10.289a6.85 6.85 0 116.85 6.85 6.85 6.85 0 01-6.85-6.85z\" fill=\"currentColor\"/></svg>\n    </button>\n  </ng-template>\n  <ng-content select=\"desy-error-message\"></ng-content>\n  <ng-container *ngTemplateOutlet=\"errorMessageRef\"></ng-container>\n  <desy-error-message *ngIf=\"!errorMessageRef && errorMessageData\"\n                      [id]=\"getErrorId()\"\n                      [text]=\"errorMessageData.text\"\n                      [html]=\"errorMessageData.html\"\n                      [classes]=\"errorMessageData.classes\"\n                      [visuallyHiddenText]=\"errorMessageData.visuallyHiddenText\"\n                      [role]=\"errorMessageData.role\"\n                      [ariaLabel]=\"errorMessageData.ariaLabel\"\n                      [ariaDescribedBy]=\"errorMessageData.ariaDescribedBy\"\n                      [ariaLabelledBy]=\"errorMessageData.ariaLabelledBy\"\n                      [ariaHidden]=\"errorMessageData.ariaHidden\"\n                      [ariaDisabled]=\"errorMessageData.ariaDisabled\"\n                      [ariaControls]=\"errorMessageData.ariaControls\"\n                      [ariaCurrent]=\"errorMessageData.ariaCurrent\"\n                      [ariaLive]=\"errorMessageData.ariaLive\"\n                      [ariaExpanded]=\"errorMessageData.ariaExpanded\"\n                      [ariaErrorMessage]=\"errorMessageData.ariaErrorMessage\"\n                      [ariaHasPopup]=\"errorMessageData.ariaHasPopup\"\n                      [tabindex]=\"errorMessageData.tabindex\"></desy-error-message>\n  <desy-error-message *ngIf=\"!errorMessageRef && !errorMessageData && errorMessageText\"\n                      [text]=\"errorMessageText\" [id]=\"getErrorId()\"></desy-error-message>\n</div>\n<!-- /searchbar -->\n"]}
65
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-bar.component.js","sourceRoot":"","sources":["../../../../../../../projects/desy-angular/src/lib/desy-forms/components/search-bar/search-bar.component.ts","../../../../../../../projects/desy-angular/src/lib/desy-forms/components/search-bar/search-bar.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,eAAe,EACf,YAAY,EACZ,UAAU,EACV,KAAK,EACL,MAAM,EAAE,SAAS,EAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,0DAA0D,CAAC;AAC3F,OAAO,EAAE,kBAAkB,EAAE,MAAM,oCAAoC,CAAC;;;;;;;AAaxE,MAAM,OAAO,kBAAmB,SAAQ,kBAA0B;IAXlE;;QAmBY,eAAU,GAAG,IAAI,YAAY,EAAE,CAAC;QAE1C,UAAK,GAAG,EAAE,CAAC;KAqBZ;IAnBC,UAAU,CAAC,KAAK;QACd,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACvB,CAAC;IAED,OAAO,CAAC,KAAU;QAChB,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC9B,CAAC;IACH,CAAC;IAED,SAAS;QACP,OAAO,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC;IAC/C,CAAC;IAED,OAAO,CAAC,KAAU;QAChB,IAAI,CAAC,KAAK,GAAI,KAAK,CAAC,MAA2B,CAAC,KAAK,CAAC;QACtD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC5B,CAAC;+GA9BU,kBAAkB;mGAAlB,kBAAkB,yMARlB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,kBAAkB,CAAC;gBACjD,KAAK,EAAE,IAAI;aACZ;SACF,iDAIgB,eAAe,oDCzBlC,4wJAwEA;;4FDjDa,kBAAkB;kBAX9B,SAAS;+BACE,iBAAiB,aAEhB;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,mBAAmB,CAAC;4BACjD,KAAK,EAAE,IAAI;yBACZ;qBACF;8BAIiC,MAAM;sBAAvC,eAAe;uBAAC,eAAe;gBAEvB,WAAW;sBAAnB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACI,UAAU;sBAAnB,MAAM","sourcesContent":["import {\n  Component,\n  ContentChildren,\n  EventEmitter,\n  forwardRef,\n  Input,\n  Output, QueryList\n} from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { ButtonComponent } from '../../../desy-buttons/components/button/button.component';\nimport { FormFieldComponent } from '../form-field/form-field.component';\n\n@Component({\n  selector: 'desy-search-bar',\n  templateUrl: './search-bar.component.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => SearchBarComponent),\n      multi: true\n    }\n  ]\n})\nexport class SearchBarComponent extends FormFieldComponent<string> {\n\n  @ContentChildren(ButtonComponent) button: QueryList<ButtonComponent>;\n\n  @Input() describedBy: string;\n  @Input() classes: any;\n  @Input() buttonClasses: string;\n  @Input() placeholder: string;\n  @Output() clickEvent = new EventEmitter();\n\n  value = '';\n  // Por petición de poder aceptar nulls/undefined o cadenas vacias para resetear el searchbar input.\n  writeValue(value): void {\n    this.value = value;\n    this.onChange(value);\n  }\n\n  onClick(event: any): void {\n    if (!this.disabled) {\n      this.clickEvent.emit(event);\n    }\n  }\n\n  hasButton(): boolean {\n    return this.button && this.button.length > 0;\n  }\n\n  onInput(event: any): void {\n    this.value = (event.target as HTMLInputElement).value;\n    this.onChange(this.value);\n  }\n}\n","<!-- searchbar -->\n<ng-content select=\"desy-label\"></ng-content>\n<ng-container *ngTemplateOutlet=\"labelRef\"></ng-container>\n<desy-label *ngIf=\"!labelRef && labelData\"\n            [text]=\"labelData.text\"\n            [html]=\"labelData.html\"\n            [classes]=\"['sr-only', labelData.classes] | makeHtmlList\"\n            [isPageHeading]=\"labelData.isPageHeading\"\n            [for]=\"id\"\n            [role]=\"labelData.role\"\n            [ariaLabel]=\"labelData.ariaLabel\"\n            [ariaDescribedBy]=\"labelData.ariaDescribedBy\"\n            [ariaLabelledBy]=\"labelData.ariaLabelledBy\"\n            [ariaHidden]=\"labelData.ariaHidden\"\n            [ariaDisabled]=\"labelData.ariaDisabled\"\n            [ariaControls]=\"labelData.ariaControls\"\n            [ariaCurrent]=\"labelData.ariaCurrent\"\n            [ariaLive]=\"labelData.ariaLive\"\n            [ariaExpanded]=\"labelData.ariaExpanded\"\n            [ariaErrorMessage]=\"labelData.ariaErrorMessage\"\n            [ariaHasPopup]=\"labelData.ariaHasPopup\"\n            [tabindex]=\"labelData.tabindex\"></desy-label>\n<desy-label *ngIf=\"!labelRef && !labelData && labelText\" [text]=\"labelText\" classes=\"sr-only\" [for]=\"id\"></desy-label>\n\n<div class=\"relative\" [ngClass]=\"{'flex flex-wrap items-end gap-sm': hasButton()}\">\n  <input type=\"search\"\n         [class]=\"['c-input block border-black rounded font-semibold placeholder-neutral-dark focus:border-black focus:shadow-outline-focus-input focus:ring-4 focus:ring-warning-base disabled:bg-neutral-light disabled:border-neutral-base', classes] | makeHtmlList\"\n         [ngClass]=\"{'border-alert-base ring-2 ring-alert-base': hasErrorsMessage(),'pr-12 w-full': !hasButton()}\"\n         [value]=\"value\" (input)=\"onInput($event)\"\n         [attr.id]=\"id ? id : null\"\n         [attr.name]=\"id ? id : null\"\n         [attr.aria-describedby]=\"[describedBy, getErrorId()] | makeHtmlList:null\"\n         [attr.aria-errormessage]=\"hasErrorsMessage() ? getErrorId() : null\"\n         [attr.aria-invalid]=\"hasErrorsMessage() ? true : null\"\n         [attr.disabled]=\"disabled ? true : null\"\n         [desyAppAccessibility]=\"this\">\n  <ng-container *ngIf=\"hasButton(); else defaultButton\">\n    <ng-content select=\"desy-button\"></ng-content>\n  </ng-container>\n  <ng-template #defaultButton>\n    <button type=\"submit\" [attr.disabled]=\"disabled ? 'disabled' : null\" [attr.aria-disabled]=\"disabled ? 'true' : null\"\n            (click)=\"onClick($event)\"\n            [class]=\"['absolute top-0 right-0 m-sm p-0.5 text-primary-base hover:text-primary-dark focus:bg-warning-base focus:outline-none focus:shadow-outline-focus', buttonClasses] | makeHtmlList\">\n      <span class=\"sr-only\">Buscar</span>\n      <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\" width=\"1.375em\" height=\"1.375em\" aria-hidden=\"true\"><path d=\"M23.498 23.487a1.713 1.713 0 000-2.421l-4.572-4.575a.43.43 0 01-.062-.539 10.283 10.283 0 10-2.911 2.911.43.43 0 01.539.055l4.574 4.574a1.712 1.712 0 002.433-.005zM3.451 10.289a6.85 6.85 0 116.85 6.85 6.85 6.85 0 01-6.85-6.85z\" fill=\"currentColor\"/></svg>\n    </button>\n  </ng-template>\n  <ng-content select=\"desy-error-message\"></ng-content>\n  <ng-container *ngTemplateOutlet=\"errorMessageRef\"></ng-container>\n  <desy-error-message *ngIf=\"!errorMessageRef && errorMessageData\"\n                      [id]=\"getErrorId()\"\n                      [text]=\"errorMessageData.text\"\n                      [html]=\"errorMessageData.html\"\n                      [classes]=\"errorMessageData.classes\"\n                      [visuallyHiddenText]=\"errorMessageData.visuallyHiddenText\"\n                      [role]=\"errorMessageData.role\"\n                      [ariaLabel]=\"errorMessageData.ariaLabel\"\n                      [ariaDescribedBy]=\"errorMessageData.ariaDescribedBy\"\n                      [ariaLabelledBy]=\"errorMessageData.ariaLabelledBy\"\n                      [ariaHidden]=\"errorMessageData.ariaHidden\"\n                      [ariaDisabled]=\"errorMessageData.ariaDisabled\"\n                      [ariaControls]=\"errorMessageData.ariaControls\"\n                      [ariaCurrent]=\"errorMessageData.ariaCurrent\"\n                      [ariaLive]=\"errorMessageData.ariaLive\"\n                      [ariaExpanded]=\"errorMessageData.ariaExpanded\"\n                      [ariaErrorMessage]=\"errorMessageData.ariaErrorMessage\"\n                      [ariaHasPopup]=\"errorMessageData.ariaHasPopup\"\n                      [tabindex]=\"errorMessageData.tabindex\"></desy-error-message>\n  <desy-error-message *ngIf=\"!errorMessageRef && !errorMessageData && errorMessageText\"\n                      [text]=\"errorMessageText\" [id]=\"getErrorId()\"></desy-error-message>\n</div>\n<!-- /searchbar -->\n"]}
@@ -40,7 +40,7 @@ export class SelectComponent extends FormFieldComponent {
40
40
  return items;
41
41
  }
42
42
  isItemSelected(item) {
43
- return this.value ? this.value == item.value : item.selected;
43
+ return this.value !== undefined ? this.value == item.value : item.selected;
44
44
  }
45
45
  isOptionGroup(item) {
46
46
  return item instanceof OptionGroupComponent;
@@ -91,4 +91,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
91
91
  type: ContentChildren,
92
92
  args: [SelectItemComponent]
93
93
  }] } });
94
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../../projects/desy-angular/src/lib/desy-forms/components/select/select.component.ts","../../../../../../../projects/desy-angular/src/lib/desy-forms/components/select/select.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAoB,SAAS,EAAE,eAAe,EAAE,WAAW,EAAE,KAAK,EAAa,SAAS,EAAiB,UAAU,EAAE,MAAM,eAAe,CAAC;AAClJ,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAGnD,OAAO,EAAE,kBAAkB,EAAE,MAAM,oCAAoC,CAAC;AACxE,OAAO,EAAE,oBAAoB,EAAE,MAAM,uCAAuC,CAAC;AAC7E,OAAO,EAAE,mBAAmB,EAAE,MAAM,qCAAqC,CAAC;;;;;;;;;;AAa1E,MAAM,OAAO,eAAgB,SAAQ,kBAAuB;IAX5D;;QAmBqC,QAAG,GAAG,IAAI,CAAC;QAO9C,gBAAW,GAAG,KAAK,CAAC;KAyCrB;IAvCC,WAAW,CAAC,OAAsB;QAChC,IAAI,CAAC,IAAI,GAAG,CAAC,IAAI,CAAC,gBAAgB,EAAE,IAAI,IAAI,CAAC,gBAAgB,KAAK,qBAAqB,CAAC,CAAC;IAC3F,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;YAChB,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;YAC9B,MAAM,YAAY,GAAG,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YACxD,IAAI,YAAY,EAAE,CAAC;gBACjB,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,CAAC;YACxD,CAAC;QACH,CAAC;IACH,CAAC;IAED,UAAU,CAAC,KAAU;QACnB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACvB,CAAC;IAED,QAAQ;QACN,MAAM,KAAK,GAAI,CAAC,IAAI,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC;QAC7F,OAAO,KAAK,CAAC;IACf,CAAC;IAED,cAAc,CAAC,IAAoB;QACjC,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC;IAC/D,CAAC;IAED,aAAa,CAAC,IAAoB;QAChC,OAAO,IAAI,YAAY,oBAAoB,CAAC;IAC9C,CAAC;IAED,OAAO,CAAC,KAAY;QAClB,IAAI,KAAK,GAAI,KAAK,CAAC,MAA4B,CAAC,KAAK,CAAA;QACrD,IAAI,CAAC,KAAK,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,IAAI,KAAK,IAAI,IAAI,IAAI,KAAK,IAAI,EAAE,IAAI,KAAK,IAAI,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;QACjH,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC5B,CAAC;+GAtDU,eAAe;mGAAf,eAAe,8SARf;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,eAAe,CAAC;gBAC9C,KAAK,EAAE,IAAI;aACZ;SACF,yDAgBgB,mBAAmB,yECjCtC,wiMAgHS;;4FD7FI,eAAe;kBAX3B,SAAS;+BACE,aAAa,aAEZ;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,gBAAgB,CAAC;4BAC9C,KAAK,EAAE,IAAI;yBACZ;qBACF;8BAIQ,IAAI;sBAAZ,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBAI6B,GAAG;sBAArC,WAAW;uBAAC,oBAAoB;gBACS,IAAI;sBAA7C,WAAW;uBAAC,2BAA2B;gBACT,gBAAgB;sBAA9C,KAAK;;sBAAI,WAAW;uBAAC,OAAO;gBAEpB,OAAO;sBAAf,KAAK;gBAEgC,cAAc;sBAAnD,eAAe;uBAAC,mBAAmB","sourcesContent":["import { AfterContentInit, Component, ContentChildren, HostBinding, Input, OnChanges, QueryList, SimpleChanges, forwardRef } from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { SelectItemData } from '../../interfaces';\nimport { FormFieldComponent } from '../form-field/form-field.component';\nimport { OptionGroupComponent } from './option-group/option-group.component';\nimport { SelectItemComponent } from './select-item/select-item.component';\n\n@Component({\n  selector: 'desy-select',\n  templateUrl: './select.component.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => SelectComponent),\n      multi: true\n    }\n  ]\n})\nexport class SelectComponent extends FormFieldComponent<any> implements AfterContentInit, OnChanges {\n\n  @Input() name: string;\n  @Input() items: SelectItemData[];\n  @Input() describedBy?: string;\n\n\n  //  form group class - asignar clases a la etiqueta desy-select\n  @HostBinding('class.c-form-group') cfg = true;\n  @HostBinding('class.c-form-group--error') cfgr: boolean;\n  @Input() @HostBinding('class') formGroupClasses: any;\n\n  @Input() classes: string;\n\n  @ContentChildren(SelectItemComponent) itemComponents: QueryList<SelectItemComponent>;\n  contentInit = false;\n\n  ngOnChanges(changes: SimpleChanges): void {\n    this.cfgr = (this.hasErrorsMessage() || this.formGroupClasses === 'c-form-group--error');\n  }\n\n  ngAfterContentInit(): void {\n    this.contentInit = true;\n    if (!this.value) {\n      const items = this.getItems();\n      const itemSelected = items?.find(item => item.selected);\n      if (itemSelected) {\n        setTimeout(() => this.writeValue(itemSelected.value));\n      }\n    }\n  }\n\n  writeValue(value: any): void {\n    this.value = value;\n    this.onChange(value);\n  }\n\n  getItems(): SelectItemData[] {\n    const items =  (this.itemComponents.length > 0) ? this.itemComponents.toArray() : this.items;\n    return items;\n  }\n\n  isItemSelected(item: SelectItemData): boolean {\n    return this.value ? this.value == item.value : item.selected;\n  }\n\n  isOptionGroup(item: SelectItemData): boolean {\n    return item instanceof OptionGroupComponent;\n  }\n\n  onInput(event: Event): void {\n    let value = (event.target as HTMLSelectElement).value\n    this.value = !isNaN(Number(value)) && value != null && value != \"\" && value != undefined ? Number(value) : value;\n    this.onChange(this.value);\n  }\n\n}\n","<ng-container *ngIf=\"labelComponent\">\n  <ng-content select=\"desy-label\"></ng-content>\n</ng-container>\n<ng-container *ngTemplateOutlet=\"labelRef\"></ng-container>\n<desy-label *ngIf=\"!labelRef && labelData && !labelComponent\"\n            [text]=\"labelData.text\"\n            [html]=\"labelData.html\"\n            [classes]=\"labelData.classes\"\n            [isPageHeading]=\"labelData.isPageHeading\"\n            [for]=\"id\"\n            [role]=\"labelData.role\"\n            [ariaLabel]=\"labelData.ariaLabel\"\n            [ariaDescribedBy]=\"labelData.ariaDescribedBy\"\n            [ariaLabelledBy]=\"labelData.ariaLabelledBy\"\n            [ariaHidden]=\"labelData.ariaHidden\"\n            [ariaDisabled]=\"labelData.ariaDisabled\"\n            [ariaControls]=\"labelData.ariaControls\"\n            [ariaCurrent]=\"labelData.ariaCurrent\"\n            [ariaLive]=\"labelData.ariaLive\"\n            [ariaExpanded]=\"labelData.ariaExpanded\"\n            [ariaErrorMessage]=\"labelData.ariaErrorMessage\"\n            [ariaHasPopup]=\"labelData.ariaHasPopup\"\n            [tabindex]=\"labelData.tabindex\"></desy-label>\n<desy-label *ngIf=\"!labelRef && !labelData && labelText && !labelComponent\"\n            [text]=\"labelText\"\n            [for]=\"id\"></desy-label>\n<ng-container *ngTemplateOutlet=\"hintRef\"></ng-container>\n<ng-container *ngIf=\"hintComponent\">\n  <ng-content select=\"desy-hint\"></ng-content>\n</ng-container>\n<desy-hint *ngIf=\"!hintRef && hintData && !hintComponent\"\n           [id]=\"getHintId()\"\n           [text]=\"hintData.text\"\n           [html]=\"hintData.html\"\n           [classes]=\"hintData.classes\"\n           [role]=\"hintData.role\"\n           [ariaLabel]=\"hintData.ariaLabel\"\n           [ariaDescribedBy]=\"hintData.ariaDescribedBy\"\n           [ariaLabelledBy]=\"hintData.ariaLabelledBy\"\n           [ariaHidden]=\"hintData.ariaHidden\"\n           [ariaDisabled]=\"hintData.ariaDisabled\"\n           [ariaControls]=\"hintData.ariaControls\"\n           [ariaCurrent]=\"hintData.ariaCurrent\"\n           [ariaLive]=\"hintData.ariaLive\"\n           [ariaExpanded]=\"hintData.ariaExpanded\"\n           [ariaErrorMessage]=\"hintData.ariaErrorMessage\"\n           [ariaHasPopup]=\"hintData.ariaHasPopup\"\n           [tabindex]=\"hintData.tabindex\"></desy-hint>\n<desy-hint *ngIf=\"!hintRef && !hintData && hintText && !hintComponent\"\n           [text]=\"hintText\"\n           [id]=\"getHintId()\"></desy-hint>\n\n<ng-container *ngIf=\"errorMessageComponent\">\n  <ng-content select=\"desy-error-message\"></ng-content>\n</ng-container>\n<ng-container *ngTemplateOutlet=\"errorMessageRef\"></ng-container>\n<desy-error-message *ngIf=\"!errorMessageRef && errorMessageData && !errorMessageComponent\"\n                    [id]=\"getErrorId()\"\n                    [text]=\"errorMessageData.text\"\n                    [html]=\"errorMessageData.html\"\n                    [classes]=\"errorMessageData.classes\"\n                    [visuallyHiddenText]=\"errorMessageData.visuallyHiddenText\"\n                    [role]=\"errorMessageData.role\"\n                    [ariaLabel]=\"errorMessageData.ariaLabel\"\n                    [ariaDescribedBy]=\"errorMessageData.ariaDescribedBy\"\n                    [ariaLabelledBy]=\"errorMessageData.ariaLabelledBy\"\n                    [ariaHidden]=\"errorMessageData.ariaHidden\"\n                    [ariaDisabled]=\"errorMessageData.ariaDisabled\"\n                    [ariaControls]=\"errorMessageData.ariaControls\"\n                    [ariaCurrent]=\"errorMessageData.ariaCurrent\"\n                    [ariaLive]=\"errorMessageData.ariaLive\"\n                    [ariaExpanded]=\"errorMessageData.ariaExpanded\"\n                    [ariaErrorMessage]=\"errorMessageData.ariaErrorMessage\"\n                    [ariaHasPopup]=\"errorMessageData.ariaHasPopup\"\n                    [tabindex]=\"errorMessageData.tabindex\"></desy-error-message>\n<desy-error-message *ngIf=\"!errorMessageRef && !errorMessageData && !errorMessageComponent && errorMessageText\"\n                    [text]=\"errorMessageText\"\n                    [id]=\"getErrorId()\"></desy-error-message>\n<select [class]=\"['c-select block mt-sm transition duration-150 ease-in-out border-black rounded font-semibold focus:border-black focus:shadow-outline-focus-input focus:ring-4 focus:ring-warning-base disabled:bg-neutral-light disabled:border-neutral-base',\n              classes,\n              hasErrorsMessage() ? 'c-select--error border-alert-base ring-2 ring-alert-base' : null] | makeHtmlList\"\n        [value]=\"value\"\n        (input)=\"onInput($event)\"\n        [attr.id]=\"id ? id : null\"\n        [attr.name]=\"name ? name : null\"\n        [attr.aria-describedby]=\"[ariaDescribedBy, describedBy, getHintId(), getErrorId()] | makeHtmlList:null\"\n        [attr.aria-errormessage]=\"ariaErrorMessage ? ariaErrorMessage : (hasErrorsMessage() ? getErrorId() : null)\"\n        [attr.aria-invalid]=\"(hasErrorsMessage() || ariaErrorMessage) ? true : null\"\n        [disabled]=\"disabled\"\n        [desyAppAccessibility]=\"this\">\n\n  <ng-container *ngFor=\"let item of getItems()\">\n    <optgroup *ngIf=\"isOptionGroup(item)\"\n              [label]=\"item?.label\"\n              [attr.disabled]=\"item.disabled ? true : null\"\n              [desyAppAccessibility]=\"item\">\n      <option *ngFor=\"let subItem of item.items\"\n              [value]=\"subItem.value\"\n              [disabled]=\"subItem.disabled\"\n              [selected]=\"isItemSelected(subItem)\"\n              [desyAppAccessibility]=\"subItem\">\n        <ng-container *desyCustomInnerContent=\"{ component: subItem, text: subItem.text }\"></ng-container>\n      </option>\n    </optgroup>\n    <option *ngIf=\"!isOptionGroup(item)\"\n            [value]=\"item.value\"\n            [disabled]=\"item.disabled ? true : null\"\n            [selected]=\"isItemSelected(item)\"\n            [desyAppAccessibility]=\"item\">\n      <ng-container *desyCustomInnerContent=\"{ component: item, text: item.text }\"></ng-container>\n    </option>\n  </ng-container>\n</select>"]}
94
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../../projects/desy-angular/src/lib/desy-forms/components/select/select.component.ts","../../../../../../../projects/desy-angular/src/lib/desy-forms/components/select/select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterContentInit, Component, ContentChildren, HostBinding, Input, OnChanges, QueryList, SimpleChanges, forwardRef } from '@angular/core';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\n\nimport { SelectItemData } from '../../interfaces';\nimport { FormFieldComponent } from '../form-field/form-field.component';\nimport { OptionGroupComponent } from './option-group/option-group.component';\nimport { SelectItemComponent } from './select-item/select-item.component';\n\n@Component({\n  selector: 'desy-select',\n  templateUrl: './select.component.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => SelectComponent),\n      multi: true\n    }\n  ]\n})\nexport class SelectComponent extends FormFieldComponent<any> implements AfterContentInit, OnChanges {\n\n  @Input() name: string;\n  @Input() items: SelectItemData[];\n  @Input() describedBy?: string;\n\n\n  //  form group class - asignar clases a la etiqueta desy-select\n  @HostBinding('class.c-form-group') cfg = true;\n  @HostBinding('class.c-form-group--error') cfgr: boolean;\n  @Input() @HostBinding('class') formGroupClasses: any;\n\n  @Input() classes: string;\n\n  @ContentChildren(SelectItemComponent) itemComponents: QueryList<SelectItemComponent>;\n  contentInit = false;\n\n  ngOnChanges(changes: SimpleChanges): void {\n    this.cfgr = (this.hasErrorsMessage() || this.formGroupClasses === 'c-form-group--error');\n  }\n\n  ngAfterContentInit(): void {\n    this.contentInit = true;\n    if (!this.value) {\n      const items = this.getItems();\n      const itemSelected = items?.find(item => item.selected);\n      if (itemSelected) {\n        setTimeout(() => this.writeValue(itemSelected.value));\n      }\n    }\n  }\n\n  writeValue(value: any): void {\n    this.value = value;\n    this.onChange(value);\n  }\n\n  getItems(): SelectItemData[] {\n    const items =  (this.itemComponents.length > 0) ? this.itemComponents.toArray() : this.items;\n    return items;\n  }\n\n  isItemSelected(item: SelectItemData): boolean {\n    return this.value !== undefined ? this.value == item.value : item.selected;\n  }\n\n  isOptionGroup(item: SelectItemData): boolean {\n    return item instanceof OptionGroupComponent;\n  }\n\n  onInput(event: Event): void {\n    let value = (event.target as HTMLSelectElement).value\n    this.value = !isNaN(Number(value)) && value != null && value != \"\" && value != undefined ? Number(value) : value;\n    this.onChange(this.value);\n  }\n\n}\n","<ng-container *ngIf=\"labelComponent\">\n  <ng-content select=\"desy-label\"></ng-content>\n</ng-container>\n<ng-container *ngTemplateOutlet=\"labelRef\"></ng-container>\n<desy-label *ngIf=\"!labelRef && labelData && !labelComponent\"\n            [text]=\"labelData.text\"\n            [html]=\"labelData.html\"\n            [classes]=\"labelData.classes\"\n            [isPageHeading]=\"labelData.isPageHeading\"\n            [for]=\"id\"\n            [role]=\"labelData.role\"\n            [ariaLabel]=\"labelData.ariaLabel\"\n            [ariaDescribedBy]=\"labelData.ariaDescribedBy\"\n            [ariaLabelledBy]=\"labelData.ariaLabelledBy\"\n            [ariaHidden]=\"labelData.ariaHidden\"\n            [ariaDisabled]=\"labelData.ariaDisabled\"\n            [ariaControls]=\"labelData.ariaControls\"\n            [ariaCurrent]=\"labelData.ariaCurrent\"\n            [ariaLive]=\"labelData.ariaLive\"\n            [ariaExpanded]=\"labelData.ariaExpanded\"\n            [ariaErrorMessage]=\"labelData.ariaErrorMessage\"\n            [ariaHasPopup]=\"labelData.ariaHasPopup\"\n            [tabindex]=\"labelData.tabindex\"></desy-label>\n<desy-label *ngIf=\"!labelRef && !labelData && labelText && !labelComponent\"\n            [text]=\"labelText\"\n            [for]=\"id\"></desy-label>\n<ng-container *ngTemplateOutlet=\"hintRef\"></ng-container>\n<ng-container *ngIf=\"hintComponent\">\n  <ng-content select=\"desy-hint\"></ng-content>\n</ng-container>\n<desy-hint *ngIf=\"!hintRef && hintData && !hintComponent\"\n           [id]=\"getHintId()\"\n           [text]=\"hintData.text\"\n           [html]=\"hintData.html\"\n           [classes]=\"hintData.classes\"\n           [role]=\"hintData.role\"\n           [ariaLabel]=\"hintData.ariaLabel\"\n           [ariaDescribedBy]=\"hintData.ariaDescribedBy\"\n           [ariaLabelledBy]=\"hintData.ariaLabelledBy\"\n           [ariaHidden]=\"hintData.ariaHidden\"\n           [ariaDisabled]=\"hintData.ariaDisabled\"\n           [ariaControls]=\"hintData.ariaControls\"\n           [ariaCurrent]=\"hintData.ariaCurrent\"\n           [ariaLive]=\"hintData.ariaLive\"\n           [ariaExpanded]=\"hintData.ariaExpanded\"\n           [ariaErrorMessage]=\"hintData.ariaErrorMessage\"\n           [ariaHasPopup]=\"hintData.ariaHasPopup\"\n           [tabindex]=\"hintData.tabindex\"></desy-hint>\n<desy-hint *ngIf=\"!hintRef && !hintData && hintText && !hintComponent\"\n           [text]=\"hintText\"\n           [id]=\"getHintId()\"></desy-hint>\n\n<ng-container *ngIf=\"errorMessageComponent\">\n  <ng-content select=\"desy-error-message\"></ng-content>\n</ng-container>\n<ng-container *ngTemplateOutlet=\"errorMessageRef\"></ng-container>\n<desy-error-message *ngIf=\"!errorMessageRef && errorMessageData && !errorMessageComponent\"\n                    [id]=\"getErrorId()\"\n                    [text]=\"errorMessageData.text\"\n                    [html]=\"errorMessageData.html\"\n                    [classes]=\"errorMessageData.classes\"\n                    [visuallyHiddenText]=\"errorMessageData.visuallyHiddenText\"\n                    [role]=\"errorMessageData.role\"\n                    [ariaLabel]=\"errorMessageData.ariaLabel\"\n                    [ariaDescribedBy]=\"errorMessageData.ariaDescribedBy\"\n                    [ariaLabelledBy]=\"errorMessageData.ariaLabelledBy\"\n                    [ariaHidden]=\"errorMessageData.ariaHidden\"\n                    [ariaDisabled]=\"errorMessageData.ariaDisabled\"\n                    [ariaControls]=\"errorMessageData.ariaControls\"\n                    [ariaCurrent]=\"errorMessageData.ariaCurrent\"\n                    [ariaLive]=\"errorMessageData.ariaLive\"\n                    [ariaExpanded]=\"errorMessageData.ariaExpanded\"\n                    [ariaErrorMessage]=\"errorMessageData.ariaErrorMessage\"\n                    [ariaHasPopup]=\"errorMessageData.ariaHasPopup\"\n                    [tabindex]=\"errorMessageData.tabindex\"></desy-error-message>\n<desy-error-message *ngIf=\"!errorMessageRef && !errorMessageData && !errorMessageComponent && errorMessageText\"\n                    [text]=\"errorMessageText\"\n                    [id]=\"getErrorId()\"></desy-error-message>\n<select [class]=\"['c-select block mt-sm transition duration-150 ease-in-out border-black rounded font-semibold focus:border-black focus:shadow-outline-focus-input focus:ring-4 focus:ring-warning-base disabled:bg-neutral-light disabled:border-neutral-base',\n              classes,\n              hasErrorsMessage() ? 'c-select--error border-alert-base ring-2 ring-alert-base' : null] | makeHtmlList\"\n        [value]=\"value\"\n        (input)=\"onInput($event)\"\n        [attr.id]=\"id ? id : null\"\n        [attr.name]=\"name ? name : null\"\n        [attr.aria-describedby]=\"[ariaDescribedBy, describedBy, getHintId(), getErrorId()] | makeHtmlList:null\"\n        [attr.aria-errormessage]=\"ariaErrorMessage ? ariaErrorMessage : (hasErrorsMessage() ? getErrorId() : null)\"\n        [attr.aria-invalid]=\"(hasErrorsMessage() || ariaErrorMessage) ? true : null\"\n        [disabled]=\"disabled\"\n        [desyAppAccessibility]=\"this\">\n\n  <ng-container *ngFor=\"let item of getItems()\">\n    <optgroup *ngIf=\"isOptionGroup(item)\"\n              [label]=\"item?.label\"\n              [attr.disabled]=\"item.disabled ? true : null\"\n              [desyAppAccessibility]=\"item\">\n      <option *ngFor=\"let subItem of item.items\"\n              [value]=\"subItem.value\"\n              [disabled]=\"subItem.disabled\"\n              [selected]=\"isItemSelected(subItem)\"\n              [desyAppAccessibility]=\"subItem\">\n        <ng-container *desyCustomInnerContent=\"{ component: subItem, text: subItem.text }\"></ng-container>\n      </option>\n    </optgroup>\n    <option *ngIf=\"!isOptionGroup(item)\"\n            [value]=\"item.value\"\n            [disabled]=\"item.disabled ? true : null\"\n            [selected]=\"isItemSelected(item)\"\n            [desyAppAccessibility]=\"item\">\n      <ng-container *desyCustomInnerContent=\"{ component: item, text: item.text }\"></ng-container>\n    </option>\n  </ng-container>\n</select>"]}
@@ -1,12 +1,16 @@
1
1
  import { __decorate, __metadata } from "tslib";
2
- import { ContentComponent } from './../../../../desy-commons/components/content/content.component';
3
- import { TableAdvancedSelectComponent } from './table-advanced-select.component';
4
- import { DesyContentChild } from '../../../../shared/decorators/desy-content-child.decorator';
5
2
  import { Component, ContentChildren, Input } from '@angular/core';
6
- import { OrderBy } from '../../../interfaces';
7
3
  import { ContentBaseComponent } from '../../../../shared/components';
4
+ import { DesyContentChild } from '../../../../shared/decorators/desy-content-child.decorator';
5
+ import { OrderBy } from '../../../interfaces';
6
+ import { ContentComponent } from './../../../../desy-commons/components/content/content.component';
7
+ import { TableAdvancedSelectComponent } from './table-advanced-select.component';
8
8
  import * as i0 from "@angular/core";
9
9
  export class TableAdvancedHeaderCellComponent extends ContentBaseComponent {
10
+ constructor() {
11
+ super(...arguments);
12
+ this.valueFilter = null;
13
+ }
10
14
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TableAdvancedHeaderCellComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
11
15
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: TableAdvancedHeaderCellComponent, selector: "desy-table-advanced-header-cell", inputs: { classes: "classes", id: "id", colspan: "colspan", rowspan: "rowspan", orderBy: "orderBy", hasFilter: "hasFilter", filterClasses: "filterClasses", hasSelect: "hasSelect", identifier: "identifier" }, queries: [{ propertyName: "selectComponent", predicate: TableAdvancedSelectComponent }, { propertyName: "contentComponent", predicate: ContentComponent }], usesInheritance: true, ngImport: i0, template: '<ng-template #contentTemplate><ng-content></ng-content></ng-template>', isInline: true }); }
12
16
  }
@@ -49,4 +53,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
49
53
  type: ContentChildren,
50
54
  args: [ContentComponent]
51
55
  }] } });
52
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtYWR2YW5jZWQtaGVhZGVyLWNlbGwuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGVzeS1hbmd1bGFyL3NyYy9saWIvZGVzeS10YWJsZXMvY29tcG9uZW50cy90YWJsZS1hZHZhbmNlZC9jb21wb25lbnRzL3RhYmxlLWFkdmFuY2VkLWhlYWRlci1jZWxsLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0saUVBQWlFLENBQUM7QUFDbkcsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFDakYsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sNERBQTRELENBQUM7QUFDOUYsT0FBTyxFQUFDLFNBQVMsRUFBRSxlQUFlLEVBQUUsS0FBSyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ2hFLE9BQU8sRUFBb0IsT0FBTyxFQUFDLE1BQU0scUJBQXFCLENBQUM7QUFDL0QsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sK0JBQStCLENBQUM7O0FBTW5FLE1BQU0sT0FBTyxnQ0FBaUMsU0FBUSxvQkFBb0I7K0dBQTdELGdDQUFnQzttR0FBaEMsZ0NBQWdDLHVUQWdCMUIsNEJBQTRCLG1EQUc1QixnQkFBZ0Isb0RBckJ2Qix1RUFBdUU7O0FBa0JsQztJQUQ5QyxnQkFBZ0IsRUFBRTs4QkFDOEMsNEJBQTRCO3lFQUFDO0FBRzNEO0lBRGxDLGdCQUFnQixFQUFFOzhCQUNtQyxnQkFBZ0I7MEVBQUM7NEZBbkI1RCxnQ0FBZ0M7a0JBSjVDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGlDQUFpQztvQkFDM0MsUUFBUSxFQUFFLHVFQUF1RTtpQkFDbEY7OEJBRVUsT0FBTztzQkFBZixLQUFLO2dCQUNHLEVBQUU7c0JBQVYsS0FBSztnQkFDRyxPQUFPO3NCQUFmLEtBQUs7Z0JBQ0csT0FBTztzQkFBZixLQUFLO2dCQUNHLE9BQU87c0JBQWYsS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUNHLGFBQWE7c0JBQXJCLEtBQUs7Z0JBQ0csU0FBUztzQkFBakIsS0FBSztnQkFDRyxVQUFVO3NCQUFsQixLQUFLO2dCQU95QyxlQUFlO3NCQUE3RCxlQUFlO3VCQUFDLDRCQUE0QjtnQkFHVixnQkFBZ0I7c0JBQWxELGVBQWU7dUJBQUMsZ0JBQWdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29udGVudENvbXBvbmVudCB9IGZyb20gJy4vLi4vLi4vLi4vLi4vZGVzeS1jb21tb25zL2NvbXBvbmVudHMvY29udGVudC9jb250ZW50LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBUYWJsZUFkdmFuY2VkU2VsZWN0Q29tcG9uZW50IH0gZnJvbSAnLi90YWJsZS1hZHZhbmNlZC1zZWxlY3QuY29tcG9uZW50JztcbmltcG9ydCB7IERlc3lDb250ZW50Q2hpbGQgfSBmcm9tICcuLi8uLi8uLi8uLi9zaGFyZWQvZGVjb3JhdG9ycy9kZXN5LWNvbnRlbnQtY2hpbGQuZGVjb3JhdG9yJztcbmltcG9ydCB7Q29tcG9uZW50LCBDb250ZW50Q2hpbGRyZW4sIElucHV0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7SGVhZENlbGxNb2RlbERhdGEsIE9yZGVyQnl9IGZyb20gJy4uLy4uLy4uL2ludGVyZmFjZXMnO1xuaW1wb3J0IHtDb250ZW50QmFzZUNvbXBvbmVudH0gZnJvbSAnLi4vLi4vLi4vLi4vc2hhcmVkL2NvbXBvbmVudHMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdkZXN5LXRhYmxlLWFkdmFuY2VkLWhlYWRlci1jZWxsJyxcbiAgdGVtcGxhdGU6ICc8bmctdGVtcGxhdGUgI2NvbnRlbnRUZW1wbGF0ZT48bmctY29udGVudD48L25nLWNvbnRlbnQ+PC9uZy10ZW1wbGF0ZT4nXG59KVxuZXhwb3J0IGNsYXNzIFRhYmxlQWR2YW5jZWRIZWFkZXJDZWxsQ29tcG9uZW50IGV4dGVuZHMgQ29udGVudEJhc2VDb21wb25lbnQgaW1wbGVtZW50cyBIZWFkQ2VsbE1vZGVsRGF0YSB7XG4gIEBJbnB1dCgpIGNsYXNzZXM6IHN0cmluZztcbiAgQElucHV0KCkgaWQ6IHN0cmluZztcbiAgQElucHV0KCkgY29sc3BhbjogbnVtYmVyO1xuICBASW5wdXQoKSByb3dzcGFuOiBudW1iZXI7XG4gIEBJbnB1dCgpIG9yZGVyQnk6IE9yZGVyQnk7IC8vIFBvc3NpYmxlIHZhbHVlcyBgbm9uZWAsIGBhc2NgLCBgZGVzY2AuXG4gIEBJbnB1dCgpIGhhc0ZpbHRlcjogYm9vbGVhbjtcbiAgQElucHV0KCkgZmlsdGVyQ2xhc3Nlczogc3RyaW5nO1xuICBASW5wdXQoKSBoYXNTZWxlY3Q/OiBib29sZWFuO1xuICBASW5wdXQoKSBpZGVudGlmaWVyPzogc3RyaW5nO1xuICB2YWx1ZUZpbHRlcj86IHN0cmluZztcbiAgYWN0aXZlRmlsdGVyPzogYm9vbGVhbjtcbiAgdmFsdWVTZWxlY3Q/OiBzdHJpbmc7XG4gIGFjdGl2ZVNlbGVjdD86IGJvb2xlYW47XG5cbiAgQERlc3lDb250ZW50Q2hpbGQoKVxuICBAQ29udGVudENoaWxkcmVuKFRhYmxlQWR2YW5jZWRTZWxlY3RDb21wb25lbnQpIHNlbGVjdENvbXBvbmVudD86IFRhYmxlQWR2YW5jZWRTZWxlY3RDb21wb25lbnQ7XG5cbiAgQERlc3lDb250ZW50Q2hpbGQoKVxuICBAQ29udGVudENoaWxkcmVuKENvbnRlbnRDb21wb25lbnQpIGNvbnRlbnRDb21wb25lbnQ/OiBDb250ZW50Q29tcG9uZW50O1xufVxuIl19
56
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtYWR2YW5jZWQtaGVhZGVyLWNlbGwuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZGVzeS1hbmd1bGFyL3NyYy9saWIvZGVzeS10YWJsZXMvY29tcG9uZW50cy90YWJsZS1hZHZhbmNlZC9jb21wb25lbnRzL3RhYmxlLWFkdmFuY2VkLWhlYWRlci1jZWxsLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxlQUFlLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2xFLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQ3JFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDREQUE0RCxDQUFDO0FBQzlGLE9BQU8sRUFBcUIsT0FBTyxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDakUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0saUVBQWlFLENBQUM7QUFDbkcsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sbUNBQW1DLENBQUM7O0FBTWpGLE1BQU0sT0FBTyxnQ0FBaUMsU0FBUSxvQkFBb0I7SUFKMUU7O1FBY0UsZ0JBQVcsR0FBbUIsSUFBSSxDQUFDO0tBVXBDOytHQXBCWSxnQ0FBZ0M7bUdBQWhDLGdDQUFnQyx1VEFnQjFCLDRCQUE0QixtREFHNUIsZ0JBQWdCLG9EQXJCdkIsdUVBQXVFOztBQWtCbEM7SUFEOUMsZ0JBQWdCLEVBQUU7OEJBQzhDLDRCQUE0Qjt5RUFBQztBQUczRDtJQURsQyxnQkFBZ0IsRUFBRTs4QkFDbUMsZ0JBQWdCOzBFQUFDOzRGQW5CNUQsZ0NBQWdDO2tCQUo1QyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxpQ0FBaUM7b0JBQzNDLFFBQVEsRUFBRSx1RUFBdUU7aUJBQ2xGOzhCQUVVLE9BQU87c0JBQWYsS0FBSztnQkFDRyxFQUFFO3NCQUFWLEtBQUs7Z0JBQ0csT0FBTztzQkFBZixLQUFLO2dCQUNHLE9BQU87c0JBQWYsS0FBSztnQkFDRyxPQUFPO3NCQUFmLEtBQUs7Z0JBQ0csU0FBUztzQkFBakIsS0FBSztnQkFDRyxhQUFhO3NCQUFyQixLQUFLO2dCQUNHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBQ0csVUFBVTtzQkFBbEIsS0FBSztnQkFPeUMsZUFBZTtzQkFBN0QsZUFBZTt1QkFBQyw0QkFBNEI7Z0JBR1YsZ0JBQWdCO3NCQUFsRCxlQUFlO3VCQUFDLGdCQUFnQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgQ29udGVudENoaWxkcmVuLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29udGVudEJhc2VDb21wb25lbnQgfSBmcm9tICcuLi8uLi8uLi8uLi9zaGFyZWQvY29tcG9uZW50cyc7XG5pbXBvcnQgeyBEZXN5Q29udGVudENoaWxkIH0gZnJvbSAnLi4vLi4vLi4vLi4vc2hhcmVkL2RlY29yYXRvcnMvZGVzeS1jb250ZW50LWNoaWxkLmRlY29yYXRvcic7XG5pbXBvcnQgeyBIZWFkQ2VsbE1vZGVsRGF0YSwgT3JkZXJCeSB9IGZyb20gJy4uLy4uLy4uL2ludGVyZmFjZXMnO1xuaW1wb3J0IHsgQ29udGVudENvbXBvbmVudCB9IGZyb20gJy4vLi4vLi4vLi4vLi4vZGVzeS1jb21tb25zL2NvbXBvbmVudHMvY29udGVudC9jb250ZW50LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBUYWJsZUFkdmFuY2VkU2VsZWN0Q29tcG9uZW50IH0gZnJvbSAnLi90YWJsZS1hZHZhbmNlZC1zZWxlY3QuY29tcG9uZW50JztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZGVzeS10YWJsZS1hZHZhbmNlZC1oZWFkZXItY2VsbCcsXG4gIHRlbXBsYXRlOiAnPG5nLXRlbXBsYXRlICNjb250ZW50VGVtcGxhdGU+PG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PjwvbmctdGVtcGxhdGU+J1xufSlcbmV4cG9ydCBjbGFzcyBUYWJsZUFkdmFuY2VkSGVhZGVyQ2VsbENvbXBvbmVudCBleHRlbmRzIENvbnRlbnRCYXNlQ29tcG9uZW50IGltcGxlbWVudHMgSGVhZENlbGxNb2RlbERhdGEge1xuICBASW5wdXQoKSBjbGFzc2VzOiBzdHJpbmc7XG4gIEBJbnB1dCgpIGlkOiBzdHJpbmc7XG4gIEBJbnB1dCgpIGNvbHNwYW46IG51bWJlcjtcbiAgQElucHV0KCkgcm93c3BhbjogbnVtYmVyO1xuICBASW5wdXQoKSBvcmRlckJ5OiBPcmRlckJ5OyAvLyBQb3NzaWJsZSB2YWx1ZXMgYG5vbmVgLCBgYXNjYCwgYGRlc2NgLlxuICBASW5wdXQoKSBoYXNGaWx0ZXI6IGJvb2xlYW47XG4gIEBJbnB1dCgpIGZpbHRlckNsYXNzZXM6IHN0cmluZztcbiAgQElucHV0KCkgaGFzU2VsZWN0PzogYm9vbGVhbjtcbiAgQElucHV0KCkgaWRlbnRpZmllcj86IHN0cmluZztcbiAgdmFsdWVGaWx0ZXI/OiBzdHJpbmcgfCBudWxsID0gbnVsbDtcbiAgYWN0aXZlRmlsdGVyPzogYm9vbGVhbjtcbiAgdmFsdWVTZWxlY3Q/OiBzdHJpbmc7XG4gIGFjdGl2ZVNlbGVjdD86IGJvb2xlYW47XG5cbiAgQERlc3lDb250ZW50Q2hpbGQoKVxuICBAQ29udGVudENoaWxkcmVuKFRhYmxlQWR2YW5jZWRTZWxlY3RDb21wb25lbnQpIHNlbGVjdENvbXBvbmVudD86IFRhYmxlQWR2YW5jZWRTZWxlY3RDb21wb25lbnQ7XG5cbiAgQERlc3lDb250ZW50Q2hpbGQoKVxuICBAQ29udGVudENoaWxkcmVuKENvbnRlbnRDb21wb25lbnQpIGNvbnRlbnRDb21wb25lbnQ/OiBDb250ZW50Q29tcG9uZW50O1xufVxuIl19