bit-ng-library 14.1.2 → 14.1.3

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.
package/README.md CHANGED
@@ -26,6 +26,10 @@ To get more help on the Angular CLI use `ng help` or go check out the [Angular C
26
26
 
27
27
  ## changelog
28
28
 
29
+ ## [14.1.3] - 2023-02-22
30
+
31
+ se corrige un fallo en el dropdown. Si se utiliza la opción valueAs="string" y se indica que se quiere generar un emptyValue al seleccionarlo, se mapea un 0 en el formcontrol en vez de un null
32
+
29
33
  ## [14.1.2] - 2023-02-22
30
34
 
31
35
  se añade FilesetModule en la lista de módulos de prime
@@ -95,7 +95,7 @@ export class BitDropDownComponent extends BitDropDownGeneralComponent {
95
95
  this.value = event.value;
96
96
  // convertimos el string selecionado del select a number
97
97
  if (this.valueAs == "string") {
98
- this.changeComponentValue(+event.value);
98
+ this.changeComponentValue(this.value != null ? +event.value : null);
99
99
  }
100
100
  else {
101
101
  this.changeComponentValue(event.value);
@@ -128,4 +128,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.8", ngImpor
128
128
  }], atributoDisabled: [{
129
129
  type: Input
130
130
  }] } });
131
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bit-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../projects/bit-ng-library/src/lib/sharedlibrary/components/form/dropdown/bit-dropdown.component.ts","../../../../../../../../projects/bit-ng-library/src/lib/sharedlibrary/components/form/dropdown/bit-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, Input, OnChanges, SimpleChange } from \"@angular/core\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\nimport { ActivatedRoute } from \"@angular/router\";\nimport { take } from \"rxjs/operators\";\n\nimport { AyudaService } from \"../../../services/ayuda.service\";\nimport { TranslateService } from \"../../../services/translate.service\";\nimport { BitDropDownGeneralComponent } from \"./bit-dropdown-general.component\";\n\n/**\n * Clase que utiliza un custom componente para select de elementos\n *    <bit-dropdown [domain]=\"'DOMAIN_TIPO_LOG'\" id=\"tipolog\" [control]=\"formControl\">&nbsp;&nbsp;Tipus d'operació</bit-dropdown>\n *\n * @input data: array de objetos a mostrar en el select. Puede ser null, en cuyo caso domain no puede ser null\n * @input domain: nombre del dominio que contiene los datos y que nos resolverá la página cuando cargue el componente. Puede ser null, en cuyo caso data no puede ser null\n * @input id: identificador del componente select\n * @input filter: true indicará que podemos buscar dentro del select, false que no.\n **/\n@Component({\n  selector: \"bit-dropdown\",\n  templateUrl: \"bit-dropdown.component.html\",\n  providers: [{\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => BitDropDownComponent),\n    multi: true\n  }]\n})\nexport class BitDropDownComponent extends BitDropDownGeneralComponent implements OnChanges, ControlValueAccessor {\n  @Input() filter: boolean = false;\n  @Input() atributoLabel = \"label\";       // El atributo de los objetos de la lista que corresponde al label\n  @Input() atributoValue = \"value\";       // El atributo de los objetos de la lista que corresponde al valor\n  @Input() atributoDisabled = \"inactivo\"; // El atributo de los objetos de la lista que indica si un valor está deshabilitado\n\n  constructor(\n    protected router: ActivatedRoute,\n    protected ayudaService: AyudaService,\n    protected translateService: TranslateService\n  ) {\n    super(router, ayudaService, translateService);\n  }\n\n  ngOnChanges(changes: { [propKey: string]: SimpleChange }) {\n    let hayCambios: boolean = false;\n    for (let propName in changes) {\n      let changedProp = changes[propName];\n      if (propName === \"data\") {\n        this.listaOpciones = changedProp.currentValue ? changedProp.currentValue.slice() : [];\n        hayCambios = true;\n      } else if (propName === \"excludedValues\") {\n        this.excludedValues = changedProp.currentValue;\n        hayCambios = true;\n      } else if (propName === \"includeEmpty\") {\n        this.includeEmpty = changedProp.currentValue;\n        hayCambios = true;\n      }\n    }\n    if (hayCambios) {\n      this.postRetrieveData();\n    }\n  }\n\n  // custom processing after retrieving data array from service\n  postRetrieveData() {\n    if (this.listaOpciones) {\n      this.listaOpcionesVisible = Object.assign([], this.listaOpciones);\n      // repasamos si hay opciones a excluir que debamos eliminar\n      if (this.excludedValues) {\n        this.listaOpcionesVisible = this.listaOpcionesVisible.filter((op) => this.excludedValues.indexOf(op.value) < 0);\n      }\n    } else {\n      this.listaOpcionesVisible = [];\n    }\n    // determinamos si debemos incluir la opción \"sin selección\" y con qué texto\n    if (this.includeEmpty) {\n      this.translateService\n        .selectTranslateWithContext(this.emptyText)\n        .pipe(take(1))\n        .subscribe((translation) => {\n          let newOption = {value: null, label: translation };\n          newOption[this.atributoValue] = null;\n          newOption[this.atributoLabel] = translation;\n          this.listaOpcionesVisible.splice(0, 0, newOption);\n          this.emptyTextResolved = translation;\n        });\n    }\n  }\n\n  get value_lectura(): string {\n    let dom = this.listaOpciones && this.listaOpciones.find((d) => d.value == this.value);\n    return dom ? dom.label : null;\n  }\n\n  writeValue(v: any): void {\n    if (this.valueAs == \"string\") {\n      // convertimos el number a string porque nos han dicho que el ID del select es string\n      this.value = v != null ? \"\"+v : v;\n    } else {\n      this.value = v;\n    }\n  }\n\n  _onChangeValue(event) {\n    this.value = event.value;\n    // convertimos el string selecionado del select a number\n    if (this.valueAs == \"string\") {\n      this.changeComponentValue(+event.value);\n    } else {\n      this.changeComponentValue(event.value);\n    }\n  }\n\n  _onClear() {\n    this.value = null;\n    this.changeComponentValue(this.value);\n  }\n}\n","<label *ngIf=\"!hideLabel\">\n  <ng-content></ng-content>&nbsp; <span *ngIf=\"obligatorio\" class=\"obligatorio fa fa-asterisk\"></span>&nbsp;&nbsp;\n  <i *ngIf=\"ayuda\" (click)=\"showAyuda()\" class=\"btn-ayuda fa fa-question\"></i>\n</label>\n<p *ngIf=\"readOnly\" class=\"lectura\" [id]=\"nombre\">{{ value_lectura }}</p>\n<ng-container *ngIf=\"!readOnly\">\n  <p-dropdown\n    id=\"{{ nombre }}\"\n    [(ngModel)]=\"value\"\n    [disabled]=\"isDisabled\"\n    [options]=\"listaOpcionesVisible\"\n    [filter]=\"filter\"\n    [optionLabel]=\"atributoLabel\"\n    [optionValue]=\"atributoValue\"\n    [optionDisabled]=\"atributoDisabled\"\n    [appendTo]=\"appendTo\"\n    (onChange)=\"_onChangeValue($event)\"\n    (onClear)=\"_onClear()\"\n    (onBlur)=\"_onBlur()\"\n    (onFocus)=\"_onFocus()\"\n    attr.data-testid=\"{{ dataTestId }}\"\n  >\n    <ng-template let-item pTemplate=\"item\">\n      <span [ngClass]=\"{ 'opcion-desactivada': item[atributoDisabled] }\">{{ item[atributoLabel] }}</span>\n    </ng-template>\n  </p-dropdown>\n  <control-messages *ngIf=\"control != null\" [control]=\"control\" [field]=\"id\"></control-messages>\n</ng-container>\n"]}
131
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bit-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../projects/bit-ng-library/src/lib/sharedlibrary/components/form/dropdown/bit-dropdown.component.ts","../../../../../../../../projects/bit-ng-library/src/lib/sharedlibrary/components/form/dropdown/bit-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, forwardRef, Input, OnChanges, SimpleChange } from \"@angular/core\";\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from \"@angular/forms\";\nimport { ActivatedRoute } from \"@angular/router\";\nimport { take } from \"rxjs/operators\";\n\nimport { AyudaService } from \"../../../services/ayuda.service\";\nimport { TranslateService } from \"../../../services/translate.service\";\nimport { BitDropDownGeneralComponent } from \"./bit-dropdown-general.component\";\n\n/**\n * Clase que utiliza un custom componente para select de elementos\n *    <bit-dropdown [domain]=\"'DOMAIN_TIPO_LOG'\" id=\"tipolog\" [control]=\"formControl\">&nbsp;&nbsp;Tipus d'operació</bit-dropdown>\n *\n * @input data: array de objetos a mostrar en el select. Puede ser null, en cuyo caso domain no puede ser null\n * @input domain: nombre del dominio que contiene los datos y que nos resolverá la página cuando cargue el componente. Puede ser null, en cuyo caso data no puede ser null\n * @input id: identificador del componente select\n * @input filter: true indicará que podemos buscar dentro del select, false que no.\n **/\n@Component({\n  selector: \"bit-dropdown\",\n  templateUrl: \"bit-dropdown.component.html\",\n  providers: [{\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => BitDropDownComponent),\n    multi: true\n  }]\n})\nexport class BitDropDownComponent extends BitDropDownGeneralComponent implements OnChanges, ControlValueAccessor {\n  @Input() filter: boolean = false;\n  @Input() atributoLabel = \"label\";       // El atributo de los objetos de la lista que corresponde al label\n  @Input() atributoValue = \"value\";       // El atributo de los objetos de la lista que corresponde al valor\n  @Input() atributoDisabled = \"inactivo\"; // El atributo de los objetos de la lista que indica si un valor está deshabilitado\n\n  constructor(\n    protected router: ActivatedRoute,\n    protected ayudaService: AyudaService,\n    protected translateService: TranslateService\n  ) {\n    super(router, ayudaService, translateService);\n  }\n\n  ngOnChanges(changes: { [propKey: string]: SimpleChange }) {\n    let hayCambios: boolean = false;\n    for (let propName in changes) {\n      let changedProp = changes[propName];\n      if (propName === \"data\") {\n        this.listaOpciones = changedProp.currentValue ? changedProp.currentValue.slice() : [];\n        hayCambios = true;\n      } else if (propName === \"excludedValues\") {\n        this.excludedValues = changedProp.currentValue;\n        hayCambios = true;\n      } else if (propName === \"includeEmpty\") {\n        this.includeEmpty = changedProp.currentValue;\n        hayCambios = true;\n      }\n    }\n    if (hayCambios) {\n      this.postRetrieveData();\n    }\n  }\n\n  // custom processing after retrieving data array from service\n  postRetrieveData() {\n    if (this.listaOpciones) {\n      this.listaOpcionesVisible = Object.assign([], this.listaOpciones);\n      // repasamos si hay opciones a excluir que debamos eliminar\n      if (this.excludedValues) {\n        this.listaOpcionesVisible = this.listaOpcionesVisible.filter((op) => this.excludedValues.indexOf(op.value) < 0);\n      }\n    } else {\n      this.listaOpcionesVisible = [];\n    }\n    // determinamos si debemos incluir la opción \"sin selección\" y con qué texto\n    if (this.includeEmpty) {\n      this.translateService\n        .selectTranslateWithContext(this.emptyText)\n        .pipe(take(1))\n        .subscribe((translation) => {\n          let newOption = { value: null, label: translation };\n          newOption[this.atributoValue] = null;\n          newOption[this.atributoLabel] = translation;\n          this.listaOpcionesVisible.splice(0, 0, newOption);\n          this.emptyTextResolved = translation;\n        });\n    }\n  }\n\n  get value_lectura(): string {\n    let dom = this.listaOpciones && this.listaOpciones.find((d) => d.value == this.value);\n    return dom ? dom.label : null;\n  }\n\n  writeValue(v: any): void {\n    if (this.valueAs == \"string\") {\n      // convertimos el number a string porque nos han dicho que el ID del select es string\n      this.value = v != null ? \"\" + v : v;\n    } else {\n      this.value = v;\n    }\n  }\n\n  _onChangeValue(event) {\n    this.value = event.value;\n    // convertimos el string selecionado del select a number\n    if (this.valueAs == \"string\") {\n      this.changeComponentValue(this.value != null ? +event.value : null);\n    } else {\n      this.changeComponentValue(event.value);\n    }\n  }\n\n  _onClear() {\n    this.value = null;\n    this.changeComponentValue(this.value);\n  }\n}\n","<label *ngIf=\"!hideLabel\">\n  <ng-content></ng-content>&nbsp; <span *ngIf=\"obligatorio\" class=\"obligatorio fa fa-asterisk\"></span>&nbsp;&nbsp;\n  <i *ngIf=\"ayuda\" (click)=\"showAyuda()\" class=\"btn-ayuda fa fa-question\"></i>\n</label>\n<p *ngIf=\"readOnly\" class=\"lectura\" [id]=\"nombre\">{{ value_lectura }}</p>\n<ng-container *ngIf=\"!readOnly\">\n  <p-dropdown\n    id=\"{{ nombre }}\"\n    [(ngModel)]=\"value\"\n    [disabled]=\"isDisabled\"\n    [options]=\"listaOpcionesVisible\"\n    [filter]=\"filter\"\n    [optionLabel]=\"atributoLabel\"\n    [optionValue]=\"atributoValue\"\n    [optionDisabled]=\"atributoDisabled\"\n    [appendTo]=\"appendTo\"\n    (onChange)=\"_onChangeValue($event)\"\n    (onClear)=\"_onClear()\"\n    (onBlur)=\"_onBlur()\"\n    (onFocus)=\"_onFocus()\"\n    attr.data-testid=\"{{ dataTestId }}\"\n  >\n    <ng-template let-item pTemplate=\"item\">\n      <span [ngClass]=\"{ 'opcion-desactivada': item[atributoDisabled] }\">{{ item[atributoLabel] }}</span>\n    </ng-template>\n  </p-dropdown>\n  <control-messages *ngIf=\"control != null\" [control]=\"control\" [field]=\"id\"></control-messages>\n</ng-container>\n"]}
@@ -4393,7 +4393,7 @@ class BitDropDownComponent extends BitDropDownGeneralComponent {
4393
4393
  this.value = event.value;
4394
4394
  // convertimos el string selecionado del select a number
4395
4395
  if (this.valueAs == "string") {
4396
- this.changeComponentValue(+event.value);
4396
+ this.changeComponentValue(this.value != null ? +event.value : null);
4397
4397
  }
4398
4398
  else {
4399
4399
  this.changeComponentValue(event.value);